<?php
function getSounds() {
$file_list = [];
$dir = scandir('./audio');
foreach ($dir as $file) {
$pos = strrpos($file, '.');
if ($pos === false || mb_strtolower(substr($file, $pos + 1)) !== 'mp3') {
continue;
}
$filename = substr($file, 0, $pos);
$file_list[$filename] = $file;
}
return $file_list;
}
function getMessageSettings() {
$defSeverities = [
TRIGGER_SEVERITY_NOT_CLASSIFIED => 1,
TRIGGER_SEVERITY_INFORMATION => 1,
TRIGGER_SEVERITY_WARNING => 1,
TRIGGER_SEVERITY_AVERAGE => 1,
TRIGGER_SEVERITY_HIGH => 1,
TRIGGER_SEVERITY_DISASTER => 1
];
$messages = [
'enabled' => 0,
'timeout' => 60,
'last.clock' => 0,
'triggers.recovery' => 1,
'triggers.severities' => null,
'sounds.mute' => 0,
'sounds.repeat' => 1,
'sounds.recovery' => 'alarm_ok.mp3',
'sounds.'.TRIGGER_SEVERITY_NOT_CLASSIFIED => 'no_sound.mp3',
'sounds.'.TRIGGER_SEVERITY_INFORMATION => 'alarm_information.mp3',
'sounds.'.TRIGGER_SEVERITY_WARNING => 'alarm_warning.mp3',
'sounds.'.TRIGGER_SEVERITY_AVERAGE => 'alarm_average.mp3',
'sounds.'.TRIGGER_SEVERITY_HIGH => 'alarm_high.mp3',
'sounds.'.TRIGGER_SEVERITY_DISASTER => 'alarm_disaster.mp3',
'show_suppressed' => 0
];
$dbProfiles = DBselect(
'SELECT p.idx,p.source,p.value_str'.
' FROM profiles p'.
' WHERE p.userid='.CWebUser::$data['userid'].
' AND '.dbConditionString('p.idx', ['web.messages'])
);
while ($profile = DBfetch($dbProfiles)) {
$messages[$profile['source']] = $profile['value_str'];
}
if ($messages['triggers.severities'] === null) {
$messages['triggers.severities'] = $defSeverities;
}
else {
$messages['triggers.severities'] = unserialize($messages['triggers.severities']);
}
return $messages;
}
function updateMessageSettings($messages) {
if (!isset($messages['enabled'])) {
$messages['enabled'] = 0;
}
if (isset($messages['triggers.severities'])) {