// The getActiveUsers obtains all active users in a given team.
static function getActiveUsers($options = null) {
global $user;
+ global $i18n;
$mdb2 = getConnection();
if (isset($options['getAllFields']))
- $sql = "select * from tt_users where team_id = $user->team_id and status = 1 order by upper(name)";
+ $sql = "select u.*, r.name as role_name, r.rank from tt_users u left join tt_roles r on (u.role_id = r.id) where u.team_id = $user->team_id and u.status = 1 order by upper(u.name)";
else
$sql = "select id, name from tt_users where team_id = $user->team_id and status = 1 order by upper(name)";
$res = $mdb2->query($sql);
if (is_a($res, 'PEAR_Error'))
return false;
while ($val = $res->fetchRow()) {
+ // Localize top manager role name, as it is not localized in db.
+ if ($val['rank'] == 512)
+ $val['role_name'] = $i18n->getKey('role.top_manager.label');
$user_list[] = $val;
}
$mdb2 = getConnection();
if ($all_fields)
- $sql = "select * from tt_users where team_id = $team_id and status = 0 order by upper(name)";
+ $sql = "select u.*, r.name as role_name from tt_users u left join tt_roles r on (u.role_id = r.id) where u.team_id = $team_id and u.status = 0 order by upper(u.name)";
else
$sql = "select id, name from tt_users where team_id = $team_id and status = 0 order by upper(name)";
$res = $mdb2->query($sql);
// The getAllUsers obtains all users in a given team.
static function getAllUsers($team_id, $all_fields = false) {
$mdb2 = getConnection();
-
if ($all_fields)
$sql = "select * from tt_users where team_id = $team_id order by upper(name)";
else
return false;
}
+ // getActiveRolesForUser - returns an array of relevant active roles for user with rank less than self.
+ // "Relevant" means that client roles are filtered out if Client plugin is disabled.
+ static function getActiveRolesForUser()
+ {
+ global $user;
+ $result = array();
+ $mdb2 = getConnection();
+
+ $sql = "select id, name, description, rank, rights from tt_roles where team_id = $user->team_id and rank < $user->rank and status = 1 order by rank";
+ $res = $mdb2->query($sql);
+ $result = array();
+ if (!is_a($res, 'PEAR_Error')) {
+ while ($val = $res->fetchRow()) {
+ $val['is_client'] = in_array('track_own_time', explode(',', $val['rights'])) ? 0 : 1; // Clients do not have data entry right.
+ if ($val['is_client'] && !$user->isPluginEnabled('cl'))
+ continue; // Skip adding a client role.
+ $result[] = $val;
+ }
+ }
+ return $result;
+ }
+
// getActiveRoles - returns an array of active roles for team.
static function getActiveRoles($team_id)
{
$result = array();
$mdb2 = getConnection();
- $sql = "select id, name, rank, description from tt_roles where team_id = $team_id and status = 1 order by rank";
+ $sql = "select id, name, description, rank, rights from tt_roles where team_id = $team_id and status = 1 order by rank";
$res = $mdb2->query($sql);
$result = array();
if (!is_a($res, 'PEAR_Error')) {
while ($val = $res->fetchRow()) {
+ $val['is_client'] = in_array('track_own_time', explode(',', $val['rights'])) ? 0 : 1; // Clients do not have data entry right.
$result[] = $val;
}
}
return $result;
}
- // getAllRoles - obtains all roles defined for team.
- static function getAllRoles($team_id) {
+ // getInactiveRolesForUser - returns an array of relevant active roles for user with rank less than self.
+ // "Relevant" means that client roles are filtered out if Client plugin is disabled.
+ static function getInactiveRolesForUser()
+ {
+ global $user;
+ $result = array();
$mdb2 = getConnection();
- $result = array();
- $sql = "select * from tt_roles where team_id = $team_id";
+ $sql = "select id, name, description, rank, rights from tt_roles where team_id = $user->team_id and rank < $user->rank and status = 0 order by rank";
$res = $mdb2->query($sql);
$result = array();
if (!is_a($res, 'PEAR_Error')) {
while ($val = $res->fetchRow()) {
+ $val['is_client'] = in_array('track_own_time', explode(',', $val['rights'])) ? 0 : 1; // Clients do not have data entry right.
+ if ($val['is_client'] && !$user->isPluginEnabled('cl'))
+ continue; // Skip adding a client role.
$result[] = $val;
}
- return $result;
}
- return false;
+ return $result;
}
// The getActiveClients returns an array of active clients for team.
$result = array();
$mdb2 = getConnection();
- if (ROLE_CLIENT == $user->role && $user->client_id)
+ if ($user->isClient())
$client_part = " and i.client_id = $user->client_id";
$sql = "select i.id, i.name, i.date, i.client_id, i.status, c.name as client_name from tt_invoices i
$mdb2 = getConnection();
+ // Mark roles deleted.
+ $sql = "update tt_roles set status = NULL where team_id = $team_id";
+ $affected = $mdb2->exec($sql);
+ if (is_a($affected, 'PEAR_Error')) return false;
+
// Mark projects deleted.
$sql = "update tt_projects set status = NULL where team_id = $team_id";
$affected = $mdb2->exec($sql);
$result = array();
$mdb2 = getConnection();
- $role_manager = ROLE_MANAGER;
$sql = "select t.name as team_name, u.id as manager_id, u.name as manager_name, u.login as manager_login, u.email as manager_email
from tt_teams t
- inner join tt_users u on (u.team_id = t.id and u.role = $role_manager)
+ inner join tt_users u on (u.team_id = t.id)
+ inner join tt_roles r on (r.id = u.role_id and r.rank = 512)
where t.id = $team_id";
$res = $mdb2->query($sql);
static function enablePlugin($plugin, $enable = true)
{
global $user;
- if (!$user->canManageTeam())
+ if (!$user->can('manage_features'))
return false;
$plugin_array = explode(',', $user->plugins);