X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FCore%2FACL.php;h=a2db32afc459c44cc21bcaa6315230d7411cccb6;hb=f826ce70ceb9f810a16b70d3d77b9ba2c8d9097d;hp=347e8278f9eca5d3d1b2ab762e756fb382a9660c;hpb=dec87d89c049f6f93af8d70ffb093f3d88d892af;p=friendica.git diff --git a/src/Core/ACL.php b/src/Core/ACL.php index 347e8278f9..a2db32afc4 100644 --- a/src/Core/ACL.php +++ b/src/Core/ACL.php @@ -1,6 +1,6 @@ registerStylesheet(Theme::getPathForFile('js/friendica-tagsinput/friendica-tagsinput.css')); $page->registerStylesheet(Theme::getPathForFile('js/friendica-tagsinput/friendica-tagsinput-typeahead.css')); + $contacts = self::getValidMessageRecipientsForUser(DI::userSession()->getLocalUserId()); + + $tpl = Renderer::getMarkupTemplate('acl/message_recipient.tpl'); + $o = Renderer::replaceMacros($tpl, [ + '$contacts' => $contacts, + '$selected' => $selected, + ]); + + Hook::callAll(DI::args()->getModuleName() . '_post_recipient', $o); + + return $o; + } + + public static function getValidMessageRecipientsForUser(int $uid): array + { $condition = [ - 'uid' => local_user(), - 'self' => false, + 'uid' => $uid, + 'self' => false, 'blocked' => false, 'pending' => false, 'archive' => false, 'deleted' => false, - 'rel' => [Contact::FOLLOWER, Contact::SHARING, Contact::FRIEND], + 'rel' => [Contact::FOLLOWER, Contact::SHARING, Contact::FRIEND], 'network' => Protocol::SUPPORT_PRIVATE, ]; - $contacts = Contact::selectToArray( - ['id', 'name', 'addr', 'micro'], + return Contact::selectToArray( + ['id', 'name', 'addr', 'micro', 'url', 'nick'], DBA::mergeConditions($condition, ["`notify` != ''"]) ); - - $arr = ['contact' => $contacts, 'entry' => $o]; - - Hook::callAll(DI::module()->getName() . '_pre_recipient', $arr); - - $tpl = Renderer::getMarkupTemplate('acl/message_recipient.tpl'); - $o = Renderer::replaceMacros($tpl, [ - '$contacts' => $contacts, - '$selected' => $selected, - ]); - - Hook::callAll(DI::module()->getName() . '_post_recipient', $o); - - return $o; } /** @@ -341,4 +342,62 @@ class ACL return $o; } + + /** + * Checks the validity of the given ACL string + * + * @param string $acl_string + * @param int $uid + * @return bool + * @throws Exception + */ + public static function isValidContact($acl_string, $uid) + { + if (empty($acl_string)) { + return true; + } + + // split into array of cids + preg_match_all('/<[A-Za-z0-9]+>/', $acl_string, $array); + + // check for each cid if the contact is valid for the given user + $cid_array = $array[0]; + foreach ($cid_array as $cid) { + $cid = str_replace(['<', '>'], ['', ''], $cid); + if (!DBA::exists('contact', ['id' => $cid, 'uid' => $uid])) { + return false; + } + } + + return true; + } + + /** + * Checks the validity of the given ACL string + * + * @param string $acl_string + * @param int $uid + * @return bool + * @throws Exception + */ + public static function isValidGroup($acl_string, $uid) + { + if (empty($acl_string)) { + return true; + } + + // split into array of cids + preg_match_all('/<[A-Za-z0-9]+>/', $acl_string, $array); + + // check for each cid if the contact is valid for the given user + $gid_array = $array[0]; + foreach ($gid_array as $gid) { + $gid = str_replace(['<', '>'], ['', ''], $gid); + if (!DBA::exists('group', ['id' => $gid, 'uid' => $uid, 'deleted' => false])) { + return false; + } + } + + return true; + } }