mirror of
https://framagit.org/hubzilla/core.git
synced 2026-06-21 00:52:33 -04:00
Add more type declarations to class attributes and functions. This should ensure that only strings and null values can be assigned to the various access list members. This is still a bit loose, as we should probably aim for lists of channel or group id's instead of a generic type like a string. I'll leave that for later, though.
203 lines
6.1 KiB
PHP
203 lines
6.1 KiB
PHP
<?php
|
|
|
|
namespace Zotlabs\Access;
|
|
|
|
|
|
/**
|
|
* @brief AccessList class which represents individual content ACLs.
|
|
*
|
|
* A class to hold an AccessList object with allowed and denied contacts and
|
|
* groups.
|
|
*
|
|
* After evaluating @ref ::Zotlabs::Access::PermissionLimits "PermissionLimits"
|
|
* and @ref ::Zotlabs::Lib::Permcat "Permcat"s individual content ACLs are evaluated.
|
|
* These answer the question "Can Joe view *this* album/photo?".
|
|
*/
|
|
class AccessList {
|
|
/**
|
|
* @brief Allow contacts
|
|
* @var string
|
|
*/
|
|
private ?string $allow_cid;
|
|
/**
|
|
* @brief Allow groups
|
|
* @var string
|
|
*/
|
|
private ?string $allow_gid;
|
|
/**
|
|
* @brief Deny contacts
|
|
* @var string
|
|
*/
|
|
private ?string $deny_cid;
|
|
/**
|
|
* @brief Deny groups
|
|
* @var string
|
|
*/
|
|
private ?string $deny_gid;
|
|
/**
|
|
* @brief Indicates if we are using the default constructor values or
|
|
* values that have been set explicitly.
|
|
* @var boolean
|
|
*/
|
|
private bool $explicit;
|
|
|
|
/**
|
|
* @brief Keys required by the constructor if the channel array is given.
|
|
*/
|
|
private const REQUIRED_KEYS_CONSTRUCTOR = [
|
|
'channel_allow_cid',
|
|
'channel_allow_gid',
|
|
'channel_deny_cid',
|
|
'channel_deny_gid'
|
|
];
|
|
|
|
/**
|
|
* @brief Keys required by the set method.
|
|
*/
|
|
private const REQUIRED_KEYS_SET = [
|
|
'allow_cid',
|
|
'allow_gid',
|
|
'deny_cid',
|
|
'deny_gid'
|
|
];
|
|
|
|
/**
|
|
* @brief Constructor for AccessList class.
|
|
*
|
|
* @note The array to pass to the constructor is different from the array
|
|
* that you provide to the set() or set_from_array() functions.
|
|
*
|
|
* @param array $channel A channel array, where these entries are evaluated:
|
|
* * \e string \b channel_allow_cid => string of allowed cids
|
|
* * \e string \b channel_allow_gid => string of allowed gids
|
|
* * \e string \b channel_deny_cid => string of denied cids
|
|
* * \e string \b channel_deny_gid => string of denied gids
|
|
*/
|
|
function __construct(array $channel) {
|
|
if ($channel) {
|
|
$this->validate_input_array($channel, self::REQUIRED_KEYS_CONSTRUCTOR);
|
|
$this->allow_cid = $channel['channel_allow_cid'];
|
|
$this->allow_gid = $channel['channel_allow_gid'];
|
|
$this->deny_cid = $channel['channel_deny_cid'];
|
|
$this->deny_gid = $channel['channel_deny_gid'];
|
|
}
|
|
else {
|
|
$this->allow_cid = '';
|
|
$this->allow_gid = '';
|
|
$this->deny_cid = '';
|
|
$this->deny_gid = '';
|
|
}
|
|
|
|
$this->explicit = false;
|
|
}
|
|
|
|
private function validate_input_array(array $arr, array $required_keys) : void {
|
|
$missing_keys = array_diff($required_keys, array_keys($arr));
|
|
|
|
if (!empty($missing_keys)) {
|
|
throw new \Exception(
|
|
'Invalid AccessList object: Expected array with keys: '
|
|
. implode(', ', $missing_keys)
|
|
);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @brief Get if we are using the default constructor values
|
|
* or values that have been set explicitly.
|
|
*
|
|
* @return boolean
|
|
*/
|
|
function get_explicit() : bool {
|
|
return $this->explicit;
|
|
}
|
|
|
|
/**
|
|
* @brief Set access list from strings such as those in already
|
|
* existing stored data items.
|
|
*
|
|
* @note The array to pass to this set function is different from the array
|
|
* that you provide to the constructor or set_from_array().
|
|
*
|
|
* @param array $arr
|
|
* * \e string \b allow_cid => string of allowed cids
|
|
* * \e string \b allow_gid => string of allowed gids
|
|
* * \e string \b deny_cid => string of denied cids
|
|
* * \e string \b deny_gid => string of denied gids
|
|
* @param boolean $explicit (optional) default true
|
|
*/
|
|
function set(array $arr, bool $explicit = true) : void {
|
|
$this->validate_input_array($arr, self::REQUIRED_KEYS_SET);
|
|
|
|
$this->allow_cid = $arr['allow_cid'];
|
|
$this->allow_gid = $arr['allow_gid'];
|
|
$this->deny_cid = $arr['deny_cid'];
|
|
$this->deny_gid = $arr['deny_gid'];
|
|
$this->explicit = $explicit;
|
|
}
|
|
|
|
/**
|
|
* @brief Return an array consisting of the current access list components
|
|
* where the elements are directly storable.
|
|
*
|
|
* @return array An associative array with:
|
|
* * \e string \b allow_cid => string of allowed cids
|
|
* * \e string \b allow_gid => string of allowed gids
|
|
* * \e string \b deny_cid => string of denied cids
|
|
* * \e string \b deny_gid => string of denied gids
|
|
*/
|
|
function get() : array {
|
|
return [
|
|
'allow_cid' => $this->allow_cid,
|
|
'allow_gid' => $this->allow_gid,
|
|
'deny_cid' => $this->deny_cid,
|
|
'deny_gid' => $this->deny_gid,
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @brief Set access list components from arrays, such as those provided by
|
|
* acl_selector().
|
|
*
|
|
* For convenience, a string (or non-array) input is assumed to be a
|
|
* comma-separated list and auto-converted into an array.
|
|
*
|
|
* @note The array to pass to this set function is different from the array
|
|
* that you provide to the constructor or set().
|
|
*
|
|
* @param array $arr An associative array with:
|
|
* * \e array|string \b contact_allow => array with cids or comma-seperated string
|
|
* * \e array|string \b group_allow => array with gids or comma-seperated string
|
|
* * \e array|string \b contact_deny => array with cids or comma-seperated string
|
|
* * \e array|string \b group_deny => array with gids or comma-seperated string
|
|
* @param boolean $explicit (optional) default true
|
|
*/
|
|
function set_from_array(array $arr, bool $explicit = true) : void {
|
|
$arr['contact_allow'] = $arr['contact_allow'] ?? [];
|
|
$arr['group_allow'] = $arr['group_allow'] ?? [];
|
|
$arr['contact_deny'] = $arr['contact_deny'] ?? [];
|
|
$arr['group_deny'] = $arr['group_deny'] ?? [];
|
|
|
|
$this->allow_cid = perms2str((is_array($arr['contact_allow']))
|
|
? $arr['contact_allow'] : explode(',', $arr['contact_allow']));
|
|
$this->allow_gid = perms2str((is_array($arr['group_allow']))
|
|
? $arr['group_allow'] : explode(',', $arr['group_allow']));
|
|
$this->deny_cid = perms2str((is_array($arr['contact_deny']))
|
|
? $arr['contact_deny'] : explode(',', $arr['contact_deny']));
|
|
$this->deny_gid = perms2str((is_array($arr['group_deny']))
|
|
? $arr['group_deny'] : explode(',', $arr['group_deny']));
|
|
|
|
$this->explicit = $explicit;
|
|
}
|
|
|
|
/**
|
|
* @brief Returns true if any access lists component is set.
|
|
*
|
|
* @return boolean Return true if any of allow_* deny_* values is set.
|
|
*/
|
|
function is_private() : bool {
|
|
return (($this->allow_cid || $this->allow_gid || $this->deny_cid || $this->deny_gid) ? true : false);
|
|
}
|
|
|
|
}
|