Introduce "order" and "limit" argument instead of "param" array for BaseRepository and make Repositories more Dependency Injectable
This commit is contained in:
parent
26d6afd27f
commit
b46b72ad3b
|
@ -63,13 +63,15 @@ abstract class BaseRepository extends BaseFactory
|
||||||
* Chainable.
|
* Chainable.
|
||||||
*
|
*
|
||||||
* @param array $condition
|
* @param array $condition
|
||||||
* @param array $params
|
* @param array $order An optional array with order information
|
||||||
|
* @param int|array $limit Optional limit information
|
||||||
|
*
|
||||||
* @return BaseCollection
|
* @return BaseCollection
|
||||||
* @throws \Exception
|
* @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);
|
return new static::$collection_class($models);
|
||||||
}
|
}
|
||||||
|
@ -81,14 +83,15 @@ abstract class BaseRepository extends BaseFactory
|
||||||
* Chainable.
|
* Chainable.
|
||||||
*
|
*
|
||||||
* @param array $condition
|
* @param array $condition
|
||||||
* @param array $params
|
* @param array $order
|
||||||
* @param int? $max_id
|
* @param int? $max_id
|
||||||
* @param int? $since_id
|
* @param int? $since_id
|
||||||
* @param int $limit
|
* @param int $limit
|
||||||
|
*
|
||||||
* @return BaseCollection
|
* @return BaseCollection
|
||||||
* @throws \Exception
|
* @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);
|
$condition = DBA::collapseCondition($condition);
|
||||||
|
|
||||||
|
@ -104,9 +107,7 @@ abstract class BaseRepository extends BaseFactory
|
||||||
$boundCondition[] = $since_id;
|
$boundCondition[] = $since_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
$params['limit'] = $limit;
|
$models = $this->selectModels($boundCondition, $order, $limit);
|
||||||
|
|
||||||
$models = $this->selectModels($boundCondition, $params);
|
|
||||||
|
|
||||||
$totalCount = DBA::count(static::$table_name, $condition);
|
$totalCount = DBA::count(static::$table_name, $condition);
|
||||||
|
|
||||||
|
@ -175,12 +176,24 @@ abstract class BaseRepository extends BaseFactory
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param array $condition Query condition
|
* @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[]
|
* @return BaseModel[]
|
||||||
* @throws \Exception
|
* @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);
|
$result = $this->dba->select(static::$table_name, [], $condition, $params);
|
||||||
|
|
||||||
/** @var BaseModel $prototype */
|
/** @var BaseModel $prototype */
|
||||||
|
|
|
@ -3,11 +3,7 @@
|
||||||
namespace Friendica\Collection;
|
namespace Friendica\Collection;
|
||||||
|
|
||||||
use Friendica\BaseCollection;
|
use Friendica\BaseCollection;
|
||||||
use Friendica\Model\Introduction;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @property Introduction[] $models
|
|
||||||
*/
|
|
||||||
class Introductions extends BaseCollection
|
class Introductions extends BaseCollection
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
|
@ -35,26 +35,28 @@ class Introduction extends BaseRepository
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param array $condition
|
* @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
|
* @return Collection\Introductions
|
||||||
* @throws \Exception
|
* @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 $condition
|
||||||
* @param array $params
|
* @param array $order
|
||||||
* @param int|null $max_id
|
* @param int|null $max_id
|
||||||
* @param int|null $since_id
|
* @param int|null $since_id
|
||||||
* @param int $limit
|
* @param int|array $limit
|
||||||
* @return Collection\Introductions
|
* @return Collection\Introductions
|
||||||
* @throws \Exception
|
* @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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,15 +2,14 @@
|
||||||
|
|
||||||
namespace Friendica\Repository;
|
namespace Friendica\Repository;
|
||||||
|
|
||||||
use Friendica\BaseModel;
|
|
||||||
use Friendica\BaseRepository;
|
use Friendica\BaseRepository;
|
||||||
use Friendica\Collection;
|
use Friendica\Collection;
|
||||||
use Friendica\Core\L10n;
|
use Friendica\Database\Database;
|
||||||
use Friendica\Database\DBA;
|
|
||||||
use Friendica\DI;
|
|
||||||
use Friendica\Model;
|
use Friendica\Model;
|
||||||
use Friendica\Model\Group;
|
use Friendica\Model\Group;
|
||||||
use Friendica\Network\HTTPException;
|
use Friendica\Network\HTTPException;
|
||||||
|
use Friendica\Util\ACLFormatter;
|
||||||
|
use Psr\Log\LoggerInterface;
|
||||||
|
|
||||||
class PermissionSet extends BaseRepository
|
class PermissionSet extends BaseRepository
|
||||||
{
|
{
|
||||||
|
@ -20,6 +19,16 @@ class PermissionSet extends BaseRepository
|
||||||
|
|
||||||
protected static $collection_class = Collection\PermissionSets::class;
|
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
|
* @param array $data
|
||||||
* @return Model\PermissionSet
|
* @return Model\PermissionSet
|
||||||
|
@ -52,27 +61,29 @@ class PermissionSet extends BaseRepository
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param array $condition
|
* @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
|
* @return Collection\PermissionSets
|
||||||
* @throws \Exception
|
* @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 $condition
|
||||||
* @param array $params
|
* @param array $order
|
||||||
* @param int|null $max_id
|
* @param int|null $max_id
|
||||||
* @param int|null $since_id
|
* @param int|null $since_id
|
||||||
* @param int $limit
|
* @param int|array $limit
|
||||||
* @return Collection\PermissionSets
|
* @return Collection\PermissionSets
|
||||||
* @throws \Exception
|
* @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_cid = null,
|
||||||
string $deny_gid = null
|
string $deny_gid = null
|
||||||
) {
|
) {
|
||||||
$ACLFormatter = DI::aclFormatter();
|
$allow_cid = $this->aclFormatter->sanitize($allow_cid);
|
||||||
|
$allow_gid = $this->aclFormatter->sanitize($allow_gid);
|
||||||
$allow_cid = $ACLFormatter->sanitize($allow_cid);
|
$deny_cid = $this->aclFormatter->sanitize($deny_cid);
|
||||||
$allow_gid = $ACLFormatter->sanitize($allow_gid);
|
$deny_gid = $this->aclFormatter->sanitize($deny_gid);
|
||||||
$deny_cid = $ACLFormatter->sanitize($deny_cid);
|
|
||||||
$deny_gid = $ACLFormatter->sanitize($deny_gid);
|
|
||||||
|
|
||||||
// Public permission
|
// Public permission
|
||||||
if (!$allow_cid && !$allow_gid && !$deny_cid && !$deny_gid) {
|
if (!$allow_cid && !$allow_gid && !$deny_cid && !$deny_gid) {
|
||||||
|
@ -134,7 +143,7 @@ class PermissionSet extends BaseRepository
|
||||||
public function selectByContactId($contact_id, $uid)
|
public function selectByContactId($contact_id, $uid)
|
||||||
{
|
{
|
||||||
$groups = [];
|
$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);
|
$groups = Group::getIdsByContactId($contact_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue