X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=WEB-INF%2Flib%2FttTeamHelper.class.php;h=74ef55452d440da338ac25cf34f81eae68c388a3;hb=2ccee198591bc2ad5d80b5e1076246449d9232c1;hp=bbca70e841d495df671a4c1c05a441703067eed4;hpb=717d0c75c9e3ddb161c3d3d8583e2b5761b1b634;p=timetracker.git diff --git a/WEB-INF/lib/ttTeamHelper.class.php b/WEB-INF/lib/ttTeamHelper.class.php index bbca70e8..74ef5545 100644 --- a/WEB-INF/lib/ttTeamHelper.class.php +++ b/WEB-INF/lib/ttTeamHelper.class.php @@ -103,23 +103,68 @@ class ttTeamHelper { return $user_list; } - // The getUsers obtains all active and inactive (but not deleted) users in a given team. - static function getUsers() { + // The swapRolesWith swaps existing user role with that of another user. + static function swapRolesWith($user_id) { global $user; $mdb2 = getConnection(); - $sql = "select id, name from tt_users where team_id = $user->team_id and (status = 1 or status = 0) order by upper(name)"; + $sql = "select u.id, u.role_id from tt_users u left join tt_roles r on (u.role_id = r.id) where u.id = $user_id and u.team_id = $user->team_id and u.status = 1 and r.rank < $user->rank"; + $res = $mdb2->query($sql); + if (is_a($res, 'PEAR_Error')) + return false; + $val = $res->fetchRow(); + if (!$val['id'] || !$val['role_id']) + return false; + + // Promote user. + $sql = "update tt_users set role_id = $user->role_id where id = $user_id and team_id = $user->team_id"; + $affected = $mdb2->exec($sql); + if (is_a($affected, 'PEAR_Error')) return false; + + // Demote self. + $role_id = $val['role_id']; + $sql = "update tt_users set role_id = $role_id where id = $user->id and team_id = $user->team_id"; + $affected = $mdb2->exec($sql); + if (is_a($affected, 'PEAR_Error')) return false; + + return true; + } + + // The getUsersForSwap obtains all users a current user can swap roles with. + static function getUsersForSwap() { + global $user; + $mdb2 = getConnection(); + + $sql = "select u.id, u.name, r.rank, r.rights 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 and r.rank < $user->rank order by upper(u.name)"; $res = $mdb2->query($sql); $user_list = array(); if (is_a($res, 'PEAR_Error')) return false; while ($val = $res->fetchRow()) { + $isClient = in_array('track_own_time', explode(',', $val['rights'])) ? 0 : 1; // Clients do not have data entry right. + if ($isClient) + continue; // Skip adding clients. $user_list[] = $val; } return $user_list; } + // The getUsers obtains all active and inactive (but not deleted) users in a given team. + static function getUsers() { + global $user; + $mdb2 = getConnection(); + $sql = "select id, name from tt_users where team_id = $user->team_id and (status = 1 or status = 0) order by upper(name)"; + $res = $mdb2->query($sql); + $user_list = array(); + if (is_a($res, 'PEAR_Error')) + return false; + while ($val = $res->fetchRow()) { + $user_list[] = $val; + } + return $user_list; + } + // The getInactiveUsers obtains all inactive users in a given team. static function getInactiveUsers($team_id, $all_fields = false) { $mdb2 = getConnection(); @@ -139,6 +184,24 @@ class ttTeamHelper { return false; } + // 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 + $sql = "select id, name from tt_users where team_id = $team_id order by upper(name)"; + $res = $mdb2->query($sql); + $result = array(); + if (!is_a($res, 'PEAR_Error')) { + while ($val = $res->fetchRow()) { + $result[] = $val; + } + return $result; + } + return false; + } + // getActiveProjects - returns an array of active projects for team. static function getActiveProjects($team_id) { @@ -657,6 +720,11 @@ class ttTeamHelper { $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);