= $job_end) { $job_begin = 0; $job_end = 10; } else { $job_end = $job_begin + 10; } $sqlhis = array_slice($select_arr['all_user'],$job_begin ,10); $uuids = ''; foreach ($sqlhis as $uuid => $userstats) { $uuids .= "'".$uuid."',"; } $uuids = substr($uuids, 0, -1); if(isset($sqlhis) && $max_timestamp != NULL && $min_timestamp_week != NULL && $min_timestamp_month != NULL) { enter_logfile($cfg,6,"Update User Stats between ".$job_begin." and ".$job_end.":"); if(($userdataweekbegin = $mysqlcon->query("SELECT `uuid`,`count`,`idle` FROM `$dbname`.`user_snapshot` WHERE `timestamp`=$min_timestamp_week AND `uuid` IN ($uuids)")->fetchAll(PDO::FETCH_ASSOC|PDO::FETCH_UNIQUE)) === false) { enter_logfile($cfg,2,"calc_userstats 6:".print_r($mysqlcon->errorInfo(), true)); } if(($userdatamonthbegin = $mysqlcon->query("SELECT `uuid`,`count`,`idle` FROM `$dbname`.`user_snapshot` WHERE `timestamp`=$min_timestamp_month AND `uuid` IN ($uuids)")->fetchAll(PDO::FETCH_ASSOC|PDO::FETCH_UNIQUE)) === false) { enter_logfile($cfg,2,"calc_userstats 8:".print_r($mysqlcon->errorInfo(), true)); } if(($userdataend = $mysqlcon->query("SELECT `uuid`,`count`,`idle` FROM `$dbname`.`user_snapshot` WHERE `timestamp`=$max_timestamp AND `uuid` IN ($uuids)")->fetchAll(PDO::FETCH_ASSOC|PDO::FETCH_UNIQUE)) === false) { enter_logfile($cfg,2,"calc_userstats 7:".print_r($mysqlcon->errorInfo(), true)); } $allupdateuuid = ''; foreach ($sqlhis as $uuid => $userstats) { check_shutdown($cfg); usleep($cfg['teamspeak_query_command_delay']); try { $clientinfo = $ts3->clientInfoDb($userstats['cldbid']); if(isset($userdataend[$uuid]) && isset($userdataweekbegin[$uuid])) { $count_week = $userdataend[$uuid]['count'] - $userdataweekbegin[$uuid]['count']; $idle_week = $userdataend[$uuid]['idle'] - $userdataweekbegin[$uuid]['idle']; $active_week = $count_week - $idle_week; } else { $count_week = 0; $idle_week = 0; $active_week = 0; } if(isset($userdataend[$uuid]) && isset($userdatamonthbegin[$uuid])) { $count_month = $userdataend[$uuid]['count'] - $userdatamonthbegin[$uuid]['count']; $idle_month = $userdataend[$uuid]['idle'] - $userdatamonthbegin[$uuid]['idle']; $active_month = $count_month - $idle_month; } else { $count_month = 0; $idle_month = 0; $active_month = 0; } $clientdesc = $mysqlcon->quote($clientinfo['client_description'], ENT_QUOTES);; $allupdateuuid .= "('" . $uuid . "','" .$userstats['rank'] . "','" . $count_week . "','" . $count_month . "','" . $idle_week . "','" . $idle_month . "','" . $active_week . "','" . $active_month . "','" . $clientinfo['client_totalconnections'] . "','" . $clientinfo['client_base64HashClientUID'] . "','" . $clientinfo['client_total_bytes_uploaded'] . "','" . $clientinfo['client_total_bytes_downloaded'] . "'," . $clientdesc . "),"; } catch (Exception $e) { enter_logfile($cfg,6,$e->getCode() . ': ' . $e->getMessage()."; Client (uuid: ".$uuid." cldbid: ".$userstats['cldbid'].") was missing in TS database, perhaps its already deleted. Run !clean to correct this."); } } unset($sqlhis, $userdataweekbegin, $userdataend, $userdatamonthbegin); if ($allupdateuuid != '') { $allupdateuuid = substr($allupdateuuid, 0, -1); $sqlexec .= "UPDATE `$dbname`.`job_check` SET `timestamp`=$job_end WHERE `job_name`='calc_user_limit'; INSERT INTO `$dbname`.`stats_user` (`uuid`,`rank`,`count_week`,`count_month`,`idle_week`,`idle_month`,`active_week`,`active_month`,`total_connections`,`base64hash`,`client_total_up`,`client_total_down`,`client_description`) VALUES $allupdateuuid ON DUPLICATE KEY UPDATE `rank`=VALUES(`rank`),`count_week`=VALUES(`count_week`),`count_month`=VALUES(`count_month`),`idle_week`=VALUES(`idle_week`),`idle_month`=VALUES(`idle_month`),`active_week`=VALUES(`active_week`),`active_month`=VALUES(`active_month`),`total_connections`=VALUES(`total_connections`),`base64hash`=VALUES(`base64hash`),`client_total_up`=VALUES(`client_total_up`),`client_total_down`=VALUES(`client_total_down`),`client_description`=VALUES(`client_description`); "; unset($allupdateuuid); } else { $sqlexec .= "UPDATE `$dbname`.`job_check` SET `timestamp`=$job_end WHERE `job_name`='calc_user_limit'; "; } } return($sqlexec); } ?>