2016-08-29 17:19:44 +00:00
|
|
|
<?php
|
2021-04-14 15:05:19 +00:00
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
2016-08-29 17:19:44 +00:00
|
|
|
/**
|
2024-05-30 18:13:41 +00:00
|
|
|
* SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
2016-08-29 17:19:44 +00:00
|
|
|
*/
|
2016-10-03 19:47:33 +00:00
|
|
|
namespace OCA\TwoFactorBackupCodes\Db;
|
2016-09-09 14:56:08 +00:00
|
|
|
|
2019-01-14 14:50:04 +00:00
|
|
|
use OCP\AppFramework\Db\QBMapper;
|
2017-05-09 14:59:18 +00:00
|
|
|
use OCP\DB\QueryBuilder\IQueryBuilder;
|
2016-12-14 10:42:16 +00:00
|
|
|
use OCP\IDBConnection;
|
2016-08-29 17:19:44 +00:00
|
|
|
use OCP\IUser;
|
|
|
|
|
2020-10-09 12:33:17 +00:00
|
|
|
/**
|
|
|
|
* @template-extends QBMapper<BackupCode>
|
|
|
|
*/
|
2019-01-14 14:50:04 +00:00
|
|
|
class BackupCodeMapper extends QBMapper {
|
2016-12-14 10:42:16 +00:00
|
|
|
public function __construct(IDBConnection $db) {
|
2017-05-09 14:59:18 +00:00
|
|
|
parent::__construct($db, 'twofactor_backupcodes');
|
2016-08-29 17:19:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param IUser $user
|
|
|
|
* @return BackupCode[]
|
|
|
|
*/
|
2021-04-14 15:05:19 +00:00
|
|
|
public function getBackupCodes(IUser $user): array {
|
2016-09-12 12:06:02 +00:00
|
|
|
/* @var IQueryBuilder $qb */
|
2016-08-29 17:19:44 +00:00
|
|
|
$qb = $this->db->getQueryBuilder();
|
|
|
|
|
|
|
|
$qb->select('id', 'user_id', 'code', 'used')
|
2017-05-09 14:59:18 +00:00
|
|
|
->from('twofactor_backupcodes')
|
2016-08-29 17:19:44 +00:00
|
|
|
->where($qb->expr()->eq('user_id', $qb->createNamedParameter($user->getUID())));
|
|
|
|
|
2019-01-14 14:50:04 +00:00
|
|
|
return self::findEntities($qb);
|
2016-08-29 17:19:44 +00:00
|
|
|
}
|
|
|
|
|
2017-05-15 11:19:44 +00:00
|
|
|
/**
|
|
|
|
* @param IUser $user
|
|
|
|
*/
|
2021-04-14 15:05:19 +00:00
|
|
|
public function deleteCodes(IUser $user): void {
|
2017-05-15 11:19:44 +00:00
|
|
|
$this->deleteCodesByUserId($user->getUID());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $uid
|
|
|
|
*/
|
2021-04-14 15:05:19 +00:00
|
|
|
public function deleteCodesByUserId(string $uid): void {
|
2016-09-12 12:06:02 +00:00
|
|
|
/* @var IQueryBuilder $qb */
|
2016-08-29 17:19:44 +00:00
|
|
|
$qb = $this->db->getQueryBuilder();
|
|
|
|
|
2017-05-09 14:59:18 +00:00
|
|
|
$qb->delete('twofactor_backupcodes')
|
2017-05-15 11:19:44 +00:00
|
|
|
->where($qb->expr()->eq('user_id', $qb->createNamedParameter($uid)));
|
2016-08-29 17:19:44 +00:00
|
|
|
$qb->execute();
|
|
|
|
}
|
|
|
|
}
|