]> git.mxchange.org Git - friendica.git/commitdiff
Introduce "order" and "limit" argument instead of "param" array for BaseRepository...
authornupplaPhil <admin@philipp.info>
Sun, 19 Jan 2020 22:22:30 +0000 (23:22 +0100)
committernupplaPhil <admin@philipp.info>
Tue, 21 Jan 2020 23:09:08 +0000 (00:09 +0100)
src/BaseRepository.php
src/Collection/Introductions.php
src/Repository/Introduction.php
src/Repository/PermissionSet.php

index c0bcab18f92fbafc37a8e96b23561eecb1899c66..a66914e88b5b6a131a23a9ee7cec83beb46ed73c 100644 (file)
@@ -63,13 +63,15 @@ abstract class BaseRepository extends BaseFactory
         * Chainable.
         *
         * @param array $condition
-        * @param array $params
+        * @param array $order An optional array with order information
+        * @param int|array $limit Optional limit information
+        *
         * @return BaseCollection
         * @throws \Exception
         */
-       public function select(array $condition = [], array $params = [])
+       public function select(array $condition = [], array $order = [], $limit = null)
        {
-               $models = $this->selectModels($condition, $params);
+               $models = $this->selectModels($condition, $order, $limit);
 
                return new static::$collection_class($models);
        }
@@ -81,14 +83,15 @@ abstract class BaseRepository extends BaseFactory
         * Chainable.
         *
         * @param array $condition
-        * @param array $params
+        * @param array $order
         * @param int?  $max_id
         * @param int?  $since_id
         * @param int   $limit
+        *
         * @return BaseCollection
         * @throws \Exception
         */
-       public function selectByBoundaries(array $condition = [], array $params = [], int $max_id = null, int $since_id = null, int $limit = self::LIMIT)
+       public function selectByBoundaries(array $condition = [], array $order = [], int $max_id = null, int $since_id = null, int $limit = self::LIMIT)
        {
                $condition = DBA::collapseCondition($condition);
 
@@ -104,9 +107,7 @@ abstract class BaseRepository extends BaseFactory
                        $boundCondition[] = $since_id;
                }
 
-               $params['limit'] = $limit;
-
-               $models = $this->selectModels($boundCondition, $params);
+               $models = $this->selectModels($boundCondition, $order, $limit);
 
                $totalCount = DBA::count(static::$table_name, $condition);
 
@@ -175,12 +176,24 @@ abstract class BaseRepository extends BaseFactory
 
        /**
         * @param array $condition Query condition
-        * @param array $params    Additional query parameters
+        * @param array $order An optional array with order information
+        * @param int|array $limit Optional limit information
+        *
         * @return BaseModel[]
         * @throws \Exception
         */
-       protected function selectModels(array $condition, array $params = [])
+       protected function selectModels(array $condition, array $order = [], $limit = null)
        {
+               $params = [];
+
+               if (!empty($order)) {
+                       $params['order'] = $order;
+               }
+
+               if (!empty($limit)) {
+                       $params['limit'] = $limit;
+               }
+
                $result = $this->dba->select(static::$table_name, [], $condition, $params);
 
                /** @var BaseModel $prototype */
index 0d4e319cb736550480b33763ef759ca6b9392e65..b0d31d4f1d790af690754bb04f3325ad704078d7 100644 (file)
@@ -3,11 +3,7 @@
 namespace Friendica\Collection;
 
 use Friendica\BaseCollection;
-use Friendica\Model\Introduction;
 
-/**
- * @property Introduction[] $models
- */
 class Introductions extends BaseCollection
 {
 
index 65c2e1ebc71e90dd66d0e86010e35e96bc1b6156..4f9806312cc82138ef06ecc201507fb4e7bdb970 100644 (file)
@@ -35,26 +35,28 @@ class Introduction extends BaseRepository
 
        /**
         * @param array $condition
-        * @param array $params
+        * @param array $order An optional array with order information
+        * @param int|array $limit Optional limit information
+        *
         * @return Collection\Introductions
         * @throws \Exception
         */
-       public function select(array $condition = [], array $params = [])
+       public function select(array $condition = [], array $order = [], $limit = null)
        {
-               return parent::select($condition, $params);
+               return parent::select($condition, $order, $limit);
        }
 
        /**
         * @param array $condition
-        * @param array $params
+        * @param array $order
         * @param int|null $max_id
         * @param int|null $since_id
-        * @param int $limit
+        * @param int|array $limit
         * @return Collection\Introductions
         * @throws \Exception
         */
-       public function selectByBoundaries(array $condition = [], array $params = [], int $max_id = null, int $since_id = null, int $limit = self::LIMIT)
+       public function selectByBoundaries(array $condition = [], array $order = [], int $max_id = null, int $since_id = null, int $limit = self::LIMIT)
        {
-               return parent::selectByBoundaries($condition, $params, $max_id, $since_id, $limit);
+               return parent::selectByBoundaries($condition, $order, $max_id, $since_id, $limit);
        }
 }
index 906dd716e66465b97cb507f7cf1c8d08a86e2be4..27c77d605254b2b4778bce65e92daf629e2e9cbd 100644 (file)
@@ -2,15 +2,14 @@
 
 namespace Friendica\Repository;
 
-use Friendica\BaseModel;
 use Friendica\BaseRepository;
 use Friendica\Collection;
-use Friendica\Core\L10n;
-use Friendica\Database\DBA;
-use Friendica\DI;
+use Friendica\Database\Database;
 use Friendica\Model;
 use Friendica\Model\Group;
 use Friendica\Network\HTTPException;
+use Friendica\Util\ACLFormatter;
+use Psr\Log\LoggerInterface;
 
 class PermissionSet extends BaseRepository
 {
@@ -20,6 +19,16 @@ class PermissionSet extends BaseRepository
 
        protected static $collection_class = Collection\PermissionSets::class;
 
+       /** @var ACLFormatter */
+       private $aclFormatter;
+
+       public function __construct(Database $dba, LoggerInterface $logger, ACLFormatter $aclFormatter)
+       {
+               parent::__construct($dba, $logger);
+
+               $this->aclFormatter = $aclFormatter;
+       }
+
        /**
         * @param array $data
         * @return Model\PermissionSet
@@ -52,27 +61,29 @@ class PermissionSet extends BaseRepository
 
        /**
         * @param array $condition
-        * @param array $params
+        * @param array $order An optional array with order information
+        * @param int|array $limit Optional limit information
+        *
         * @return Collection\PermissionSets
         * @throws \Exception
         */
-       public function select(array $condition = [], array $params = [])
+       public function select(array $condition = [], array $order = [], $limit = null)
        {
-               return parent::select($condition, $params);
+               return parent::select($condition, $order, $limit);
        }
 
        /**
         * @param array $condition
-        * @param array $params
+        * @param array $order
         * @param int|null $max_id
         * @param int|null $since_id
-        * @param int $limit
+        * @param int|array $limit
         * @return Collection\PermissionSets
         * @throws \Exception
         */
-       public function selectByBoundaries(array $condition = [], array $params = [], int $max_id = null, int $since_id = null, int $limit = self::LIMIT)
+       public function selectByBoundaries(array $condition = [], array $order = [], int $max_id = null, int $since_id = null, int $limit = self::LIMIT)
        {
-               return parent::selectByBoundaries($condition, $params, $max_id, $since_id, $limit);
+               return parent::selectByBoundaries($condition, $order, $max_id, $since_id, $limit);
        }
 
        /**
@@ -93,12 +104,10 @@ class PermissionSet extends BaseRepository
                string $deny_cid = null,
                string $deny_gid = null
        ) {
-               $ACLFormatter = DI::aclFormatter();
-
-               $allow_cid = $ACLFormatter->sanitize($allow_cid);
-               $allow_gid = $ACLFormatter->sanitize($allow_gid);
-               $deny_cid = $ACLFormatter->sanitize($deny_cid);
-               $deny_gid = $ACLFormatter->sanitize($deny_gid);
+               $allow_cid = $this->aclFormatter->sanitize($allow_cid);
+               $allow_gid = $this->aclFormatter->sanitize($allow_gid);
+               $deny_cid = $this->aclFormatter->sanitize($deny_cid);
+               $deny_gid = $this->aclFormatter->sanitize($deny_gid);
 
                // Public permission
                if (!$allow_cid && !$allow_gid && !$deny_cid && !$deny_gid) {
@@ -134,7 +143,7 @@ class PermissionSet extends BaseRepository
        public function selectByContactId($contact_id, $uid)
        {
                $groups = [];
-               if (DBA::exists('contact', ['id' => $contact_id, 'uid' => $uid, 'blocked' => false])) {
+               if ($this->dba->exists('contact', ['id' => $contact_id, 'uid' => $uid, 'blocked' => false])) {
                        $groups = Group::getIdsByContactId($contact_id);
                }