X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/timetracker.git/blobdiff_plain/ce2bb98acb1f5e2a846f95b798a4af409c842ebb..3d6b6fb758fd7e0befbdd497013d33264b9111e5:/WEB-INF/lib/ttUser.class.php diff --git a/WEB-INF/lib/ttUser.class.php b/WEB-INF/lib/ttUser.class.php index ae197c69..2560417f 100644 --- a/WEB-INF/lib/ttUser.class.php +++ b/WEB-INF/lib/ttUser.class.php @@ -54,11 +54,12 @@ class ttUser { var $uncompleted_indicators = 0; // Uncompleted time entry indicators (show nowhere or on users page). var $bcc_email = null; // Bcc email. var $allow_ip = null; // Specification from where user is allowed access. + var $password_complexity = null; // Password complexity example. var $currency = null; // Currency. var $plugins = null; // Comma-separated list of enabled plugins. var $config = null; // Comma-separated list of miscellaneous config options. var $group = null; // Group name. - var $custom_logo = 0; // Whether to use a custom logo for team. + var $custom_logo = 0; // Whether to use a custom logo for group. var $lock_spec = null; // Cron specification for record locking. var $workday_minutes = 480; // Number of work minutes in a regular day. var $rights = array(); // An array of user rights such as 'track_own_time', etc. @@ -76,7 +77,7 @@ class ttUser { $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, g.tracking_mode, g.project_required, g.task_required, g.record_type, - g.bcc_email, g.allow_ip, g.plugins, g.config, g.lock_spec, g.workday_minutes, g.custom_logo + 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 "; if ($id) $sql .= "u.id = $id"; @@ -113,6 +114,7 @@ class ttUser { $this->record_type = $val['record_type']; $this->bcc_email = $val['bcc_email']; $this->allow_ip = $val['allow_ip']; + $this->password_complexity = $val['password_complexity']; $this->group = $val['group_name']; $this->currency = $val['currency']; $this->plugins = $val['plugins']; @@ -148,12 +150,7 @@ class ttUser { return in_array($do_something, $this->rights); } - // isAdmin - determines whether current user is admin. - function isAdmin() { - return $this->can('administer_site'); - } - - // isManager - determines whether current user is team manager. + // isManager - determines whether current user is group manager. // This is a legacy function that we are getting rid of by replacing with rights check. function isManager() { return $this->can('export_data'); // By default this is assigned to managers but not co-managers. @@ -161,7 +158,7 @@ class ttUser { // to this function and then remove it. } - // isCoManager - determines whether current user is team comanager. + // isCoManager - determines whether current user is group comanager. // This is a legacy function that we are getting rid of by replacing with rights check. function isCoManager() { return ($this->can('manage_users') && !$this->can('export_data')); @@ -416,6 +413,9 @@ class ttUser { // updateGroup updates group information with new data. function updateGroup($fields) { + if (!($this->can('manage_basic_settings') || + $this->can('manage_advanced_settings') || + $this->can('manage_features'))) return false; $mdb2 = getConnection(); @@ -450,4 +450,32 @@ class ttUser { return true; } + + // enablePlugin either enables or disables a specific plugin for group. + function enablePlugin($plugin, $enable = true) + { + if (!$this->can('manage_advanced_settings')) + return false; // Note: enablePlugin is currently only used on week_view.php. + // So, it's not really a plugin we are enabling, but rather week view display options. + // Therefore, a check for manage_advanced_settings, not manage_features. + + $plugin_array = explode(',', $this->plugins); + if ($enable && !in_array($plugin, $plugin_array)) + $plugin_array[] = $plugin; // Add plugin to array. + + if (!$enable && in_array($plugin, $plugin_array)) { + $key = array_search($plugin, $plugin_array); + if ($key !== false) + unset($plugin_array[$key]); // Remove plugin from array. + } + + $plugins = implode(',', $plugin_array); + if ($plugins != $this->plugins) { + if (!$this->updateGroup(array('plugins' => $plugins))) + return false; + $this->plugins = $plugins; + } + + return true; + } }