123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- <?php
- /*
- * @copyright Copyright (c) 2019 Sergio Brighenti <sergio@brighenti.me>
- *
- * @author Sergio Brighenti <sergio@brighenti.me>
- *
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * 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, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- */
- namespace App\Controllers;
- use App\Database\DB;
- use App\Web\Lang;
- use App\Web\Session;
- use App\Web\View;
- use DI\Container;
- use DI\DependencyException;
- use DI\NotFoundException;
- use League\Flysystem\FileNotFoundException;
- use League\Flysystem\Filesystem;
- use Monolog\Logger;
- use Psr\Http\Message\ServerRequestInterface as Request;
- use Slim\Exception\HttpNotFoundException;
- use Slim\Exception\HttpUnauthorizedException;
- /**
- * @property Session|null session
- * @property View view
- * @property DB|null database
- * @property Logger|null logger
- * @property Filesystem|null storage
- * @property Lang lang
- * @property array config
- */
- abstract class Controller
- {
- /** @var Container */
- protected $container;
- public function __construct(Container $container)
- {
- $this->container = $container;
- }
- /**
- * @param $name
- *
- * @throws DependencyException
- * @throws NotFoundException
- *
- * @return mixed|null
- */
- public function __get($name)
- {
- if ($this->container->has($name)) {
- return $this->container->get($name);
- }
- }
- /**
- * @param $id
- *
- * @return int
- */
- protected function getUsedSpaceByUser($id): int
- {
- $medias = $this->database->query('SELECT `uploads`.`storage_path` FROM `uploads` WHERE `user_id` = ?', $id);
- $totalSize = 0;
- $filesystem = $this->storage;
- foreach ($medias as $media) {
- try {
- $totalSize += $filesystem->getSize($media->storage_path);
- } catch (FileNotFoundException $e) {
- $this->logger->error('Error calculating file size', array('exception' => $e));
- }
- }
- return $totalSize;
- }
- /**
- * @param Request $request
- * @param $id
- * @param bool $authorize
- *
- * @throws HttpNotFoundException
- * @throws HttpUnauthorizedException
- *
- * @return mixed
- */
- protected function getUser(Request $request, $id, $authorize = false)
- {
- $user = $this->database->query('SELECT * FROM `users` WHERE `id` = ? LIMIT 1', $id)->fetch();
- if (!$user) {
- throw new HttpNotFoundException($request);
- }
- if ($authorize && $user->id !== $this->session->get('user_id') && !$this->session->get('admin', false)) {
- throw new HttpUnauthorizedException($request);
- }
- return $user;
- }
- }
|