123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170 |
- <?php
- namespace App\Controllers;
- use App\Database\DB;
- use App\Database\Queries\UserQuery;
- use App\Web\Lang;
- use App\Web\Session;
- use App\Web\ValidationChecker;
- use App\Web\View;
- use DI\Container;
- use DI\DependencyException;
- use DI\NotFoundException;
- use Exception;
- use League\Flysystem\Filesystem;
- use Monolog\Logger;
- use Psr\Http\Message\ServerRequestInterface as Request;
- /**
- * @property Session session
- * @property View view
- * @property DB 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
- *
- * @return mixed|null
- * @throws NotFoundException
- *
- * @throws DependencyException
- */
- public function __get($name)
- {
- if ($this->container->has($name)) {
- return $this->container->get($name);
- }
- return null;
- }
- /**
- * @param $key
- * @param null $default
- * @return object
- */
- protected function getSetting($key, $default = null)
- {
- return $this->database->query('SELECT `value` FROM `settings` WHERE `key` = '.$this->database->getPdo()->quote($key))->fetch()->value ?? $default;
- }
- /**
- * @param $current
- * @param $max
- */
- protected function setSessionQuotaInfo($current, $max)
- {
- $this->session->set('current_disk_quota', humanFileSize($current));
- if ($this->getSetting('quota_enabled', 'off') === 'on') {
- if ($max < 0) {
- $this->session->set('max_disk_quota', '∞');
- $this->session->set('percent_disk_quota', null);
- } else {
- $this->session->set('max_disk_quota', humanFileSize($max));
- $this->session->set('percent_disk_quota', round(($current * 100) / $max));
- }
- } else {
- $this->session->set('max_disk_quota', null);
- $this->session->set('percent_disk_quota', null);
- }
- }
- /**
- * @param Request $request
- * @param $userId
- * @param $fileSize
- * @param bool $dec
- * @return bool
- */
- protected function updateUserQuota(Request $request, $userId, $fileSize, $dec = false)
- {
- $user = make(UserQuery::class)->get($request, $userId);
- if ($dec) {
- $tot = max($user->current_disk_quota - $fileSize, 0);
- } else {
- $tot = $user->current_disk_quota + $fileSize;
- if ($this->getSetting('quota_enabled') === 'on' && $user->max_disk_quota > 0 && $user->max_disk_quota < $tot) {
- return false;
- }
- }
- $this->database->query('UPDATE `users` SET `current_disk_quota`=? WHERE `id` = ?', [
- $tot,
- $user->id,
- ]);
- return true;
- }
- /**
- * @param $userId
- * @throws Exception
- */
- protected function refreshRememberCookie($userId)
- {
- $selector = bin2hex(random_bytes(8));
- $token = bin2hex(random_bytes(32));
- $expire = time() + 604800; // a week
- $this->database->query('UPDATE `users` SET `remember_selector`=?, `remember_token`=?, `remember_expire`=? WHERE `id`=?', [
- $selector,
- password_hash($token, PASSWORD_DEFAULT),
- date('Y-m-d\TH:i:s', $expire),
- $userId,
- ]);
- // Workaround for php <= 7.3
- if (PHP_VERSION_ID < 70300) {
- setcookie('remember', "{$selector}:{$token}", $expire, '; SameSite=Lax', '', false, true);
- } else {
- setcookie('remember', "{$selector}:{$token}", [
- 'expires' => $expire,
- 'httponly' => true,
- 'samesite' => 'Lax',
- ]);
- }
- }
- /**
- * @param Request $request
- * @return ValidationChecker
- */
- public function getUserCreateValidator(Request $request)
- {
- return ValidationChecker::make()
- ->rules([
- 'email.required' => filter_var(param($request, 'email'), FILTER_VALIDATE_EMAIL) !== false,
- 'username.required' => !empty(param($request, 'username')),
- 'password.required' => !empty(param($request, 'password')),
- 'email.unique' => $this->database->query('SELECT COUNT(*) AS `count` FROM `users` WHERE `email` = ?', param($request, 'email'))->fetch()->count == 0,
- 'username.unique' => $this->database->query('SELECT COUNT(*) AS `count` FROM `users` WHERE `username` = ?', param($request, 'username'))->fetch()->count == 0,
- ])
- ->onFail(function ($rule) {
- $alerts = [
- 'email.required' => lang('email_required'),
- 'username.required' => lang('username_required'),
- 'password.required' => lang('password_required'),
- 'email.unique' => lang('email_taken'),
- 'username.unique' => lang('username_taken'),
- ];
- $this->session->alert($alerts[$rule], 'danger');
- });
- }
- }
|