feature management for admins: Merge branch 'devolop'
This commit is contained in:
parent
135052a5a0
commit
c1ed2bd975
|
@ -1,23 +1,25 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @file include/features.php *
|
* @file include/features.php
|
||||||
* @brief Features management
|
* @brief Features management
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief check if feature is enabled
|
* @brief check if feature is enabled
|
||||||
*
|
*
|
||||||
* return boolean
|
* @return boolean
|
||||||
*/
|
*/
|
||||||
function feature_enabled($uid,$feature) {
|
function feature_enabled($uid,$feature) {
|
||||||
//return true;
|
|
||||||
|
|
||||||
$x = get_pconfig($uid,'feature',$feature);
|
$x = get_config('feature_lock',$feature);
|
||||||
if($x === false) {
|
if($x === false) {
|
||||||
$x = get_config('feature',$feature);
|
$x = get_pconfig($uid,'feature',$feature);
|
||||||
if($x === false)
|
if($x === false) {
|
||||||
$x = get_feature_default($feature);
|
$x = get_config('feature',$feature);
|
||||||
|
if($x === false)
|
||||||
|
$x = get_feature_default($feature);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
$arr = array('uid' => $uid, 'feature' => $feature, 'enabled' => $x);
|
$arr = array('uid' => $uid, 'feature' => $feature, 'enabled' => $x);
|
||||||
call_hooks('feature_enabled',$arr);
|
call_hooks('feature_enabled',$arr);
|
||||||
|
@ -42,14 +44,17 @@ function get_feature_default($feature) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @ brief get a list of all available features
|
* @brief Get a list of all available features
|
||||||
|
*
|
||||||
* The array includes the setting group, the setting name,
|
* The array includes the setting group, the setting name,
|
||||||
* explainations for the setting and if it's enabled or disabled
|
* explainations for the setting and if it's enabled or disabled
|
||||||
* by default
|
* by default
|
||||||
*
|
*
|
||||||
|
* @param bool $filtered True removes any locked features
|
||||||
|
*
|
||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
function get_features() {
|
function get_features($filtered = true) {
|
||||||
|
|
||||||
$arr = array(
|
$arr = array(
|
||||||
|
|
||||||
|
@ -57,56 +62,78 @@ function get_features() {
|
||||||
'general' => array(
|
'general' => array(
|
||||||
t('General Features'),
|
t('General Features'),
|
||||||
//array('expire', t('Content Expiration'), t('Remove old posts/comments after a period of time')),
|
//array('expire', t('Content Expiration'), t('Remove old posts/comments after a period of time')),
|
||||||
array('multi_profiles', t('Multiple Profiles'), t('Ability to create multiple profiles'),false),
|
array('multi_profiles', t('Multiple Profiles'), t('Ability to create multiple profiles'), false, get_config('feature_lock','multi_profiles')),
|
||||||
array('photo_location', t('Photo Location'), t('Photo metadata is normally stripped. This extracts the location (if present) prior to stripping metadata and links it to a map.'),false),
|
array('photo_location', t('Photo Location'), t('Photo metadata is normally stripped. This extracts the location (if present) prior to stripping metadata and links it to a map.'), false, get_config('feature_lock','photo_location')),
|
||||||
),
|
),
|
||||||
|
|
||||||
// Post composition
|
// Post composition
|
||||||
'composition' => array(
|
'composition' => array(
|
||||||
t('Post Composition Features'),
|
t('Post Composition Features'),
|
||||||
array('richtext', t('Richtext Editor'), t('Enable richtext editor'),false),
|
array('richtext', t('Richtext Editor'), t('Enable richtext editor'), false, get_config('feature_lock','richtext')),
|
||||||
array('preview', t('Post Preview'), t('Allow previewing posts and comments before publishing them'),false),
|
array('preview', t('Post Preview'), t('Allow previewing posts and comments before publishing them'), false, get_config('feature_lock','preview')),
|
||||||
array('aclautomention', t('Auto-mention Forums'), t('Add/remove mention when a fourm page is selected/deselected in ACL window.'),false),
|
array('aclautomention', t('Auto-mention Forums'), t('Add/remove mention when a fourm page is selected/deselected in ACL window.'), false, get_config('feature_lock','aclautomention')),
|
||||||
),
|
),
|
||||||
|
|
||||||
// Network sidebar widgets
|
// Network sidebar widgets
|
||||||
'widgets' => array(
|
'widgets' => array(
|
||||||
t('Network Sidebar Widgets'),
|
t('Network Sidebar Widgets'),
|
||||||
array('archives', t('Search by Date'), t('Ability to select posts by date ranges'),false),
|
array('archives', t('Search by Date'), t('Ability to select posts by date ranges'), false, get_config('feature_lock','archives')),
|
||||||
array('forumlist_widget', t('List Forums'), t('Enable widget to display the forums your are connected with'),true),
|
array('forumlist_widget', t('List Forums'), t('Enable widget to display the forums your are connected with'), true, get_config('feature_lock','forumlist_widget')),
|
||||||
array('groups', t('Group Filter'), t('Enable widget to display Network posts only from selected group'),false),
|
array('groups', t('Group Filter'), t('Enable widget to display Network posts only from selected group'), false, get_config('feature_lock','groups')),
|
||||||
array('networks', t('Network Filter'), t('Enable widget to display Network posts only from selected network'),false),
|
array('networks', t('Network Filter'), t('Enable widget to display Network posts only from selected network'), false, get_config('feature_lock','networks')),
|
||||||
array('savedsearch', t('Saved Searches'), t('Save search terms for re-use'),false),
|
array('savedsearch', t('Saved Searches'), t('Save search terms for re-use'), false, get_config('feature_lock','savedsearch')),
|
||||||
),
|
),
|
||||||
|
|
||||||
// Network tabs
|
// Network tabs
|
||||||
'net_tabs' => array(
|
'net_tabs' => array(
|
||||||
t('Network Tabs'),
|
t('Network Tabs'),
|
||||||
array('personal_tab', t('Network Personal Tab'), t('Enable tab to display only Network posts that you\'ve interacted on'),false),
|
array('personal_tab', t('Network Personal Tab'), t('Enable tab to display only Network posts that you\'ve interacted on'), false, get_config('feature_lock','personal_tab')),
|
||||||
array('new_tab', t('Network New Tab'), t('Enable tab to display only new Network posts (from the last 12 hours)'),false),
|
array('new_tab', t('Network New Tab'), t('Enable tab to display only new Network posts (from the last 12 hours)'), false, get_config('feature_lock','new_tab')),
|
||||||
array('link_tab', t('Network Shared Links Tab'), t('Enable tab to display only Network posts with links in them'),false),
|
array('link_tab', t('Network Shared Links Tab'), t('Enable tab to display only Network posts with links in them'), false, get_config('feature_lock','link_tab')),
|
||||||
),
|
),
|
||||||
|
|
||||||
// Item tools
|
// Item tools
|
||||||
'tools' => array(
|
'tools' => array(
|
||||||
t('Post/Comment Tools'),
|
t('Post/Comment Tools'),
|
||||||
array('multi_delete', t('Multiple Deletion'), t('Select and delete multiple posts/comments at once'),false),
|
array('multi_delete', t('Multiple Deletion'), t('Select and delete multiple posts/comments at once'), false, get_config('feature_lock','multi_delete')),
|
||||||
array('edit_posts', t('Edit Sent Posts'), t('Edit and correct posts and comments after sending'),false),
|
array('edit_posts', t('Edit Sent Posts'), t('Edit and correct posts and comments after sending'), false, get_config('feature_lock','edit_posts')),
|
||||||
array('commtag', t('Tagging'), t('Ability to tag existing posts'),false),
|
array('commtag', t('Tagging'), t('Ability to tag existing posts'), false, get_config('feature_lock','commtag')),
|
||||||
array('categories', t('Post Categories'), t('Add categories to your posts'),false),
|
array('categories', t('Post Categories'), t('Add categories to your posts'), false, get_config('feature_lock','categories')),
|
||||||
array('filing', t('Saved Folders'), t('Ability to file posts under folders'),false),
|
array('filing', t('Saved Folders'), t('Ability to file posts under folders'), false, get_config('feature_lock','filing')),
|
||||||
array('dislike', t('Dislike Posts'), t('Ability to dislike posts/comments')),
|
array('dislike', t('Dislike Posts'), t('Ability to dislike posts/comments'), false, get_config('feature_lock','dislike')),
|
||||||
array('star_posts', t('Star Posts'), t('Ability to mark special posts with a star indicator'),false),
|
array('star_posts', t('Star Posts'), t('Ability to mark special posts with a star indicator'), false, get_config('feature_lock','star_posts')),
|
||||||
array('ignore_posts', t('Mute Post Notifications'), t('Ability to mute notifications for a thread'),false),
|
array('ignore_posts', t('Mute Post Notifications'), t('Ability to mute notifications for a thread'), false, get_config('feature_lock','ignore_posts')),
|
||||||
),
|
),
|
||||||
|
|
||||||
// Advanced Profile Settings
|
// Advanced Profile Settings
|
||||||
'advanced_profile' => array(
|
'advanced_profile' => array(
|
||||||
t('Advanced Profile Settings'),
|
t('Advanced Profile Settings'),
|
||||||
array('forumlist_profile', t('List Forums'), t('Show visitors public community forums at the Advanced Profile Page'),false),
|
array('forumlist_profile', t('List Forums'), t('Show visitors public community forums at the Advanced Profile Page'), false, get_config('feature_lock','forumlist_profile')),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// removed any locked features and remove the entire category if this makes it empty
|
||||||
|
|
||||||
|
if($filtered) {
|
||||||
|
foreach($arr as $k => $x) {
|
||||||
|
$has_items = false;
|
||||||
|
$kquantity = count($arr[$k]);
|
||||||
|
for($y = 0; $y < $kquantity; $y ++) {
|
||||||
|
if(is_array($arr[$k][$y])) {
|
||||||
|
if($arr[$k][$y][4] === false) {
|
||||||
|
$has_items = true;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
unset($arr[$k][$y]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(! $has_items) {
|
||||||
|
unset($arr[$k]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
call_hooks('get_features',$arr);
|
call_hooks('get_features',$arr);
|
||||||
return $arr;
|
return $arr;
|
||||||
}
|
}
|
||||||
|
|
618
mod/admin.php
618
mod/admin.php
File diff suppressed because it is too large
Load diff
|
@ -29,10 +29,21 @@ function friendica_init(&$a) {
|
||||||
$visible_plugins[] = $rr['name'];
|
$visible_plugins[] = $rr['name'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
load_config('feature_lock');
|
||||||
|
$locked_features = array();
|
||||||
|
if(is_array($a->config['feature_lock']) && count($a->config['feature_lock'])) {
|
||||||
|
foreach($a->config['feature_lock'] as $k => $v) {
|
||||||
|
if($k === 'config_loaded')
|
||||||
|
continue;
|
||||||
|
$locked_features[$k] = intval($v);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$data = Array(
|
$data = Array(
|
||||||
'version' => FRIENDICA_VERSION,
|
'version' => FRIENDICA_VERSION,
|
||||||
'url' => z_root(),
|
'url' => z_root(),
|
||||||
'plugins' => $visible_plugins,
|
'plugins' => $visible_plugins,
|
||||||
|
'locked_features' => $locked_features,
|
||||||
'register_policy' => $register_policy[$a->config['register_policy']],
|
'register_policy' => $register_policy[$a->config['register_policy']],
|
||||||
'admin' => $admin,
|
'admin' => $admin,
|
||||||
'site_name' => $a->config['sitename'],
|
'site_name' => $a->config['sitename'],
|
||||||
|
|
113
mod/settings.php
113
mod/settings.php
|
@ -43,57 +43,67 @@ function settings_init(&$a) {
|
||||||
'selected' => (($a->argc == 1) && ($a->argv[0] === 'settings')?'active':''),
|
'selected' => (($a->argc == 1) && ($a->argv[0] === 'settings')?'active':''),
|
||||||
'accesskey' => 'o',
|
'accesskey' => 'o',
|
||||||
),
|
),
|
||||||
array(
|
|
||||||
'label' => t('Additional features'),
|
|
||||||
'url' => $a->get_baseurl(true).'/settings/features',
|
|
||||||
'selected' => (($a->argc > 1) && ($a->argv[1] === 'features') ? 'active' : ''),
|
|
||||||
'accesskey' => 't',
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'label' => t('Display'),
|
|
||||||
'url' => $a->get_baseurl(true).'/settings/display',
|
|
||||||
'selected' => (($a->argc > 1) && ($a->argv[1] === 'display')?'active':''),
|
|
||||||
'accesskey' => 'i',
|
|
||||||
),
|
|
||||||
|
|
||||||
array(
|
|
||||||
'label' => t('Social Networks'),
|
|
||||||
'url' => $a->get_baseurl(true).'/settings/connectors',
|
|
||||||
'selected' => (($a->argc > 1) && ($a->argv[1] === 'connectors')?'active':''),
|
|
||||||
'accesskey' => 'w',
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'label' => t('Plugins'),
|
|
||||||
'url' => $a->get_baseurl(true).'/settings/addon',
|
|
||||||
'selected' => (($a->argc > 1) && ($a->argv[1] === 'addon')?'active':''),
|
|
||||||
'accesskey' => 'l',
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'label' => t('Delegations'),
|
|
||||||
'url' => $a->get_baseurl(true).'/delegate',
|
|
||||||
'selected' => (($a->argc == 1) && ($a->argv[0] === 'delegate')?'active':''),
|
|
||||||
'accesskey' => 'd',
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'label' => t('Connected apps'),
|
|
||||||
'url' => $a->get_baseurl(true) . '/settings/oauth',
|
|
||||||
'selected' => (($a->argc > 1) && ($a->argv[1] === 'oauth')?'active':''),
|
|
||||||
'accesskey' => 'b',
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'label' => t('Export personal data'),
|
|
||||||
'url' => $a->get_baseurl(true) . '/uexport',
|
|
||||||
'selected' => (($a->argc == 1) && ($a->argv[0] === 'uexport')?'active':''),
|
|
||||||
'accesskey' => 'e',
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'label' => t('Remove account'),
|
|
||||||
'url' => $a->get_baseurl(true) . '/removeme',
|
|
||||||
'selected' => (($a->argc == 1) && ($a->argv[0] === 'removeme')?'active':''),
|
|
||||||
'accesskey' => 'r',
|
|
||||||
)
|
|
||||||
);
|
);
|
||||||
|
|
||||||
|
if(get_features()) {
|
||||||
|
$tabs[] = array(
|
||||||
|
'label' => t('Additional features'),
|
||||||
|
'url' => $a->get_baseurl(true).'/settings/features',
|
||||||
|
'selected' => (($a->argc > 1) && ($a->argv[1] === 'features') ? 'active' : ''),
|
||||||
|
'accesskey' => 't',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
$tabs[] = array(
|
||||||
|
'label' => t('Display'),
|
||||||
|
'url' => $a->get_baseurl(true).'/settings/display',
|
||||||
|
'selected' => (($a->argc > 1) && ($a->argv[1] === 'display')?'active':''),
|
||||||
|
'accesskey' => 'i',
|
||||||
|
);
|
||||||
|
|
||||||
|
$tabs[] = array(
|
||||||
|
'label' => t('Social Networks'),
|
||||||
|
'url' => $a->get_baseurl(true).'/settings/connectors',
|
||||||
|
'selected' => (($a->argc > 1) && ($a->argv[1] === 'connectors')?'active':''),
|
||||||
|
'accesskey' => 'w',
|
||||||
|
);
|
||||||
|
|
||||||
|
$tabs[] = array(
|
||||||
|
'label' => t('Plugins'),
|
||||||
|
'url' => $a->get_baseurl(true).'/settings/addon',
|
||||||
|
'selected' => (($a->argc > 1) && ($a->argv[1] === 'addon')?'active':''),
|
||||||
|
'accesskey' => 'l',
|
||||||
|
);
|
||||||
|
|
||||||
|
$tabs[] = array(
|
||||||
|
'label' => t('Delegations'),
|
||||||
|
'url' => $a->get_baseurl(true).'/delegate',
|
||||||
|
'selected' => (($a->argc == 1) && ($a->argv[0] === 'delegate')?'active':''),
|
||||||
|
'accesskey' => 'd',
|
||||||
|
);
|
||||||
|
|
||||||
|
$tabs[] = array(
|
||||||
|
'label' => t('Connected apps'),
|
||||||
|
'url' => $a->get_baseurl(true) . '/settings/oauth',
|
||||||
|
'selected' => (($a->argc > 1) && ($a->argv[1] === 'oauth')?'active':''),
|
||||||
|
'accesskey' => 'b',
|
||||||
|
);
|
||||||
|
|
||||||
|
$tabs[] = array(
|
||||||
|
'label' => t('Export personal data'),
|
||||||
|
'url' => $a->get_baseurl(true) . '/uexport',
|
||||||
|
'selected' => (($a->argc == 1) && ($a->argv[0] === 'uexport')?'active':''),
|
||||||
|
'accesskey' => 'e',
|
||||||
|
);
|
||||||
|
|
||||||
|
$tabs[] = array(
|
||||||
|
'label' => t('Remove account'),
|
||||||
|
'url' => $a->get_baseurl(true) . '/removeme',
|
||||||
|
'selected' => (($a->argc == 1) && ($a->argv[0] === 'removeme')?'active':''),
|
||||||
|
'accesskey' => 'r',
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
$tabtpl = get_markup_template("generic_links_widget.tpl");
|
$tabtpl = get_markup_template("generic_links_widget.tpl");
|
||||||
$a->page['aside'] = replace_macros($tabtpl, array(
|
$a->page['aside'] = replace_macros($tabtpl, array(
|
||||||
'$title' => t('Settings'),
|
'$title' => t('Settings'),
|
||||||
|
@ -622,7 +632,6 @@ function settings_post(&$a) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if(! function_exists('settings_content')) {
|
|
||||||
function settings_content(&$a) {
|
function settings_content(&$a) {
|
||||||
|
|
||||||
$o = '';
|
$o = '';
|
||||||
|
@ -747,7 +756,7 @@ function settings_content(&$a) {
|
||||||
$arr[$fname] = array();
|
$arr[$fname] = array();
|
||||||
$arr[$fname][0] = $fdata[0];
|
$arr[$fname][0] = $fdata[0];
|
||||||
foreach(array_slice($fdata,1) as $f) {
|
foreach(array_slice($fdata,1) as $f) {
|
||||||
$arr[$fname][1][] = array('feature_' .$f[0],$f[1],((intval(get_pconfig(local_user(),'feature',$f[0]))) ? "1" : ''),$f[2],array(t('Off'),t('On')));
|
$arr[$fname][1][] = array('feature_' .$f[0],$f[1],((intval(feature_enabled(local_user(),$f[0]))) ? "1" : ''),$f[2],array(t('Off'),t('On')));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1287,5 +1296,5 @@ function settings_content(&$a) {
|
||||||
|
|
||||||
return $o;
|
return $o;
|
||||||
|
|
||||||
}}
|
}
|
||||||
|
|
||||||
|
|
21
view/templates/admin_settings_features.tpl
Normal file
21
view/templates/admin_settings_features.tpl
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
<h1>{{$title}}</h1>
|
||||||
|
|
||||||
|
<form action="admin/features" method="post" autocomplete="off">
|
||||||
|
<input type='hidden' name='form_security_token' value='{{$form_security_token}}'>
|
||||||
|
|
||||||
|
{{foreach $features as $g => $f}}
|
||||||
|
<h3 class="settings-heading"><a href="javascript:;">{{$f.0}}</a></h3>
|
||||||
|
|
||||||
|
<div class="settings-content-block">
|
||||||
|
{{foreach $f.1 as $fcat}}
|
||||||
|
{{include file="field_yesno.tpl" field=$fcat.0}}
|
||||||
|
{{include file="field_yesno.tpl" field=$fcat.1}}
|
||||||
|
{{/foreach}}
|
||||||
|
|
||||||
|
<div class="settings-submit-wrapper" >
|
||||||
|
<input type="submit" name="submit" class="settings-features-submit" value="{{$submit|escape:'html'}}" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{{/foreach}}
|
||||||
|
|
||||||
|
</form>
|
9
view/templates/admin_settings_head.tpl
Normal file
9
view/templates/admin_settings_head.tpl
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
<script>
|
||||||
|
$(document).ready(function() {
|
||||||
|
$('.settings-content-block').hide();
|
||||||
|
$('.settings-heading').click(function(){
|
||||||
|
$('.settings-content-block').hide();
|
||||||
|
$(this).next('.settings-content-block').toggle();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
</script>
|
Loading…
Reference in a new issue