X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;ds=sidebyside;f=WEB-INF%2Flib%2FttUser.class.php;h=21cd19aa7bba2ad3ef4770832ceee3169696b68c;hb=b4be5795ddbcef63b4b6fffb200c3dfc3ffcb530;hp=e498cde0e822302559ec427d678d71c0287aeddc;hpb=6dbcf228dba9d1175ffd0c177f0739c58ce0f199;p=timetracker.git diff --git a/WEB-INF/lib/ttUser.class.php b/WEB-INF/lib/ttUser.class.php index e498cde0..21cd19aa 100644 --- a/WEB-INF/lib/ttUser.class.php +++ b/WEB-INF/lib/ttUser.class.php @@ -32,13 +32,16 @@ class ttUser { var $login = null; // User login. var $name = null; // User name. var $id = null; // User id. + var $org_id = null; // Organization id. var $group_id = null; // Group id. var $role_id = null; // Role id. var $role_name = null; // Role name. var $rank = null; // User role rank. var $client_id = null; // Client id for client user role. var $behalf_id = null; // User id, on behalf of whom we are working. + var $behalf_group_id = null; // Group id, on behalf of which we are working. var $behalf_name = null; // User name, on behalf of whom we are working. + var $behalf_group = null; // Group name, on behalf of which we are working. var $email = null; // User email. var $lang = null; // Language. var $decimal_mark = null; // Decimal separator. @@ -68,7 +71,7 @@ class ttUser { var $is_client = false; // Whether user is a client as determined by missing 'track_own_time' right. var $minutes_in_unit = 15; // Number of minutes in unit for Work units plugin. var $first_unit_threshold = 0;// Threshold for 1st unit for Work units plugin. - var $unit_totals_only = 0; // Totlas only option for the Work units plugin. + var $unit_totals_only = 0; // Totals only option for the Work units plugin. // Constructor. function __construct($login, $id = null) { @@ -79,8 +82,8 @@ class ttUser { $mdb2 = getConnection(); - $sql = "SELECT u.id, u.login, u.name, u.group_id, u.role_id, r.rank, r.name as role_name, r.rights, u.client_id, u.email, g.name as group_name, - g.currency, g.lang, g.decimal_mark, g.date_format, g.time_format, g.week_start, + $sql = "SELECT u.id, u.login, u.name, u.group_id, u.role_id, r.rank, r.name as role_name, r.rights, u.client_id, u.email, + g.org_id, g.name as group_name, g.currency, g.lang, g.decimal_mark, g.date_format, g.time_format, g.week_start, g.tracking_mode, g.project_required, g.task_required, g.record_type, g.bcc_email, g.allow_ip, g.password_complexity, g.plugins, g.config, g.lock_spec, g.workday_minutes, g.custom_logo FROM tt_users u LEFT JOIN tt_groups g ON (u.group_id = g.id) LEFT JOIN tt_roles r on (r.id = u.role_id) WHERE "; @@ -100,6 +103,7 @@ class ttUser { $this->login = $val['login']; $this->name = $val['name']; $this->id = $val['id']; + $this->org_id = $val['org_id']; $this->group_id = $val['group_id']; $this->role_id = $val['role_id']; $this->role_name = $val['role_name']; @@ -143,11 +147,16 @@ class ttUser { $this->unit_totals_only = $config->getDefinedValue('unit_totals_only'); } - // Set "on behalf" id and name. + // Set "on behalf" id and name (user). if (isset($_SESSION['behalf_id'])) { $this->behalf_id = $_SESSION['behalf_id']; $this->behalf_name = $_SESSION['behalf_name']; } + // Set "on behalf" id and name (group). + if (isset($_SESSION['behalf_group_id'])) { + $this->behalf_group_id = $_SESSION['behalf_group_id']; + $this->behalf_group = $_SESSION['behalf_group_name']; + } } } @@ -156,6 +165,11 @@ class ttUser { return ($this->behalf_id ? $this->behalf_id : $this->id); } + // The getActiveGroup returns group id on behalf of which the current user is operating. + function getActiveGroup() { + return ($this->behalf_group_id ? $this->behalf_group_id : $this->group_id); + } + // can - determines whether user has a right to do something. function can($do_something) { return in_array($do_something, $this->rights); @@ -349,6 +363,51 @@ class ttUser { return $user_list; } + // getGroups obtains an array consisting of: + // - A parent group (..) of a currently selected group, if available. + // - A currently selected group (.) represented by $behalf_group_id. + // - All subgroups (only immediate children) of a currently selected group. + function getGroups() { + $mdb2 = getConnection(); + + $selected_group_id = ($this->behalf_group_id ? $this->behalf_group_id : $this->group_id); + $selected_group_name = ($this->behalf_group_id ? $this->behalf_group : $this->group); + + // Start with parent group. + if ($selected_group_id != $this->org_id) { + // We are in one of the subgroups, and a parent exists. + // Get parent group info. + $sql = "select parent_id from tt_groups where org_id = $this->org_id and id = $selected_group_id"; + $res = $mdb2->query($sql); + if (!is_a($res, 'PEAR_Error')) { + $val = $res->fetchRow(); + $parent_id = $val['parent_id']; + if ($parent_id) { + // Get parent group name. + $sql = "select name from tt_groups where org_id = $this->org_id and id = $parent_id"; + $res = $mdb2->query($sql); + if (!is_a($res, 'PEAR_Error')) { + $val = $res->fetchRow(); + $groups[] = array('id'=>$parent_id,'name'=>$val['name']); + } + } + } + } + + // Add current group. + $groups[] = array('id'=>$selected_group_id,'name'=>$selected_group_name); + + // Add subgroups. + $sql = "select id, name from tt_groups where org_id = $this->org_id and parent_id = $selected_group_id"; + $res = $mdb2->query($sql); + if (!is_a($res, 'PEAR_Error')) { + while ($val = $res->fetchRow()) { + $groups[] = array('id'=>$val['id'],'name'=>$val['name']); + } + } + return $groups; + } + // getUser function is used to manage users in group and returns user details. // At the moment, the function is used for user edits and deletes. function getUser($user_id) {