X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=WEB-INF%2Flib%2FttTeamHelper.class.php;h=2aff793bcc7ae93251c8ec76912ce2e6a3645ec9;hb=3209a25c21cd59c6476d820624545963a5a4a857;hp=27f31bb32d1ee7aa82b21a9d6b77cc3eb758ce44;hpb=e80e19c6b609af8e06403a337a5cd46200ab4fc6;p=timetracker.git diff --git a/WEB-INF/lib/ttTeamHelper.class.php b/WEB-INF/lib/ttTeamHelper.class.php index 27f31bb3..2aff793b 100644 --- a/WEB-INF/lib/ttTeamHelper.class.php +++ b/WEB-INF/lib/ttTeamHelper.class.php @@ -85,7 +85,7 @@ class ttTeamHelper { 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'); + $val['role_name'] = $i18n->get('role.top_manager.label'); $user_list[] = $val; } @@ -108,6 +108,7 @@ class ttTeamHelper { global $user; $mdb2 = getConnection(); + // Obtain role id for the user we are swapping ourselves with. $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')) @@ -116,14 +117,16 @@ class ttTeamHelper { if (!$val['id'] || !$val['role_id']) return false; + $modified_part = ', modified = now(), modified_ip = '.$mdb2->quote($_SERVER['REMOTE_ADDR']).', modified_by = '.$mdb2->quote($user->id); + // Promote user. - $sql = "update tt_users set role_id = $user->role_id where id = $user_id and team_id = $user->team_id"; + $sql = "update tt_users set role_id = $user->role_id".$modified_part." 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"; + $sql = "update tt_users set role_id = $role_id".$modified_part." where id = $user->id and team_id = $user->team_id"; $affected = $mdb2->exec($sql); if (is_a($affected, 'PEAR_Error')) return false; @@ -141,7 +144,7 @@ class ttTeamHelper { 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. + $isClient = in_array('track_own_time', explode(',', $val['rights'])) ? 0 : 1; // Clients do not have track_own_time right. if ($isClient) continue; // Skip adding clients. $user_list[] = $val; @@ -688,24 +691,6 @@ class ttTeamHelper { return false; } - // The getTeams function returns an array of all active teams on the server. - static function getTeams() { - $result = array(); - $mdb2 = getConnection(); - - $sql = "select id, name, created, lang from tt_teams where status = 1 order by id desc"; - $res = $mdb2->query($sql); - $result = array(); - if (!is_a($res, 'PEAR_Error')) { - while ($val = $res->fetchRow()) { - $val['date'] = substr($val['created'], 0, 10); // Strip the time. - $result[] = $val; - } - return $result; - } - return false; - } - // The markDeleted function marks the team and everything in it as deleted. static function markDeleted($team_id) { @@ -771,6 +756,7 @@ class ttTeamHelper { // The insert function creates a new team. static function insert($fields) { + global $user; $mdb2 = getConnection(); // Start with team name and currency. @@ -853,6 +839,9 @@ class ttTeamHelper { $values .= ', '.$mdb2->quote($fields['config']); } + $columns .= ', created, created_ip, created_by'; + $values .= ', now(), '.$mdb2->quote($_SERVER['REMOTE_ADDR']).', '.$mdb2->quote($user->id); + $sql = "insert into tt_teams ($columns) values($values)"; $affected = $mdb2->exec($sql); @@ -916,8 +905,8 @@ class ttTeamHelper { // Get all team ids for teams created or modified more than 8 months ago. // $ts = date('Y-m-d', strtotime('-1 year')); - $ts = date('Y-m-d', strtotime('-8 month')); - $sql = "select id from tt_teams where timestamp < '$ts' order by id"; + $ts = $mdb2->quote(date('Y-m-d', strtotime('-8 month'))); + $sql = "select id from tt_teams where created < $ts and (modified is null or modified < $ts) order by id"; $res = $mdb2->query($sql); $count = 0; @@ -953,7 +942,7 @@ class ttTeamHelper { $count = 0; $ts = date('Y-m-d', strtotime('-2 years')); - $sql = "select count(*) as cnt from tt_log where user_id in ($user_list) and timestamp > '$ts'"; + $sql = "select count(*) as cnt from tt_log where user_id in ($user_list) and created > '$ts'"; $res = $mdb2->query($sql); if (!is_a($res, 'PEAR_Error')) { if ($val = $res->fetchRow()) { @@ -968,7 +957,7 @@ class ttTeamHelper { // We will consider a team inactive if it has 5 or less time entries made more than 1 year ago. $count_last_year = 0; $ts = date('Y-m-d', strtotime('-1 year')); - $sql = "select count(*) as cnt from tt_log where user_id in ($user_list) and timestamp > '$ts'"; + $sql = "select count(*) as cnt from tt_log where user_id in ($user_list) and created > '$ts'"; $res = $mdb2->query($sql); if (!is_a($res, 'PEAR_Error')) { if ($val = $res->fetchRow()) {