2001-12-28 01:59:30 +01:00
|
|
|
<?php
|
|
|
|
/**************************************************************************\
|
2004-08-09 16:30:59 +02:00
|
|
|
* eGroupWare - Preferences *
|
|
|
|
* http://www.egroupware.org *
|
2001-12-28 01:59:30 +01:00
|
|
|
* -------------------------------------------- *
|
|
|
|
* This program is free software; you can redistribute it and/or modify it *
|
|
|
|
* under the terms of the GNU General Public License as published by the *
|
|
|
|
* Free Software Foundation; either version 2 of the License, or (at your *
|
|
|
|
* option) any later version. *
|
|
|
|
\**************************************************************************/
|
2003-08-28 16:31:11 +02:00
|
|
|
|
2001-12-28 01:59:30 +01:00
|
|
|
/* $Id$ */
|
|
|
|
|
|
|
|
class uiaclprefs
|
|
|
|
{
|
|
|
|
var $acl;
|
|
|
|
var $template;
|
|
|
|
|
|
|
|
var $public_functions = array('index' => True);
|
|
|
|
|
|
|
|
function index()
|
|
|
|
{
|
2006-12-06 15:53:03 +01:00
|
|
|
$query_types = array(
|
|
|
|
'all' => 'all fields',
|
|
|
|
'lid' => 'LoginID',
|
|
|
|
'start' => 'start with',
|
|
|
|
'exact' => 'exact',
|
|
|
|
);
|
|
|
|
|
2003-08-28 16:31:11 +02:00
|
|
|
$acl_app = get_var('acl_app',array('POST','GET'));
|
2004-08-31 11:33:08 +02:00
|
|
|
$start = get_var('start',array('POST','GET'),0);
|
2003-08-28 16:31:11 +02:00
|
|
|
$query = get_var('query',array('POST','GET'));
|
2005-07-09 21:07:16 +02:00
|
|
|
$owner = get_var('owner',array('POST','GET'),$GLOBALS['egw_info']['user']['account_id']);
|
2006-12-06 15:53:03 +01:00
|
|
|
$search_type= get_var('search_type',array('POST','GET'));
|
|
|
|
|
2004-08-28 15:41:23 +02:00
|
|
|
if (!$acl_app)
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2003-08-28 16:31:11 +02:00
|
|
|
$acl_app = 'preferences';
|
2002-06-18 03:13:43 +02:00
|
|
|
$acl_app_not_passed = True;
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
2003-04-20 22:47:50 +02:00
|
|
|
else
|
|
|
|
{
|
2005-07-09 21:07:16 +02:00
|
|
|
$GLOBALS['egw']->translation->add_app($acl_app);
|
2003-04-20 22:47:50 +02:00
|
|
|
}
|
2005-11-08 12:40:35 +01:00
|
|
|
// make acl called via sidebox menu of an app, to behave like a part of that app
|
|
|
|
$referer = $_POST['referer'];
|
|
|
|
if (!$referer)
|
|
|
|
{
|
2005-11-09 13:46:52 +01:00
|
|
|
$referer = $GLOBALS['egw']->common->get_referer('/preferences/index.php');
|
2005-11-08 12:40:35 +01:00
|
|
|
}
|
2006-12-06 15:53:03 +01:00
|
|
|
//echo '<p align="right">'."search_type='$search_type'</p>\n";
|
2001-12-28 01:59:30 +01:00
|
|
|
|
2005-07-09 21:07:16 +02:00
|
|
|
$GLOBALS['egw_info']['flags']['currentapp'] = $acl_app;
|
2001-12-28 01:59:30 +01:00
|
|
|
|
|
|
|
if ($acl_app_not_passed)
|
|
|
|
{
|
2005-07-09 21:07:16 +02:00
|
|
|
if(is_object($GLOBALS['egw']->log))
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2005-07-09 21:07:16 +02:00
|
|
|
$GLOBALS['egw']->log->message(array(
|
2001-12-28 01:59:30 +01:00
|
|
|
'text' => 'F-BadmenuactionVariable, failed to pass acl_app.',
|
|
|
|
'line' => __LINE__,
|
|
|
|
'file' => __FILE__
|
|
|
|
));
|
2005-07-09 21:07:16 +02:00
|
|
|
$GLOBALS['egw']->log->commit();
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-07-09 21:07:16 +02:00
|
|
|
if (($GLOBALS['egw_info']['server']['deny_user_grants_access'] || $owner != $GLOBALS['egw_info']['user']['account_id'])
|
|
|
|
&& !isset($GLOBALS['egw_info']['user']['apps']['admin']) || $acl_app_not_passed)
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2005-10-14 16:31:35 +02:00
|
|
|
$GLOBALS['egw']->common->egw_header();
|
2004-08-31 11:33:08 +02:00
|
|
|
echo parse_navbar();
|
2001-12-28 01:59:30 +01:00
|
|
|
echo '<center><b>' . lang('Access not permitted') . '</b></center>';
|
2005-10-14 16:31:35 +02:00
|
|
|
$GLOBALS['egw']->common->egw_footer();
|
2004-08-31 11:33:08 +02:00
|
|
|
return;
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
|
|
|
|
2005-11-08 12:40:35 +01:00
|
|
|
$owner_name = $GLOBALS['egw']->common->grab_owner_name($owner);
|
2005-12-15 00:26:26 +01:00
|
|
|
if(!($no_privat_grants = $GLOBALS['egw']->accounts->get_type($owner) == 'g'))
|
2004-08-28 15:41:23 +02:00
|
|
|
{
|
2005-11-08 12:40:35 +01:00
|
|
|
// admin setting acl-rights is handled as with group-rights => no private grants !!
|
2005-07-09 21:07:16 +02:00
|
|
|
$no_privat_grants = $owner != $GLOBALS['egw_info']['user']['account_id'];
|
2004-08-28 15:41:23 +02:00
|
|
|
}
|
2005-10-14 16:31:35 +02:00
|
|
|
$this->acl =& CreateObject('phpgwapi.acl',(int)$owner);
|
2010-04-20 09:08:56 +02:00
|
|
|
// should we enumerate group acl (does app use it), eg. addressbook does NOT use group ACL's but group addressbooks
|
|
|
|
$not_enum_group_acls = $acl_app == 'addressbook' ? true : $GLOBALS['egw']->hooks->single('not_enum_group_acls',$acl_app);
|
|
|
|
$this->acl->read_repository($not_enum_group_acls);
|
2001-12-28 01:59:30 +01:00
|
|
|
|
2005-11-08 12:40:35 +01:00
|
|
|
if ($_POST['save'] || $_POST['apply'])
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2003-08-28 16:31:11 +02:00
|
|
|
$processed = $_POST['processed'];
|
2001-12-28 01:59:30 +01:00
|
|
|
$to_remove = unserialize(urldecode($processed));
|
2004-08-31 11:33:08 +02:00
|
|
|
foreach($to_remove as $uid)
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2005-07-09 21:07:16 +02:00
|
|
|
//echo "deleting acl-records for $uid=".$GLOBALS['egw']->accounts->id2name($uid)." and $acl_app<br>\n";
|
2004-08-31 11:33:08 +02:00
|
|
|
$this->acl->delete($acl_app,$uid);
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Group records */
|
2004-08-28 15:41:23 +02:00
|
|
|
$totalacl = array();
|
2005-07-09 21:07:16 +02:00
|
|
|
$group_variable = $_POST['g_'.$GLOBALS['egw_info']['flags']['currentapp']];
|
2001-12-28 01:59:30 +01:00
|
|
|
|
2004-08-28 15:41:23 +02:00
|
|
|
if (is_array($group_variable))
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2004-08-28 15:41:23 +02:00
|
|
|
foreach($group_variable as $rowinfo => $perm)
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2004-08-28 15:41:23 +02:00
|
|
|
list($group_id,$rights) = explode('_',$rowinfo);
|
|
|
|
$totalacl[$group_id] += $rights;
|
|
|
|
}
|
|
|
|
foreach($totalacl as $group_id => $rights)
|
|
|
|
{
|
|
|
|
if($no_privat_grants)
|
|
|
|
{
|
|
|
|
/* Don't allow group-grants or admin to grant private */
|
2005-07-09 21:07:16 +02:00
|
|
|
$rights &= ~EGW_ACL_PRIVATE;
|
2004-08-28 15:41:23 +02:00
|
|
|
}
|
2005-07-09 21:07:16 +02:00
|
|
|
//echo "adding acl-rights $rights for $group_id=".$GLOBALS['egw']->accounts->id2name($group_id)." and $acl_app<br>\n";
|
|
|
|
$this->acl->add($GLOBALS['egw_info']['flags']['currentapp'],$group_id,$rights);
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* User records */
|
2004-08-28 15:41:23 +02:00
|
|
|
$totalacl = array();
|
2005-07-09 21:07:16 +02:00
|
|
|
$user_variable = $_POST['u_'.$GLOBALS['egw_info']['flags']['currentapp']];
|
2001-12-28 01:59:30 +01:00
|
|
|
|
2004-08-28 15:41:23 +02:00
|
|
|
if (is_array($user_variable))
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2004-08-28 15:41:23 +02:00
|
|
|
foreach($user_variable as $rowinfo => $perm)
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2004-08-31 11:33:08 +02:00
|
|
|
list($user_id,$rights) = explode('_',$rowinfo);
|
2004-08-28 15:41:23 +02:00
|
|
|
$totalacl[$user_id] += $rights;
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
2004-08-28 15:41:23 +02:00
|
|
|
foreach($totalacl as $user_id => $rights)
|
|
|
|
{
|
|
|
|
if($no_privat_grants)
|
|
|
|
{
|
|
|
|
/* Don't allow group-grants or admin to grant private */
|
2005-07-09 21:07:16 +02:00
|
|
|
$rights &= ~ EGW_ACL_PRIVATE;
|
2004-08-28 15:41:23 +02:00
|
|
|
}
|
2005-07-09 21:07:16 +02:00
|
|
|
//echo "adding acl-rights $rights for $user_id=".$GLOBALS['egw']->accounts->id2name($user_id)." and $acl_app<br>\n";
|
|
|
|
$this->acl->add($GLOBALS['egw_info']['flags']['currentapp'],$user_id,$rights);
|
2004-08-28 15:41:23 +02:00
|
|
|
}
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
2004-08-31 11:33:08 +02:00
|
|
|
$this->acl->save_repository();
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
2005-11-08 12:40:35 +01:00
|
|
|
if ($_POST['save'] || $_POST['cancel'])
|
|
|
|
{
|
|
|
|
$GLOBALS['egw']->redirect_link($referer);
|
|
|
|
}
|
2005-07-09 21:07:16 +02:00
|
|
|
$GLOBALS['egw_info']['flags']['app_header'] = lang('%1 - Preferences',$GLOBALS['egw_info']['apps'][$acl_app]['title']).' - '.lang('acl').': '.$owner_name;
|
2005-10-14 16:31:35 +02:00
|
|
|
$GLOBALS['egw']->common->egw_header();
|
2003-08-28 16:31:11 +02:00
|
|
|
echo parse_navbar();
|
2001-12-28 01:59:30 +01:00
|
|
|
|
2005-10-14 16:31:35 +02:00
|
|
|
$this->template =& CreateObject('phpgwapi.Template',$GLOBALS['egw']->common->get_tpl_dir($acl_app));
|
2001-12-28 01:59:30 +01:00
|
|
|
$templates = Array (
|
2005-11-08 12:40:35 +01:00
|
|
|
'preferences' => '../../../preferences/templates/default/acl.tpl',
|
2001-12-28 01:59:30 +01:00
|
|
|
'row_colspan' => 'preference_colspan.tpl',
|
|
|
|
'acl_row' => 'preference_acl_row.tpl'
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->template->set_file($templates);
|
2006-12-06 15:53:03 +01:00
|
|
|
$this->template->set_block('preferences','list','list'); // refers to list area in acl.tpl (which is named as preferences)
|
|
|
|
$this->template->set_block('list','letter_search','letter_search_cells'); // refers to the area letter_search (nested within area list)
|
2001-12-28 01:59:30 +01:00
|
|
|
if ($submit)
|
|
|
|
{
|
|
|
|
$this->template->set_var('errors',lang('ACL grants have been updated'));
|
|
|
|
}
|
|
|
|
|
2004-08-28 15:41:23 +02:00
|
|
|
$common_hidden_vars = array(
|
|
|
|
'start' => $start,
|
|
|
|
'query' => $query,
|
|
|
|
'owner' => $owner,
|
|
|
|
'acl_app' => $acl_app,
|
2005-11-08 12:40:35 +01:00
|
|
|
'referer' => $referer,
|
2006-12-06 15:53:03 +01:00
|
|
|
'search_type' => $search_type, // KL 20061204 added to have a search type available
|
2004-08-28 15:41:23 +02:00
|
|
|
);
|
2001-12-28 01:59:30 +01:00
|
|
|
$var = Array(
|
|
|
|
'errors' => '',
|
2003-04-20 22:47:50 +02:00
|
|
|
'title' => '<br>',
|
2005-07-09 21:07:16 +02:00
|
|
|
'action_url' => $GLOBALS['egw']->link('/index.php','menuaction=preferences.uiaclprefs.index&acl_app=' . $acl_app),
|
2005-11-08 12:40:35 +01:00
|
|
|
'lang_save' => lang('Save'),
|
|
|
|
'lang_apply' => lang('Apply'),
|
|
|
|
'lang_cancel' => lang('Cancel'),
|
2008-03-25 15:44:49 +01:00
|
|
|
'common_hidden_vars_form' => html::input_hidden($common_hidden_vars)
|
2001-12-28 01:59:30 +01:00
|
|
|
);
|
|
|
|
$this->template->set_var($var);
|
|
|
|
|
2003-08-28 16:31:11 +02:00
|
|
|
$vars = $this->template->get_undefined('row_colspan');
|
2004-08-28 15:41:23 +02:00
|
|
|
foreach($vars as $var)
|
2003-08-28 16:31:11 +02:00
|
|
|
{
|
2007-04-29 17:07:11 +02:00
|
|
|
if(strpos($var,'lang_') !== false)
|
2003-08-28 16:31:11 +02:00
|
|
|
{
|
2003-12-20 19:54:18 +01:00
|
|
|
$value = str_replace('lang_','',$var);
|
|
|
|
$value = str_replace('_',' ',$value);
|
2001-12-28 01:59:30 +01:00
|
|
|
|
2003-08-28 16:31:11 +02:00
|
|
|
$this->template->set_var($var,lang($value));
|
|
|
|
}
|
|
|
|
}
|
2001-12-28 01:59:30 +01:00
|
|
|
|
2005-07-09 21:07:16 +02:00
|
|
|
$accounts = $GLOBALS['egw']->accounts->search(array(
|
2004-08-28 15:41:23 +02:00
|
|
|
'type' => 'both',
|
|
|
|
'start' => $start,
|
|
|
|
'query' => $query,
|
2006-12-06 15:53:03 +01:00
|
|
|
'query_type' => $search_type, //KL 20061204 added to have query_type available
|
2004-08-28 15:41:23 +02:00
|
|
|
'order' => 'account_type,account_lid',
|
|
|
|
'sort' => 'ASC',
|
|
|
|
));
|
2005-07-09 21:07:16 +02:00
|
|
|
$totalentries = $GLOBALS['egw']->accounts->total;
|
2006-12-06 15:53:03 +01:00
|
|
|
$shownentries = count($accounts);
|
2005-07-09 21:07:16 +02:00
|
|
|
|
2010-04-20 09:08:56 +02:00
|
|
|
if ($not_enum_group_acls === true)
|
|
|
|
{
|
|
|
|
$memberships = array();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$memberships = $GLOBALS['egw']->accounts->memberships($owner,true);
|
|
|
|
if (is_array($not_enum_group_acls)) $memberships = array_diff($memberships,$not_enum_group_acls);
|
|
|
|
}
|
|
|
|
$header_type = '';
|
|
|
|
$processed = Array();
|
|
|
|
foreach((array)$accounts as $uid => $data)
|
|
|
|
{
|
|
|
|
if ($data['account_type'] == 'u' && $data['account_id'] == $owner)
|
2006-12-06 15:53:03 +01:00
|
|
|
{
|
2004-09-02 18:00:49 +02:00
|
|
|
continue; /* no need to grant to self if user */
|
2006-12-06 15:53:03 +01:00
|
|
|
}
|
2004-08-28 15:41:23 +02:00
|
|
|
if ($data['account_type'] != $header_type)
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2004-08-28 15:41:23 +02:00
|
|
|
$this->template->set_var('string',$data['account_type'] == 'g' ? lang('Groups') : lang('Users'));
|
|
|
|
$this->template->parse('row','row_colspan',True);
|
|
|
|
$header_type = $data['account_type'];
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
2005-07-09 21:07:16 +02:00
|
|
|
$tr_class = $GLOBALS['egw']->nextmatchs->alternate_row_color($tr_color,true);
|
2001-12-28 01:59:30 +01:00
|
|
|
|
2004-08-28 15:41:23 +02:00
|
|
|
if ($data['account_type'] == 'g')
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2005-05-21 20:25:08 +02:00
|
|
|
$this->display_row($tr_class,'g_',$data['account_id'],$data['account_lid'],$no_privat_grants,$memberships);
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
2004-08-28 15:41:23 +02:00
|
|
|
else
|
|
|
|
{
|
2005-07-09 21:07:16 +02:00
|
|
|
$this->display_row($tr_class,'u_',$data['account_id'],$GLOBALS['egw']->common->display_fullname($data['account_lid'],$data['account_firstname'],$data['account_lastname']),$no_privat_grants,$memberships);
|
2004-08-28 15:41:23 +02:00
|
|
|
}
|
2007-02-14 13:47:00 +01:00
|
|
|
$processed[] = $data['account_id'];
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
|
|
|
|
2004-08-28 15:41:23 +02:00
|
|
|
$extra_parms = array(
|
|
|
|
'menuaction' => 'preferences.uiaclprefs.index',
|
|
|
|
'acl_app' => $acl_app,
|
|
|
|
'owner' => $owner,
|
2005-11-08 12:40:35 +01:00
|
|
|
'referer' => $referer,
|
2006-12-06 15:53:03 +01:00
|
|
|
'search_type' => is_array($query_types) ? $search_type : '',
|
2008-03-25 15:44:49 +01:00
|
|
|
'search_value' => isset($query) && $query ? html::htmlspecialchars($query) : '',
|
|
|
|
'query' => isset($query) && $query ? html::htmlspecialchars($query) : '',
|
2004-08-28 15:41:23 +02:00
|
|
|
);
|
2001-12-28 01:59:30 +01:00
|
|
|
$var = Array(
|
2005-07-09 21:07:16 +02:00
|
|
|
'nml' => $GLOBALS['egw']->nextmatchs->left('/index.php',$start,$totalentries,$extra_parms),
|
|
|
|
'nmr' => $GLOBALS['egw']->nextmatchs->right('/index.php',$start,$totalentries,$extra_parms),
|
2006-12-06 15:53:03 +01:00
|
|
|
'lang_groups' => lang('showing %1 - %2 of %3',$start+1,$start+$shownentries,$totalentries),
|
2008-03-25 15:44:49 +01:00
|
|
|
'search_type' => is_array($query_types) ? html::select('search_type',$search_type,$query_types) : '',
|
|
|
|
'search_value' => isset($query) && $query ? html::htmlspecialchars($query) : '',
|
2001-12-28 01:59:30 +01:00
|
|
|
'search' => lang('search'),
|
|
|
|
'processed' => urlencode(serialize($processed))
|
|
|
|
);
|
|
|
|
|
2006-12-06 15:53:03 +01:00
|
|
|
$letters = lang('alphabet');
|
|
|
|
$letters = explode(',',substr($letters,-1) != '*' ? $letters : 'a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z');
|
|
|
|
$extra_parms['search_type'] = 'start';
|
|
|
|
foreach($letters as $letter)
|
|
|
|
{
|
|
|
|
$extra_parms['query'] = $letter;
|
|
|
|
$this->template->set_var(array(
|
|
|
|
'letter' => $letter,
|
|
|
|
'link' => $GLOBALS['egw']->link('/index.php',$extra_parms),
|
|
|
|
'class' => $query == $letter && $search_type == 'start' ? 'letter_box_active' : 'letter_box',
|
|
|
|
));
|
|
|
|
$this->template->fp('letter_search_cells','letter_search',True);
|
|
|
|
}
|
|
|
|
unset($extra_parms['query']);
|
|
|
|
unset($extra_parms['search_value']);
|
|
|
|
unset($extra_parms['search_type']);
|
|
|
|
$this->template->set_var(array(
|
|
|
|
'letter' => lang('all'),
|
|
|
|
'link' => $GLOBALS['egw']->link('/index.php',$extra_parms),
|
|
|
|
'class' => $search_type != 'start' || !in_array($query,$letters) ? 'letter_box_active' : 'letter_box',
|
|
|
|
));
|
|
|
|
$this->template->fp('letter_search_cells','letter_search',True);
|
|
|
|
|
2001-12-28 01:59:30 +01:00
|
|
|
$this->template->set_var($var);
|
|
|
|
|
|
|
|
$this->template->pfp('out','preferences');
|
|
|
|
}
|
|
|
|
|
2004-08-28 15:41:23 +02:00
|
|
|
function check_acl($label,$id,$acl,$rights,$right,$disabled=False)
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2005-12-15 00:26:26 +01:00
|
|
|
//echo "<p>check_acl($label,$id,$acl,$rights,$right,$disabled)</p>\n";
|
2005-07-09 21:07:16 +02:00
|
|
|
$this->template->set_var($acl,$label.$GLOBALS['egw_info']['flags']['currentapp'].'['.$id.'_'.$right.']');
|
2004-08-28 15:41:23 +02:00
|
|
|
$rights_set = ($rights & $right) ? ' checked="1"' : '';
|
|
|
|
if ($disabled)
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
|
|
|
// This is so you can't select it in the GUI
|
2004-08-28 15:41:23 +02:00
|
|
|
$rights_set .= ' disabled="1"';
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
|
|
|
$this->template->set_var($acl.'_selected',$rights_set);
|
|
|
|
}
|
|
|
|
|
2005-05-21 20:25:08 +02:00
|
|
|
function display_row($tr_class,$label,$id,$name,$no_privat_grants,$memberships)
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2005-12-15 00:26:26 +01:00
|
|
|
//echo "<p>display_row(,$label,$id,$name,$no_privat_grants,".print_r($memberships,true).")</p>\n";
|
2005-05-21 20:25:08 +02:00
|
|
|
$this->template->set_var('row_class',$tr_class);
|
2001-12-28 01:59:30 +01:00
|
|
|
$this->template->set_var('user',$name);
|
2005-07-09 21:07:16 +02:00
|
|
|
$rights = $this->acl->get_rights($id,$GLOBALS['egw_info']['flags']['currentapp']);
|
|
|
|
$is_group = $GLOBALS['egw']->accounts->get_type($id) == 'g';
|
2004-08-31 11:33:08 +02:00
|
|
|
|
|
|
|
foreach(array(
|
2005-07-09 21:07:16 +02:00
|
|
|
EGW_ACL_READ => 'read',
|
2005-12-15 00:26:26 +01:00
|
|
|
EGW_ACL_ADD => 'add',
|
2005-07-09 21:07:16 +02:00
|
|
|
EGW_ACL_EDIT => 'edit',
|
2005-12-15 00:26:26 +01:00
|
|
|
EGW_ACL_DELETE => 'delete',
|
|
|
|
EGW_ACL_PRIVATE => 'private',
|
2005-07-09 21:07:16 +02:00
|
|
|
EGW_ACL_CUSTOM_1 => 'custom_1',
|
|
|
|
EGW_ACL_CUSTOM_2 => 'custom_2',
|
|
|
|
EGW_ACL_CUSTOM_3 => 'custom_3',
|
2004-08-31 11:33:08 +02:00
|
|
|
) as $right => $name)
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2004-08-31 11:33:08 +02:00
|
|
|
$is_group_set = False;
|
|
|
|
if ($is_group)
|
2001-12-28 01:59:30 +01:00
|
|
|
{
|
2005-07-09 21:07:16 +02:00
|
|
|
$grantors = $this->acl->get_ids_for_location($id,$right,$GLOBALS['egw_info']['flags']['currentapp']);
|
2004-08-31 11:33:08 +02:00
|
|
|
if (is_array($grantors))
|
2004-08-28 15:41:23 +02:00
|
|
|
{
|
2004-08-31 11:33:08 +02:00
|
|
|
foreach($grantors as $grantor)
|
|
|
|
{
|
2005-07-09 21:07:16 +02:00
|
|
|
//echo $GLOBALS['egw']->accounts->id2name($id)."=$id: $name-grant from ".$GLOBALS['egw']->accounts->id2name($grantor)."=$grantor<br>\n";
|
2004-08-31 11:33:08 +02:00
|
|
|
// check if the grant comes from a group, the owner is a member off, in that case he is NOT allowed to remove it
|
|
|
|
if(in_array($grantor,$memberships))
|
|
|
|
{
|
|
|
|
//echo "==> member of ==> set by group<br>";
|
|
|
|
$is_group_set = True;
|
|
|
|
}
|
|
|
|
}
|
2004-08-28 15:41:23 +02:00
|
|
|
}
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
2005-07-09 21:07:16 +02:00
|
|
|
$this->check_acl($label,$id,$name,$rights,$right,$is_group_set || $no_privat_grants && $right == EGW_ACL_PRIVATE);
|
2001-12-28 01:59:30 +01:00
|
|
|
}
|
|
|
|
$this->template->parse('row','acl_row',True);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|