remove torrent file limits

This commit is contained in:
ghost 2023-10-09 22:58:55 +03:00
parent e591fe36a1
commit b25cc173c5
3 changed files with 16 additions and 40 deletions

2
.env
View File

@ -63,6 +63,4 @@ APP_PAGE_TITLE_LENGTH_MIN=10
APP_PAGE_TITLE_LENGTH_MAX=255 APP_PAGE_TITLE_LENGTH_MAX=255
APP_PAGE_DESCRIPTION_LENGTH_MIN=0 APP_PAGE_DESCRIPTION_LENGTH_MIN=0
APP_PAGE_DESCRIPTION_LENGTH_MAX=10000 APP_PAGE_DESCRIPTION_LENGTH_MAX=10000
APP_PAGE_TORRENT_FILE_QUANTITY_MIN=1
APP_PAGE_TORRENT_FILE_QUANTITY_MAX=100
APP_TORRENT_FILE_SIZE_MAX=1024000 APP_TORRENT_FILE_SIZE_MAX=1024000

View File

@ -16,8 +16,6 @@ parameters:
app.page.title.length.max: '%env(APP_PAGE_TITLE_LENGTH_MAX)%' app.page.title.length.max: '%env(APP_PAGE_TITLE_LENGTH_MAX)%'
app.page.description.length.min: '%env(APP_PAGE_DESCRIPTION_LENGTH_MIN)%' app.page.description.length.min: '%env(APP_PAGE_DESCRIPTION_LENGTH_MIN)%'
app.page.description.length.max: '%env(APP_PAGE_DESCRIPTION_LENGTH_MAX)%' app.page.description.length.max: '%env(APP_PAGE_DESCRIPTION_LENGTH_MAX)%'
app.page.torrent.file.quantity.min: '%env(APP_PAGE_TORRENT_FILE_QUANTITY_MIN)%'
app.page.torrent.file.quantity.max: '%env(APP_PAGE_TORRENT_FILE_QUANTITY_MAX)%'
app.torrent.size.max: '%env(APP_TORRENT_FILE_SIZE_MAX)%' app.torrent.size.max: '%env(APP_TORRENT_FILE_SIZE_MAX)%'
services: services:

View File

@ -120,11 +120,7 @@ class PageController extends AbstractController
'error' => [], 'error' => [],
'attribute' => 'attribute' =>
[ [
'placeholder' => sprintf( 'placeholder' => $translator->trans('Select torrent file')
$translator->trans('Append %s-%s torrent files'),
$this->getParameter('app.page.torrent.file.quantity.min'),
$this->getParameter('app.page.torrent.file.quantity.max')
)
] ]
], ],
'sensitive' => 'sensitive' =>
@ -170,35 +166,30 @@ class PageController extends AbstractController
} }
/// Torrents /// Torrents
$total = 0;
$torrents = []; $torrents = [];
if ($files = $request->files->get('torrents')) if ($files = $request->files->get('torrents'))
{ {
foreach ($files as $file) foreach ($files as $file)
{ {
//// Quantity /// Torrent
$total++; if ($file = $request->files->get('torrent'))
//// File size
if (filesize($file->getPathName()) > $this->getParameter('app.torrent.size.max'))
{ {
$form['torrents']['error'][] = $translator->trans('Torrent file out of size limit'); //// Validate torrent file
if (filesize($file->getPathName()) > $this->getParameter('app.torrent.size.max'))
{
$form['torrents']['error'][] = $translator->trans('Torrent file out of size limit');
continue; continue;
} }
//// Validate torrent format //// Validate torrent format
try if (!$torrentService->readTorrentFileByFilepath($file->getPathName()))
{ {
\Rhilip\Bencode\TorrentFile::load( $form['torrents']['error'][] = $translator->trans('Could not parse torrent file');
$file->getPathName()
);
}
catch (ParseException $e) continue;
{ }
$form['torrents']['error'][] = $translator->trans('Could not parse torrent file');
} }
//// Content //// Content
@ -206,7 +197,7 @@ class PageController extends AbstractController
$file->getPathName(), $file->getPathName(),
$user->getId(), $user->getId(),
time(), time(),
(array) $locales, [$request->get('locale')],
(bool) $request->get('sensitive'), (bool) $request->get('sensitive'),
$user->isApproved() $user->isApproved()
); );
@ -215,17 +206,6 @@ class PageController extends AbstractController
} }
} }
if ($total < $this->getParameter('app.page.torrent.file.quantity.min') ||
$total > $this->getParameter('app.page.torrent.file.quantity.max'))
{
$form['torrents']['error'][] = sprintf(
$translator->trans('Torrents quantity out of %s-%s range'),
number_format($this->getParameter('app.page.torrent.file.quantity.min')),
number_format($this->getParameter('app.page.torrent.file.quantity.max'))
);
}
if (empty($form['locale']['error']) && if (empty($form['locale']['error']) &&
empty($form['title']['error']) && empty($form['title']['error']) &&
empty($form['description']['error']) && empty($form['description']['error']) &&