]> git.mxchange.org Git - friendica.git/commitdiff
Add permission set lazy loading to Profile Field model
authorHypolite Petovan <hypolite@mrpetovan.com>
Tue, 14 Jan 2020 03:22:02 +0000 (22:22 -0500)
committerHypolite Petovan <hypolite@mrpetovan.com>
Thu, 23 Jan 2020 00:42:35 +0000 (19:42 -0500)
src/Collection/ProfileFields.php
src/Model/ProfileField.php
src/Repository/ProfileField.php

index e171b839b2cc7664c44fd05d50fdde58228918cf..223c3ec148376d9f00ecc8786beadd5254a8fdc9 100644 (file)
@@ -6,5 +6,12 @@ use Friendica\BaseCollection;
 
 class ProfileFields extends BaseCollection
 {
-
+       /**
+        * @param callable $callback
+        * @return ProfileFields
+        */
+       public function map(callable $callback)
+       {
+               return parent::map($callback);
+       }
 }
index 51b43e33c8a838828d41c06715948cf46b9fe36c..e4192a980984c8986c806e998747f9b49e611f43 100644 (file)
@@ -3,6 +3,9 @@
 namespace Friendica\Model;
 
 use Friendica\BaseModel;
+use Friendica\Database\Database;
+use Friendica\Network\HTTPException;
+use Psr\Log\LoggerInterface;
 
 /**
  * Custom profile field model class.
@@ -17,8 +20,40 @@ use Friendica\BaseModel;
  * @property string value
  * @property string created
  * @property string edited
+ * @property PermissionSet permissionset
  */
 class ProfileField extends BaseModel
 {
+       /** @var PermissionSet */
+       private $permissionset;
 
+       /** @var \Friendica\Repository\PermissionSet */
+       private $permissionSetRepository;
+
+       public function __construct(Database $dba, LoggerInterface $logger, \Friendica\Repository\PermissionSet $permissionSetRepository, array $data = [])
+       {
+               parent::__construct($dba, $logger, $data);
+
+               $this->permissionSetRepository = $permissionSetRepository;
+       }
+
+       public function __get($name)
+       {
+               $this->checkValid();
+
+               switch ($name) {
+                       case 'permissionset':
+                               $this->permissionset =
+                                       $this->permissionset ??
+                                               $this->permissionSetRepository->selectFirst(['id' => $this->psid, 'uid' => $this->uid]);
+
+                               $return = $this->permissionset;
+                               break;
+                       default:
+                               $return = parent::__get($name);
+                               break;
+               }
+
+               return $return;
+       }
 }
index 21fd2da7c8c514306e9f52972393f3ef0e5d5f06..d04104898add8cea72ec7da6ee17c1fea6614c89 100644 (file)
@@ -5,9 +5,10 @@ namespace Friendica\Repository;
 use Friendica\BaseModel;
 use Friendica\BaseRepository;
 use Friendica\Collection;
+use Friendica\Database\Database;
 use Friendica\Model;
-use Friendica\Model\PermissionSet;
 use Friendica\Util\DateTimeFormat;
+use Psr\Log\LoggerInterface;
 
 class ProfileField extends BaseRepository
 {
@@ -17,13 +18,23 @@ class ProfileField extends BaseRepository
 
        protected static $collection_class = Collection\ProfileFields::class;
 
+       /** @var PermissionSet */
+       private $permissionSet;
+
+       public function __construct(Database $dba, LoggerInterface $logger, PermissionSet $permissionSet)
+       {
+               parent::__construct($dba, $logger);
+
+               $this->permissionSet = $permissionSet;
+       }
+
        /**
         * @param array $data
         * @return Model\ProfileField
         */
        protected function create(array $data)
        {
-               return new Model\ProfileField($this->dba, $this->logger, $data);
+               return new Model\ProfileField($this->dba, $this->logger, $this->permissionSet, $data);
        }
 
        /**
@@ -84,7 +95,9 @@ class ProfileField extends BaseRepository
         */
        public function selectByContactId(int $cid, int $uid)
        {
-               $psids = PermissionSet::get($uid, $cid);
+               $permissionSets = $this->permissionSet->selectByContactId($cid, $uid);
+
+               $psids = $permissionSets->column('id');
 
                // Includes public custom fields
                $psids[] = 0;