summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRoeland Jago Douma <rullzer@users.noreply.github.com>2021-03-03 14:58:51 +0100
committerGitHub <noreply@github.com>2021-03-03 14:58:51 +0100
commit0829fea5e7f9a81a69599c5df7c75b997055e5ba (patch)
tree159cfa2a98c143be809742abb68353d77a39a248
parentb87e54bb1c6ec62d7b7ca9a03d6ed5b07dfd75c1 (diff)
parentee7702e5f0399b3df9ea739179eab16eb8007f6d (diff)
downloadnextcloud-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.php21
-rw-r--r--apps/dav/tests/unit/Controller/DirectControllerTest.php2
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')