aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2016-01-25 21:13:41 +0100
committerThomas Müller <thomas.mueller@tmit.eu>2016-01-25 21:13:41 +0100
commit4c9e328211a3f986cd2c6186e4c1de755d5c940b (patch)
tree53e4b5a23366f59ddc2bcfc15013d6ceeb9efebb
parentfe08700b597b8c765716e92569d30524cfef9b84 (diff)
parent09ae1604637127189e7aaf6777243e8b84a89dd8 (diff)
downloadnextcloud-server-4c9e328211a3f986cd2c6186e4c1de755d5c940b.tar.gz
nextcloud-server-4c9e328211a3f986cd2c6186e4c1de755d5c940b.zip
Merge pull request #21892 from owncloud/issue-21890-parameters
Add parameters types to IQueryBuilder
-rw-r--r--apps/dav/lib/caldav/caldavbackend.php3
-rw-r--r--apps/dav/lib/carddav/carddavbackend.php5
-rw-r--r--lib/private/repair/cleantags.php3
-rw-r--r--lib/private/share/share.php3
-rw-r--r--lib/private/share20/defaultshareprovider.php7
-rw-r--r--lib/private/systemtag/systemtagmanager.php8
-rw-r--r--lib/private/systemtag/systemtagobjectmapper.php10
-rw-r--r--lib/private/tags.php7
-rw-r--r--lib/public/db/querybuilder/iquerybuilder.php39
9 files changed, 64 insertions, 21 deletions
diff --git a/apps/dav/lib/caldav/caldavbackend.php b/apps/dav/lib/caldav/caldavbackend.php
index 6af75ca064c..0b70b37967f 100644
--- a/apps/dav/lib/caldav/caldavbackend.php
+++ b/apps/dav/lib/caldav/caldavbackend.php
@@ -22,6 +22,7 @@
namespace OCA\DAV\CalDAV;
+use OCP\DB\QueryBuilder\IQueryBuilder;
use Sabre\CalDAV\Backend\AbstractBackend;
use Sabre\CalDAV\Backend\SchedulingSupport;
use Sabre\CalDAV\Backend\SubscriptionSupport;
@@ -384,7 +385,7 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription
->from('calendarobjects')
->where($query->expr()->eq('calendarid', $query->createNamedParameter($calendarId)))
->andWhere($query->expr()->in('uri', $query->createParameter('uri')))
- ->setParameter('uri', $uris, \Doctrine\DBAL\Connection::PARAM_STR_ARRAY);
+ ->setParameter('uri', $uris, IQueryBuilder::PARAM_STR_ARRAY);
$stmt = $query->execute();
diff --git a/apps/dav/lib/carddav/carddavbackend.php b/apps/dav/lib/carddav/carddavbackend.php
index 97067abb7c3..44164e61259 100644
--- a/apps/dav/lib/carddav/carddavbackend.php
+++ b/apps/dav/lib/carddav/carddavbackend.php
@@ -25,6 +25,7 @@
namespace OCA\DAV\CardDAV;
use OCA\DAV\Connector\Sabre\Principal;
+use OCP\DB\QueryBuilder\IQueryBuilder;
use OCP\IDBConnection;
use Sabre\CardDAV\Backend\BackendInterface;
use Sabre\CardDAV\Backend\SyncSupport;
@@ -118,7 +119,7 @@ class CardDavBackend implements BackendInterface, SyncSupport {
->where($query->expr()->in('s.principaluri', $query->createParameter('principaluri')))
->andWhere($query->expr()->eq('s.type', $query->createParameter('type')))
->setParameter('type', 'addressbook')
- ->setParameter('principaluri', $principals, \Doctrine\DBAL\Connection::PARAM_STR_ARRAY)
+ ->setParameter('principaluri', $principals, IQueryBuilder::PARAM_STR_ARRAY)
->execute();
while($row = $result->fetch()) {
@@ -423,7 +424,7 @@ class CardDavBackend implements BackendInterface, SyncSupport {
->from('cards')
->where($query->expr()->eq('addressbookid', $query->createNamedParameter($addressBookId)))
->andWhere($query->expr()->in('uri', $query->createParameter('uri')))
- ->setParameter('uri', $uris, \Doctrine\DBAL\Connection::PARAM_STR_ARRAY);
+ ->setParameter('uri', $uris, IQueryBuilder::PARAM_STR_ARRAY);
$cards = [];
diff --git a/lib/private/repair/cleantags.php b/lib/private/repair/cleantags.php
index 7421242eb48..537c4da78aa 100644
--- a/lib/private/repair/cleantags.php
+++ b/lib/private/repair/cleantags.php
@@ -24,6 +24,7 @@ namespace OC\Repair;
use OC\Hooks\BasicEmitter;
use OC\RepairStep;
+use OCP\DB\QueryBuilder\IQueryBuilder;
use OCP\IDBConnection;
/**
@@ -134,7 +135,7 @@ class CleanTags extends BasicEmitter implements RepairStep {
$qb->expr()->eq('type', $qb->expr()->literal('files'))
)
->andWhere($qb->expr()->in($deleteId, $qb->createParameter('ids')));
- $qb->setParameter('ids', $items, \Doctrine\DBAL\Connection::PARAM_INT_ARRAY);
+ $qb->setParameter('ids', $items, IQueryBuilder::PARAM_INT_ARRAY);
$qb->execute();
}
}
diff --git a/lib/private/share/share.php b/lib/private/share/share.php
index c695e9a156b..96b920fe994 100644
--- a/lib/private/share/share.php
+++ b/lib/private/share/share.php
@@ -38,6 +38,7 @@
namespace OC\Share;
use OC\Files\Filesystem;
+use OCP\DB\QueryBuilder\IQueryBuilder;
use OCP\IUserSession;
use OCP\IDBConnection;
use OCP\IConfig;
@@ -426,7 +427,7 @@ class Share extends Constants {
if (!empty($groups)) {
$where = $fileDependentWhere . ' WHERE `' . $column . '` = ? AND `item_type` = ? AND `share_with` in (?)';
$arguments = array($itemSource, $itemType, $groups);
- $types = array(null, null, \Doctrine\DBAL\Connection::PARAM_STR_ARRAY);
+ $types = array(null, null, IQueryBuilder::PARAM_STR_ARRAY);
if ($owner !== null) {
$where .= ' AND `uid_owner` = ?';
diff --git a/lib/private/share20/defaultshareprovider.php b/lib/private/share20/defaultshareprovider.php
index 8c193c437d3..3d5462792cd 100644
--- a/lib/private/share20/defaultshareprovider.php
+++ b/lib/private/share20/defaultshareprovider.php
@@ -24,6 +24,7 @@ use OC\Share20\Exception\InvalidShare;
use OC\Share20\Exception\ProviderException;
use OC\Share20\Exception\ShareNotFound;
use OC\Share20\Exception\BackendError;
+use OCP\DB\QueryBuilder\IQueryBuilder;
use OCP\Files\NotFoundException;
use OCP\IGroup;
use OCP\IUser;
@@ -33,8 +34,6 @@ use OCP\Files\IRootFolder;
use OCP\IDBConnection;
use OCP\Files\Node;
-use Doctrine\DBAL\Connection;
-
/**
* Class DefaultShareProvider
*
@@ -520,7 +519,7 @@ class DefaultShareProvider implements IShareProvider {
$qb->where($qb->expr()->eq('share_type', $qb->createNamedParameter(\OCP\Share::SHARE_TYPE_GROUP)));
$qb->andWhere($qb->expr()->in('share_with', $qb->createNamedParameter(
$groups,
- Connection::PARAM_STR_ARRAY
+ IQueryBuilder::PARAM_STR_ARRAY
)));
$cursor = $qb->execute();
@@ -697,4 +696,4 @@ class DefaultShareProvider implements IShareProvider {
return $share;
}
-} \ No newline at end of file
+}
diff --git a/lib/private/systemtag/systemtagmanager.php b/lib/private/systemtag/systemtagmanager.php
index 733336f4de9..af912a74936 100644
--- a/lib/private/systemtag/systemtagmanager.php
+++ b/lib/private/systemtag/systemtagmanager.php
@@ -22,8 +22,8 @@
namespace OC\SystemTag;
-use Doctrine\DBAL\Connection;
use Doctrine\DBAL\Exception\UniqueConstraintViolationException;
+use OCP\DB\QueryBuilder\IQueryBuilder;
use OCP\IDBConnection;
use OCP\SystemTag\ISystemTagManager;
use OCP\SystemTag\TagAlreadyExistsException;
@@ -85,7 +85,7 @@ class SystemTagManager implements ISystemTagManager {
->addOrderBy('name', 'ASC')
->addOrderBy('visibility', 'ASC')
->addOrderBy('editable', 'ASC')
- ->setParameter('tagids', $tagIds, Connection::PARAM_INT_ARRAY);
+ ->setParameter('tagids', $tagIds, IQueryBuilder::PARAM_INT_ARRAY);
$result = $query->execute();
while ($row = $result->fetch()) {
@@ -252,13 +252,13 @@ class SystemTagManager implements ISystemTagManager {
$query = $this->connection->getQueryBuilder();
$query->delete(SystemTagObjectMapper::RELATION_TABLE)
->where($query->expr()->in('systemtagid', $query->createParameter('tagids')))
- ->setParameter('tagids', $tagIds, Connection::PARAM_INT_ARRAY)
+ ->setParameter('tagids', $tagIds, IQueryBuilder::PARAM_INT_ARRAY)
->execute();
$query = $this->connection->getQueryBuilder();
$query->delete(self::TAG_TABLE)
->where($query->expr()->in('id', $query->createParameter('tagids')))
- ->setParameter('tagids', $tagIds, Connection::PARAM_INT_ARRAY)
+ ->setParameter('tagids', $tagIds, IQueryBuilder::PARAM_INT_ARRAY)
->execute();
if ($tagNotFoundException !== null) {
diff --git a/lib/private/systemtag/systemtagobjectmapper.php b/lib/private/systemtag/systemtagobjectmapper.php
index 4b50539f155..458b558ad97 100644
--- a/lib/private/systemtag/systemtagobjectmapper.php
+++ b/lib/private/systemtag/systemtagobjectmapper.php
@@ -22,8 +22,8 @@
namespace OC\SystemTag;
-use Doctrine\DBAL\Connection;
use Doctrine\DBAL\Exception\UniqueConstraintViolationException;
+use OCP\DB\QueryBuilder\IQueryBuilder;
use OCP\IDBConnection;
use OCP\SystemTag\ISystemTag;
use OCP\SystemTag\ISystemTagManager;
@@ -68,7 +68,7 @@ class SystemTagObjectMapper implements ISystemTagObjectMapper {
->from(self::RELATION_TABLE)
->where($query->expr()->in('objectid', $query->createParameter('objectids')))
->andWhere($query->expr()->eq('objecttype', $query->createParameter('objecttype')))
- ->setParameter('objectids', $objIds, Connection::PARAM_INT_ARRAY)
+ ->setParameter('objectids', $objIds, IQueryBuilder::PARAM_INT_ARRAY)
->setParameter('objecttype', $objectType)
->addOrderBy('objectid', 'ASC')
->addOrderBy('systemtagid', 'ASC');
@@ -104,7 +104,7 @@ class SystemTagObjectMapper implements ISystemTagObjectMapper {
->from(self::RELATION_TABLE)
->where($query->expr()->in('systemtagid', $query->createParameter('tagids')))
->andWhere($query->expr()->eq('objecttype', $query->createParameter('objecttype')))
- ->setParameter('tagids', $tagIds, Connection::PARAM_INT_ARRAY)
+ ->setParameter('tagids', $tagIds, IQueryBuilder::PARAM_INT_ARRAY)
->setParameter('objecttype', $objectType);
$objectIds = [];
@@ -162,7 +162,7 @@ class SystemTagObjectMapper implements ISystemTagObjectMapper {
->andWhere($query->expr()->in('systemtagid', $query->createParameter('tagids')))
->setParameter('objectid', $objId)
->setParameter('objecttype', $objectType)
- ->setParameter('tagids', $tagIds, Connection::PARAM_INT_ARRAY)
+ ->setParameter('tagids', $tagIds, IQueryBuilder::PARAM_INT_ARRAY)
->execute();
}
@@ -191,7 +191,7 @@ class SystemTagObjectMapper implements ISystemTagObjectMapper {
->where($query->expr()->in('objectid', $query->createParameter('objectids')))
->andWhere($query->expr()->eq('objecttype', $query->createParameter('objecttype')))
->andWhere($query->expr()->eq('systemtagid', $query->createParameter('tagid')))
- ->setParameter('objectids', $objIds, Connection::PARAM_INT_ARRAY)
+ ->setParameter('objectids', $objIds, IQueryBuilder::PARAM_INT_ARRAY)
->setParameter('tagid', $tagId)
->setParameter('objecttype', $objectType);
diff --git a/lib/private/tags.php b/lib/private/tags.php
index ea5e2ca2f2b..cf39a9a9759 100644
--- a/lib/private/tags.php
+++ b/lib/private/tags.php
@@ -41,8 +41,9 @@
namespace OC;
-use \OC\Tagging\Tag;
-use \OC\Tagging\TagMapper;
+use OC\Tagging\Tag;
+use OC\Tagging\TagMapper;
+use OCP\DB\QueryBuilder\IQueryBuilder;
class Tags implements \OCP\ITags {
@@ -223,7 +224,7 @@ class Tags implements \OCP\ITags {
'FROM `' . self::RELATION_TABLE . '` r, `' . self::TAG_TABLE . '` ' .
'WHERE `categoryid` = `id` AND `uid` = ? AND r.`type` = ? AND `objid` IN (?)',
array($this->user, $this->type, $chunk),
- array(null, null, \Doctrine\DBAL\Connection::PARAM_INT_ARRAY)
+ array(null, null, IQueryBuilder::PARAM_INT_ARRAY)
);
while ($row = $result->fetch()) {
$objId = (int)$row['objid'];
diff --git a/lib/public/db/querybuilder/iquerybuilder.php b/lib/public/db/querybuilder/iquerybuilder.php
index c803f08a888..5a020f4f6a2 100644
--- a/lib/public/db/querybuilder/iquerybuilder.php
+++ b/lib/public/db/querybuilder/iquerybuilder.php
@@ -21,11 +21,50 @@
namespace OCP\DB\QueryBuilder;
+
+use Doctrine\DBAL\Connection;
+
/**
* This class provides a wrapper around Doctrine's QueryBuilder
* @since 8.2.0
*/
interface IQueryBuilder {
+
+ /**
+ * @since 9.0.0
+ */
+ const PARAM_NULL = \PDO::PARAM_NULL;
+ /**
+ * @since 9.0.0
+ */
+ const PARAM_BOOL = \PDO::PARAM_BOOL;
+ /**
+ * @since 9.0.0
+ */
+ const PARAM_INT = \PDO::PARAM_INT;
+ /**
+ * @since 9.0.0
+ */
+ const PARAM_STR = \PDO::PARAM_STR;
+ /**
+ * @since 9.0.0
+ */
+ const PARAM_LOB = \PDO::PARAM_LOB;
+ /**
+ * @since 9.0.0
+ */
+ const PARAM_DATE = 'datetime';
+
+ /**
+ * @since 9.0.0
+ */
+ const PARAM_INT_ARRAY = Connection::PARAM_INT_ARRAY;
+ /**
+ * @since 9.0.0
+ */
+ const PARAM_STR_ARRAY = Connection::PARAM_STR_ARRAY;
+
+
/**
* Enable/disable automatic prefixing of table names with the oc_ prefix
*