diff options
author | Simon Rettberg | 2019-01-21 14:49:54 +0100 |
---|---|---|
committer | Simon Rettberg | 2019-01-21 14:49:54 +0100 |
commit | 54a516de8a49bdcdd2b95ecbfe2a365a860adaf4 (patch) | |
tree | 414f1991ec693fb0c62c4fd080fbd8143cc48da1 /modules-available/statistics/api.inc.php | |
parent | [statistics] Improve ID44 filter matching (diff) | |
download | slx-admin-54a516de8a49bdcdd2b95ecbfe2a365a860adaf4.tar.gz slx-admin-54a516de8a49bdcdd2b95ecbfe2a365a860adaf4.tar.xz slx-admin-54a516de8a49bdcdd2b95ecbfe2a365a860adaf4.zip |
[statistics] Log if client seems to have crashed
Log when we reset a client's state in the cron job, as well as if we
receive a poweron event even though the state in the DB is still IDLE or
OCCUPIED.
Diffstat (limited to 'modules-available/statistics/api.inc.php')
-rw-r--r-- | modules-available/statistics/api.inc.php | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/modules-available/statistics/api.inc.php b/modules-available/statistics/api.inc.php index 8f5e9fd0..674cc48d 100644 --- a/modules-available/statistics/api.inc.php +++ b/modules-available/statistics/api.inc.php @@ -161,6 +161,11 @@ if ($type{0} === '~') { // Check for suspicious hardware changes if ($old !== false) { checkHardwareChange($old, $new); + + // Log potential crash + if ($old['state'] === 'IDLE' || $old['state'] === 'OCCUPIED') { + writeClientLog('machine-mismatch-poweron', 'Client sent poweron event, but previous known state is ' . $old['state']); + } } // Write statistics data @@ -403,6 +408,18 @@ function writeStatisticLog($type, $username, $data) )); } +function writeClientLog($type, $description) +{ + global $ip, $uuid; + Database::exec('INSERT INTO clientlog (dateline, logtypeid, clientip, machineuuid, description, extra) VALUES (UNIX_TIMESTAMP(), :type, :client, :uuid, :description, :longdesc)', array( + 'type' => $type, + 'client' => $ip, + 'description' => $description, + 'longdesc' => '', + 'uuid' => $uuid, + )); +} + // For backwards compat, we require the . prefix if ($type{0} === '.') { |