74 lines
2.5 KiB
PHP
74 lines
2.5 KiB
PHP
<?php
|
|
|
|
|
|
namespace Zotlabs\Access;
|
|
|
|
use Zotlabs\Lib as Zlib;
|
|
|
|
class Permissions {
|
|
|
|
/**
|
|
* Extensible permissions.
|
|
* To add new permissions, add to the list of $perms below, with a simple description.
|
|
* Also visit PermissionRoles.php and add to the $ret['perms_connect'] property for any role
|
|
* if this permission should be granted to new connections.
|
|
*
|
|
* Permissions with 'view' in the name are considered read permissions. Anything
|
|
* else requires authentication. Read permission limits are PERMS_PUBLIC and anything else
|
|
* is given PERMS_SPECIFIC.
|
|
*
|
|
* PermissionLimits::Std_limits() retrieves the standard limits. A permission role
|
|
* MAY alter an individual setting after retrieving the Std_limits if you require
|
|
* something different for a specific permission within the given role.
|
|
*
|
|
*/
|
|
|
|
|
|
static public function Perms($filter = '') {
|
|
|
|
$perms = [
|
|
[ 'view_stream' => t('Can view my normal stream and posts') ],
|
|
[ 'send_stream' => t('Can send me their channel stream and posts') ],
|
|
[ 'view_profile' => t('Can view my default channel profile') ],
|
|
[ 'view_contacts' => t('Can view my connections') ],
|
|
[ 'view_storage' => t('Can view my file storage and photos') ],
|
|
[ 'write_storage' => t('Can upload/modify my file storage and photos') ],
|
|
[ 'view_pages' => t('Can view my channel webpages') ],
|
|
[ 'write_pages' => t('Can create/edit my channel webpages') ],
|
|
[ 'post_wall' => t('Can post on my channel (wall) page') ],
|
|
[ 'post_comments' => t('Can comment on or like my posts') ],
|
|
[ 'post_mail' => t('Can send me private mail messages') ],
|
|
[ 'post_like' => t('Can like/dislike profiles and profile things') ],
|
|
[ 'tag_deliver' => t('Can forward to all my channel connections via @+ mentions in posts') ],
|
|
[ 'chat' => t('Can chat with me') ],
|
|
[ 'republish' => t('Can source my public posts in derived channels') ],
|
|
[ 'delegate' => t('Can administer my channel') ]
|
|
];
|
|
|
|
$x = array('permissions' => $perms, 'filter' => $filter);
|
|
call_hooks('permissions_list',$x);
|
|
return($x['permissions']);
|
|
|
|
}
|
|
|
|
static public function BlockedAnonPerms() {
|
|
|
|
// Perms from the above list that are blocked from anonymous observers.
|
|
// e.g. you must be authenticated.
|
|
|
|
$res = array();
|
|
$perms = PermissionLimits::Std_limits();
|
|
foreach($perms as $perm => $limit) {
|
|
if($limit != PERMS_PUBLIC) {
|
|
$res[] = $perm;
|
|
}
|
|
}
|
|
|
|
$x = array('permissions' => $res);
|
|
call_hooks('write_perms',$x);
|
|
return($x['permissions']);
|
|
|
|
}
|
|
|
|
|
|
} |