From 6ae7bc79818da4aac981d62ec9c578c286e93e65 Mon Sep 17 00:00:00 2001 From: Dennis Eichhorn Date: Mon, 14 Feb 2022 00:00:25 +0100 Subject: [PATCH] improve media upload --- Controller/ApiController.php | 110 ++++++++++++++++++++++++++++------- 1 file changed, 89 insertions(+), 21 deletions(-) diff --git a/Controller/ApiController.php b/Controller/ApiController.php index 416125e..08384fe 100755 --- a/Controller/ApiController.php +++ b/Controller/ApiController.php @@ -14,8 +14,13 @@ declare(strict_types=1); namespace Modules\News\Controller; +use Modules\Admin\Models\AccountMapper; use Modules\Admin\Models\NullAccount; +use Modules\Media\Models\CollectionMapper; +use Modules\Media\Models\MediaMapper; use Modules\Media\Models\NullMedia; +use Modules\Media\Models\Reference; +use Modules\Media\Models\ReferenceMapper; use Modules\News\Models\NewsArticle; use Modules\News\Models\NewsArticleMapper; use Modules\News\Models\NewsStatus; @@ -144,9 +149,93 @@ final class ApiController extends Controller $newsArticle = $this->createNewsArticleFromRequest($request); $this->createModel($request->header->account, $newsArticle, NewsArticleMapper::class, 'news', $request->getOrigin()); + + if (!empty($request->getFiles() ?? []) + || !empty($request->getDataJson('media') ?? []) + ) { + $this->createNewsMedia($newsArticle, $request); + } + $this->fillJsonResponse($request, $response, NotificationLevel::OK, 'News', 'News successfully created', $newsArticle); } + private function createNewsMedia(NewsArticle $news, RequestAbstract $request) : void + { + $path = $this->createNewsDir($news); + $account = AccountMapper::get()->where('id', $request->header->account)->execute(); + + if (!empty($uploadedFiles = $request->getFiles() ?? [])) { + $uploaded = $this->app->moduleManager->get('Media')->uploadFiles( + [], + [], + $uploadedFiles, + $request->header->account, + __DIR__ . '/../../../Modules/Media/Files' . $path, + $path, + ); + + $collection = null; + + foreach ($uploaded as $media) { + MediaMapper::create()->execute($media); + NewsArticleMapper::writer()->createRelationTable('media', [$media->getId()], $news->getId()); + + $ref = new Reference(); + $ref->source = new NullMedia($media->getId()); + $ref->createdBy = new NullAccount($request->header->account); + $ref->setVirtualPath($accountPath = '/Accounts/' . $account->getId() . ' ' . $account->login . '/News/' . $news->createdAt->format('Y') . '/' . $news->createdAt->format('m') . '/' . $news->getId()); + + ReferenceMapper::create()->execute($ref); + + if ($collection === null) { + $collection = $this->app->moduleManager->get('Media')->createRecursiveMediaCollection( + '/Modules/Media/Files', + $accountPath, + $request->header->account, + __DIR__ . '/../../../Modules/Media/Files/Accounts/' . $account->getId() . '/News/' . $news->createdAt->format('Y') . '/' . $news->createdAt->format('m') . '/' . $news->getId() + ); + } + + CollectionMapper::writer()->createRelationTable('sources', [$ref->getId()], $collection->getId()); + } + } + + if (!empty($mediaFiles = $request->getDataJson('media') ?? [])) { + $collection = null; + + foreach ($mediaFiles as $media) { + NewsArticleMapper::writer()->createRelationTable('media', [(int) $media], $news->getId()); + + $ref = new Reference(); + $ref->source = new NullMedia((int) $media); + $ref->createdBy = new NullAccount($request->header->account); + $ref->setVirtualPath($path); + + ReferenceMapper::create()->execute($ref); + + if ($collection === null) { + $collection = $this->app->moduleManager->get('Media')->createRecursiveMediaCollection( + '/Modules/Media/Files', + $path, + $request->header->account, + __DIR__ . '/../../../Modules/Media/Files' . $path + ); + } + + CollectionMapper::writer()->createRelationTable('sources', [$ref->getId()], $collection->getId()); + } + } + } + + private function createNewsDir(NewsArticle $news) : string + { + return '/Modules/News/' + . $news->createdAt->format('Y') . '/' + . $news->createdAt->format('m') . '/' + . $news->createdAt->format('d') . '/' + . $news->getId(); + } + /** * Method to create news article from request. * @@ -195,27 +284,6 @@ final class ApiController extends Controller } } - if (!empty($uploadedFiles = $request->getFiles() ?? [])) { - $uploaded = $this->app->moduleManager->get('Media')->uploadFiles( - [], - [], - $uploadedFiles, - $request->header->account, - __DIR__ . '/../../../Modules/Media/Files/Modules/News', - '/Modules/News', - ); - - foreach ($uploaded as $media) { - $newsArticle->addMedia($media); - } - } - - if (!empty($mediaFiles = $request->getDataJson('media') ?? [])) { - foreach ($mediaFiles as $media) { - $newsArticle->addMedia(new NullMedia($media)); - } - } - return $newsArticle; }