]> git.mxchange.org Git - friendica.git/blobdiff - src/Module/Attach.php
Standards
[friendica.git] / src / Module / Attach.php
index eed1275c58cbb52d2729ebae171c7565831189a7..bd785881c3d067a9a36cdfb0a17bf2ae7b84740c 100644 (file)
@@ -1,53 +1,64 @@
 <?php
 /**
- * @file src/Module/Attach.php
+ * @copyright Copyright (C) 2010-2021, the Friendica project
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program.  If not, see <https://www.gnu.org/licenses/>.
+ *
  */
 
-
 namespace Friendica\Module;
 
 use Friendica\BaseModule;
-use Friendica\Core\L10n;
-use Friendica\Core\System;
 use Friendica\Core\Logger;
+use Friendica\DI;
 use Friendica\Model\Attach as MAttach;
 
 /**
- * @brief Attach Module
+ * Attach Module
  */
 class Attach extends BaseModule
 {
        /**
-        * @brief Module initializer
-        *
-        * Fetch an attached file given the id
+        * Return to user an attached file given the id
         */
-       public static function init()
+       protected function rawContent(array $request = [])
        {
-               $a = self::getApp();
-               if ($a->argc != 2) {
-                       System::httpExit(400); // Bad Request.
+               $a = DI::app();
+               if (empty($this->parameters['item'])) {
+                       throw new \Friendica\Network\HTTPException\BadRequestException();
                }
-       
 
-               $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
                $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"
@@ -64,4 +75,4 @@ class Attach extends BaseModule
                exit();
                // NOTREACHED
        }
-}
\ No newline at end of file
+}