More robust
This commit is contained in:
@@ -5,21 +5,29 @@ declare(strict_types=1);
|
||||
class MediaController extends BaseController
|
||||
{
|
||||
private const UPLOAD_MAX_BYTES = 10 * 1024 * 1024; // 10 Mo
|
||||
private const PER_PAGE = 24;
|
||||
|
||||
public function beforeRoute(): void
|
||||
{
|
||||
$this->requireAuth();
|
||||
$this->disableCache();
|
||||
}
|
||||
|
||||
public function index(): void
|
||||
{
|
||||
$this->requireAuth();
|
||||
$this->f3->expire(0);
|
||||
$page = max(1, (int) ($this->f3->get('GET.page') ?? 1));
|
||||
$result = (new Media($this->db))->paginateLibrary($page, self::PER_PAGE);
|
||||
|
||||
$this->render('admin/media.html', [
|
||||
$this->renderSession('admin/media.html', [
|
||||
'pageTitle' => 'Médiathèque',
|
||||
'items' => (new Media($this->db))->all(),
|
||||
]);
|
||||
'items' => $result['items'],
|
||||
'pagination' => $result,
|
||||
'paginationAlias' => 'media_index',
|
||||
], true);
|
||||
}
|
||||
|
||||
public function upload(): void
|
||||
{
|
||||
$this->requireAuth();
|
||||
$this->verifyCsrf();
|
||||
|
||||
try {
|
||||
@@ -27,7 +35,8 @@ class MediaController extends BaseController
|
||||
$originalName = (string) ($this->f3->get('FILES.image.name') ?? '');
|
||||
|
||||
$received = Web::instance()->receive(
|
||||
fn(array $file): bool => $file['size'] <= self::UPLOAD_MAX_BYTES,
|
||||
fn(array $file): bool => (int) ($file['size'] ?? 0) > 0
|
||||
&& (int) ($file['size'] ?? 0) <= self::UPLOAD_MAX_BYTES,
|
||||
overwrite: false,
|
||||
slug: true
|
||||
);
|
||||
@@ -36,7 +45,7 @@ class MediaController extends BaseController
|
||||
$accepted = array_keys(array_filter($received));
|
||||
|
||||
if ($accepted === []) {
|
||||
throw new RuntimeException('Choisis une image valide à envoyer (JPG, PNG, WebP ≤ ' . (int)(self::UPLOAD_MAX_BYTES / 1024 / 1024) . ' Mo).');
|
||||
throw new RuntimeException('Choisis une image valide à envoyer (JPG, PNG, WebP ≤ ' . (int) (self::UPLOAD_MAX_BYTES / 1024 / 1024) . ' Mo).');
|
||||
}
|
||||
|
||||
foreach ($accepted as $destPath) {
|
||||
@@ -48,12 +57,11 @@ class MediaController extends BaseController
|
||||
$this->flash('error', $e->getMessage());
|
||||
}
|
||||
|
||||
$this->f3->reroute($this->f3->alias('media_index'));
|
||||
$this->f3->reroute('@media_index');
|
||||
}
|
||||
|
||||
public function updateAlt(): void
|
||||
{
|
||||
$this->requireAuth();
|
||||
$this->verifyCsrf();
|
||||
|
||||
try {
|
||||
@@ -64,12 +72,11 @@ class MediaController extends BaseController
|
||||
$this->flash('error', $e->getMessage());
|
||||
}
|
||||
|
||||
$this->f3->reroute($this->f3->alias('media_index'));
|
||||
$this->f3->reroute('@media_index');
|
||||
}
|
||||
|
||||
public function delete(): void
|
||||
{
|
||||
$this->requireAuth();
|
||||
$this->verifyCsrf();
|
||||
|
||||
try {
|
||||
@@ -79,6 +86,6 @@ class MediaController extends BaseController
|
||||
$this->flash('error', $e->getMessage());
|
||||
}
|
||||
|
||||
$this->f3->reroute($this->f3->alias('media_index'));
|
||||
$this->f3->reroute('@media_index');
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user