diff options
author | Roeland Jago Douma <rullzer@users.noreply.github.com> | 2021-03-03 14:58:51 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-03-03 14:58:51 +0100 |
commit | 0829fea5e7f9a81a69599c5df7c75b997055e5ba (patch) | |
tree | 159cfa2a98c143be809742abb68353d77a39a248 | |
parent | b87e54bb1c6ec62d7b7ca9a03d6ed5b07dfd75c1 (diff) | |
parent | ee7702e5f0399b3df9ea739179eab16eb8007f6d (diff) | |
download | nextcloud-server-0829fea5e7f9a81a69599c5df7c75b997055e5ba.tar.gz nextcloud-server-0829fea5e7f9a81a69599c5df7c75b997055e5ba.zip |
Merge pull request #25896 from nextcloud/techdept/qbmapper
Move DirectMapper to QBMapper
-rw-r--r-- | apps/dav/lib/Db/DirectMapper.php | 21 | ||||
-rw-r--r-- | apps/dav/tests/unit/Controller/DirectControllerTest.php | 2 |
2 files changed, 10 insertions, 13 deletions
diff --git a/apps/dav/lib/Db/DirectMapper.php b/apps/dav/lib/Db/DirectMapper.php index f088011d1dc..8192793bb02 100644 --- a/apps/dav/lib/Db/DirectMapper.php +++ b/apps/dav/lib/Db/DirectMapper.php @@ -27,10 +27,13 @@ declare(strict_types=1); namespace OCA\DAV\Db; use OCP\AppFramework\Db\DoesNotExistException; -use OCP\AppFramework\Db\Mapper; +use OCP\AppFramework\Db\QBMapper; use OCP\IDBConnection; -class DirectMapper extends Mapper { +/** + * @template-extends QBMapper<Direct> + */ +class DirectMapper extends QBMapper { public function __construct(IDBConnection $db) { parent::__construct($db, 'directlink', Direct::class); } @@ -44,26 +47,18 @@ class DirectMapper extends Mapper { $qb = $this->db->getQueryBuilder(); $qb->select('*') - ->from('directlink') + ->from($this->getTableName()) ->where( $qb->expr()->eq('token', $qb->createNamedParameter($token)) ); - $cursor = $qb->execute(); - $data = $cursor->fetch(); - $cursor->closeCursor(); - - if ($data === false) { - throw new DoesNotExistException('Direct link with token does not exist'); - } - - return Direct::fromRow($data); + return parent::findEntity($qb); } public function deleteExpired(int $expiration) { $qb = $this->db->getQueryBuilder(); - $qb->delete('directlink') + $qb->delete($this->getTableName()) ->where( $qb->expr()->lt('expiration', $qb->createNamedParameter($expiration)) ); diff --git a/apps/dav/tests/unit/Controller/DirectControllerTest.php b/apps/dav/tests/unit/Controller/DirectControllerTest.php index 0cfe7c5cde4..2c8a708ba02 100644 --- a/apps/dav/tests/unit/Controller/DirectControllerTest.php +++ b/apps/dav/tests/unit/Controller/DirectControllerTest.php @@ -142,6 +142,8 @@ class DirectControllerTest extends TestCase { $this->assertSame(101, $direct->getFileId()); $this->assertSame('superduperlongtoken', $direct->getToken()); $this->assertSame(42 + 60 * 60 * 8, $direct->getExpiration()); + + return $direct; }); $this->urlGenerator->method('getAbsoluteURL') |