%PDF- %PDF-
Direktori : /www/varak.net/nextcloud.varak.net/apps/twofactor_nextcloud_notification/lib/Db/ |
Current File : /www/varak.net/nextcloud.varak.net/apps/twofactor_nextcloud_notification/lib/Db/TokenMapper.php |
<?php declare(strict_types=1); /** * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors * SPDX-License-Identifier: AGPL-3.0-or-later */ namespace OCA\TwoFactorNextcloudNotification\Db; use OCP\AppFramework\Db\DoesNotExistException; use OCP\AppFramework\Db\QBMapper; use OCP\AppFramework\Utility\ITimeFactory; use OCP\IDBConnection; use OCP\Security\ISecureRandom; /** * @template-extends QBMapper<Token> */ class TokenMapper extends QBMapper { public function __construct( IDBConnection $db, private ITimeFactory $timeFactory, private ISecureRandom $random, ) { parent::__construct($db, 'twofactor_tnn_tokens', Token::class); } /** * @param string $token * @return Token * @throws DoesNotExistException */ public function getByToken(string $token): Token { $qb = $this->db->getQueryBuilder(); $qb->select('*') ->from($this->getTableName()) ->where( $qb->expr()->eq('token', $qb->createNamedParameter($token)) ); return $this->findEntity($qb); } /** * @param int $id * @return Token * @throws DoesNotExistException */ public function getById(int $id): Token { $qb = $this->db->getQueryBuilder(); $qb->select('*') ->from($this->getTableName()) ->where( $qb->expr()->eq('id', $qb->createNamedParameter($id)) ); return $this->findEntity($qb); } public function generate(string $userId): Token { $token = new Token(); $token->setStatus(Token::PENDING); $token->setUserId($userId); $token->setTimestamp($this->timeFactory->getTime()); $token->setToken($this->random->generate(40, ISecureRandom::CHAR_DIGITS.ISecureRandom::CHAR_LOWER.ISecureRandom::CHAR_UPPER)); /** @var Token $token */ $token = $this->insert($token); return $token; } public function getTokensForCleanup(): array { // Clear all tokens older than 10 minutes $time = $this->timeFactory->getTime() - (60 * 10); $qb = $this->db->getQueryBuilder(); $qb->select('*') ->from($this->getTableName()) ->where($qb->expr()->lt('timestamp', $qb->createNamedParameter($time))); return $this->findEntities($qb); } }