X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FModule%2FFiler%2FSaveTag.php;h=3adf4f1fb5fc2e3ec57e257c01402487bf4bad98;hb=561aba18e3a230c0912ad9483c6df43cc40e09d6;hp=1db3384ca5eed51977465a0f3c0a55b12ebe1916;hpb=bd62d548db39b617d087aabb536435004adf0470;p=friendica.git diff --git a/src/Module/Filer/SaveTag.php b/src/Module/Filer/SaveTag.php index 1db3384ca5..3adf4f1fb5 100644 --- a/src/Module/Filer/SaveTag.php +++ b/src/Module/Filer/SaveTag.php @@ -1,52 +1,76 @@ . + * + */ namespace Friendica\Module\Filer; +use Friendica\App; use Friendica\BaseModule; use Friendica\Core\L10n; -use Friendica\Core\PConfig; use Friendica\Core\Renderer; +use Friendica\Database\DBA; use Friendica\Model; +use Friendica\Module\Response; +use Friendica\Network\HTTPException; +use Friendica\Util\Profiler; use Friendica\Util\XML; +use Psr\Log\LoggerInterface; /** * Shows a dialog for adding tags to a file */ class SaveTag extends BaseModule { - public static function init($parameters) + public function __construct(L10n $l10n, App\BaseURL $baseUrl, App\Arguments $args, LoggerInterface $logger, Profiler $profiler, Response $response, array $server, array $parameters = []) { + parent::__construct($l10n, $baseUrl, $args, $logger, $profiler, $response, $server, $parameters); + if (!local_user()) { - info(L10n::t('You must be logged in to use this module')); - self::getApp()->internalRedirect(); + notice($this->t('You must be logged in to use this module')); + $baseUrl->redirect(); } } - public static function rawContent($parameters) + protected function rawContent(array $request = []) { - $a = self::getApp(); - $logger = $a->getLogger(); - $term = XML::unescape(trim($_GET['term'] ?? '')); - // @TODO: Replace with parameter from router - $item_id = (($a->argc > 1) ? intval($a->argv[1]) : 0); - $logger->info('filer', ['tag' => $term, 'item' => $item_id]); + $item_id = $this->parameters['id'] ?? 0; + + $this->logger->info('filer', ['tag' => $term, 'item' => $item_id]); if ($item_id && strlen($term)) { - // file item - Model\FileTag::saveFile(local_user(), $item_id, $term); - info(L10n::t('Filetag %s saved to item', $term)); + $item = Model\Post::selectFirst(['uri-id'], ['id' => $item_id]); + if (!DBA::isResult($item)) { + throw new HTTPException\NotFoundException(); + } + Model\Post\Category::storeFileByURIId($item['uri-id'], local_user(), Model\Post\Category::FILE, $term); } // return filer dialog - $filetags = PConfig::get(local_user(), 'system', 'filetags', ''); - $filetags = Model\FileTag::fileToArray($filetags); + $filetags = Model\Post\Category::getArray(local_user(), Model\Post\Category::FILE); $tpl = Renderer::getMarkupTemplate("filer_dialog.tpl"); echo Renderer::replaceMacros($tpl, [ - '$field' => ['term', L10n::t("Save to Folder:"), '', '', $filetags, L10n::t('- select -')], - '$submit' => L10n::t('Save'), + '$field' => ['term', $this->t("Save to Folder:"), '', '', $filetags, $this->t('- select -')], + '$submit' => $this->t('Save'), ]); exit;