global_perm = $global_perm; $this->channel_perm = $channel_perm; $this->fallback_description = ($description == '') ? t('Visible to your default audience') : $description; } /** * If the interpretation of an empty ACL can't be summarised with a global default permission * or a specific permission setting then use this method and describe what it means instead. * Remember to localize the description first. * * @param string $description - the localized caption for the no-ACL option in the ACL dialog. * @return a new instance of PermissionDescription */ public static function fromDescription($description) { return new PermissionDescription('', 0x80000, $description); } /** * Use this method only if the interpretation of an empty ACL doesn't fall back to a global * default permission. You should pass one of the constants from boot.php - PERMS_PUBLIC, * PERMS_NETWORK etc. * * @param integer $perm - a single enumerated constant permission - PERMS_PUBLIC, PERMS_NETWORK etc. * @return a new instance of PermissionDescription */ public static function fromStandalonePermission($perm) { $result = new PermissionDescription('', $perm); $checkPerm = $result->get_permission_description(); if($checkPerm == $result->fallback_description) { $result = null; logger('null PermissionDescription from unknown standalone permission: ' . $perm, LOGGER_DEBUG, LOG_ERR); } return $result; } /** * This is the preferred way to create a PermissionDescription, as it provides the most details. * Use this method if you know an empty ACL will result in one of the global default permissions * being used, such as channel_r_stream (for which you would pass 'view_stream'). * * @param string $permname - a key for the global perms array from get_perms() in permissions.php, * e.g. 'view_stream', 'view_profile', etc. * @return a new instance of PermissionDescription */ public static function fromGlobalPermission($permname) { $result = null; $global_perms = \Zotlabs\Access\Permissions::Perms(); if(array_key_exists($permname, $global_perms)) { $channelPerm = \Zotlabs\Access\PermissionLimits::Get(\App::$channel['channel_id'], $permname); $result = new PermissionDescription('', $channelPerm); } else { // The acl dialog can handle null arguments, but it shouldn't happen logger('null PermissionDescription from unknown global permission: ' . $permname, LOGGER_DEBUG, LOG_ERR); } return $result; } /** * Gets a localized description of the permission, or a generic message if the permission * is unknown. * * @return string description */ public function get_permission_description() { switch($this->channel_perm) { case 0: return t('Only me'); case PERMS_PUBLIC: return t('Public'); case PERMS_NETWORK: return t('Anybody in the $Projectname network'); case PERMS_SITE: return sprintf(t('Any account on %s'), \App::get_hostname()); case PERMS_CONTACTS: return t('Any of my connections'); case PERMS_SPECIFIC: return t('Only connections I specifically allow'); case PERMS_AUTHED: return t('Anybody authenticated (could include visitors from other networks)'); case PERMS_PENDING: return t('Any connections including those who haven\'t yet been approved'); default: return $this->fallback_description; } } /** * Returns an icon css class name if an appropriate one is available, e.g. "bi-globe" for Public, * otherwise returns empty string. * * @return string icon css class name (often FontAwesome) */ public function get_permission_icon() { switch($this->channel_perm) { case 0:/* only me */ return 'bi-eye-slash'; case PERMS_PUBLIC: return 'bi-globe'; case PERMS_NETWORK: return 'bi-share'; // bi-share is very similiar to the hubzilla logo, but we should create our own logo class to use case PERMS_SITE: return 'bi-geo'; case PERMS_CONTACTS: return 'bi-people'; case PERMS_SPECIFIC: return 'bi-list-ul'; case PERMS_AUTHED: return ''; case PERMS_PENDING: return ''; default: return ''; } } /** * Returns a localized description of where the permission came from, if this is known. * If it's not know, or if the permission is standalone and didn't come from a default * permission setting, then empty string is returned. * * @return string description or empty string */ public function get_permission_origin_description() { switch($this->global_perm) { case PERMS_R_STREAM: return t('This is your default setting for the audience of your normal stream, and posts.'); case PERMS_R_PROFILE: return t('This is your default setting for who can view your default channel profile'); case PERMS_R_ABOOK: return t('This is your default setting for who can view your connections'); case PERMS_R_STORAGE: return t('This is your default setting for who can view your file storage and photos'); case PERMS_R_PAGES: return t('This is your default setting for the audience of your webpages'); default: return ''; } } }