mirror of
https://code.castopod.org/adaures/castopod
synced 2025-05-12 17:25:45 +00:00
119 lines
3.3 KiB
PHP
119 lines
3.3 KiB
PHP
![]() |
<?php
|
||
|
|
||
|
declare(strict_types=1);
|
||
|
|
||
|
/**
|
||
|
* @copyright 2022 Ad Aures
|
||
|
* @license https://www.gnu.org/licenses/agpl-3.0.en.html AGPL3
|
||
|
* @link https://castopod.org/
|
||
|
*/
|
||
|
|
||
|
namespace Modules\PremiumPodcasts\Controllers;
|
||
|
|
||
|
use App\Controllers\BaseController;
|
||
|
use App\Entities\Podcast;
|
||
|
use App\Models\PodcastModel;
|
||
|
use CodeIgniter\Exceptions\PageNotFoundException;
|
||
|
use CodeIgniter\HTTP\RedirectResponse;
|
||
|
use Modules\PremiumPodcasts\PremiumPodcasts;
|
||
|
|
||
|
class LockController extends BaseController
|
||
|
{
|
||
|
protected Podcast $podcast;
|
||
|
|
||
|
protected PremiumPodcasts $premiumPodcasts;
|
||
|
|
||
|
public function __construct()
|
||
|
{
|
||
|
$this->premiumPodcasts = service('premium_podcasts');
|
||
|
}
|
||
|
|
||
|
public function _remap(string $method, string ...$params): mixed
|
||
|
{
|
||
|
if ($params === []) {
|
||
|
throw PageNotFoundException::forPageNotFound();
|
||
|
}
|
||
|
|
||
|
if (($podcast = (new PodcastModel())->getPodcastByHandle($params[0])) === null) {
|
||
|
throw PageNotFoundException::forPageNotFound();
|
||
|
}
|
||
|
|
||
|
$this->podcast = $podcast;
|
||
|
|
||
|
return $this->{$method}();
|
||
|
}
|
||
|
|
||
|
public function index(): string
|
||
|
{
|
||
|
$locale = service('request')
|
||
|
->getLocale();
|
||
|
$cacheName =
|
||
|
"page_podcast#{$this->podcast->id}_{$locale}_unlock" .
|
||
|
(can_user_interact() ? '_authenticated' : '');
|
||
|
|
||
|
if (! ($cachedView = cache($cacheName))) {
|
||
|
$data = [
|
||
|
// TODO: metatags for locked premium podcasts
|
||
|
'metatags' => '',
|
||
|
'podcast' => $this->podcast,
|
||
|
];
|
||
|
|
||
|
helper('form');
|
||
|
|
||
|
if (can_user_interact()) {
|
||
|
return view('podcast/unlock', $data);
|
||
|
}
|
||
|
|
||
|
// The page cache is set to a decade so it is deleted manually upon podcast update
|
||
|
return view('podcast/unlock', $data, [
|
||
|
'cache' => DECADE,
|
||
|
'cache_name' => $cacheName,
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
return $cachedView;
|
||
|
}
|
||
|
|
||
|
public function attemptUnlock(): RedirectResponse
|
||
|
{
|
||
|
$rules = [
|
||
|
'token' => 'required',
|
||
|
];
|
||
|
|
||
|
if (! $this->validate($rules)) {
|
||
|
return redirect()->back()
|
||
|
->withInput()
|
||
|
->with('errors', $this->validator->getErrors());
|
||
|
}
|
||
|
|
||
|
$token = (string) $this->request->getPost('token');
|
||
|
|
||
|
// attempt unlocking the podcast with the token
|
||
|
if (! $this->premiumPodcasts->unlock($this->podcast->handle, $token)) {
|
||
|
// bad key or subscription is not active
|
||
|
return redirect()->back()
|
||
|
->withInput()
|
||
|
->with('error', lang('PremiumPodcasts.messages.unlockBadAttempt'));
|
||
|
}
|
||
|
|
||
|
$redirectURL = session('redirect_url') ?? site_url('/');
|
||
|
unset($_SESSION['redirect_url']);
|
||
|
|
||
|
return redirect()->to($redirectURL)
|
||
|
->withCookies()
|
||
|
->with('message', lang('PremiumPodcasts.messages.unlockSuccess'));
|
||
|
}
|
||
|
|
||
|
public function attemptLock(): RedirectResponse
|
||
|
{
|
||
|
$this->premiumPodcasts->lock($this->podcast->handle);
|
||
|
|
||
|
$redirectURL = session('redirect_url') ?? site_url('/');
|
||
|
unset($_SESSION['redirect_url']);
|
||
|
|
||
|
return redirect()->to($redirectURL)
|
||
|
->withCookies()
|
||
|
->with('message', lang('PremiumPodcasts.messages.lockSuccess'));
|
||
|
}
|
||
|
}
|