X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FModule%2FAttach.php;h=7d877c12655b0a11efa78413a0debaadc1e8d93c;hb=3bca4fe2a64671d09e08346456cdfa6c12f996e9;hp=24e0edc5552ad774d7187573249835acd31474b7;hpb=10114661d40b740146a66f75771aeddc17c4242e;p=friendica.git diff --git a/src/Module/Attach.php b/src/Module/Attach.php index 24e0edc555..7d877c1265 100644 --- a/src/Module/Attach.php +++ b/src/Module/Attach.php @@ -1,51 +1,64 @@ . + * */ - namespace Friendica\Module; use Friendica\BaseModule; -use Friendica\Core\L10n; use Friendica\Core\Logger; use Friendica\Core\System; +use Friendica\DI; use Friendica\Model\Attach as MAttach; /** - * @brief Attach Module + * Attach Module */ class Attach extends BaseModule { /** - * @brief Return to user an attached file given the id + * Return to user an attached file given the id */ - public static function rawContent() + protected function rawContent(array $request = []) { - $a = self::getApp(); - if ($a->argc != 2) { - System::httpExit(400); // Bad Request. + if (empty($this->parameters['item'])) { + throw new \Friendica\Network\HTTPException\BadRequestException(); } - // @TODO: Replace with parameter from router - $item_id = intval($a->argv[1]); - + $item_id = intval($this->parameters['item']); + // Check for existence $item = MAttach::exists(['id' => $item_id]); if ($item === false) { - System::httpExit(404, ['description' => L10n::t('Item was not found.')]); + throw new \Friendica\Network\HTTPException\NotFoundException(DI::l10n()->t('Item was not found.')); } - // Now we'll fetch the item, if we have enough permisson + // Now we'll fetch the item, if we have enough permission $item = MAttach::getByIdWithPermission($item_id); if ($item === false) { - System::httpExit(403, ['description' => L10n::t('Permission denied.')]); + throw new \Friendica\Network\HTTPException\ForbiddenException(DI::l10n()->t('Permission denied.')); } $data = MAttach::getData($item); if (is_null($data)) { - Logger::log('NULL data for attachment with id ' . $item['id']); - System::httpExit(404, ['description' => L10n::t('Item was not found.')]); + Logger::notice('NULL data for attachment with id ' . $item['id']); + throw new \Friendica\Network\HTTPException\NotFoundException(DI::l10n()->t('Item was not found.')); } // Use quotes around the filename to prevent a "multiple Content-Disposition" @@ -59,7 +72,7 @@ class Attach extends BaseModule } echo $data; - exit(); + System::exit(); // NOTREACHED } }