It is okay to call daemonControl with function==None for command == stop. All others give a warning. Fixes monitors on other servers not stopping when set to None.

pull/3322/head
Isaac Connor 2021-06-12 12:21:44 -04:00
parent 3141ec32fe
commit bb67c27d3b
1 changed files with 7 additions and 7 deletions

View File

@ -143,28 +143,28 @@ class Monitor extends AppModel {
);
public function daemonControl($monitor, $command, $daemon=null) {
if ( $monitor['Function'] == 'None' ) {
ZM\Debug('Calling daemonControl when Function == None');
if ($monitor['Function'] == 'None' and $command != 'stop') {
ZM\Warning("Calling daemonControl with command $command when Function == None");
return;
}
if ( defined('ZM_SERVER_ID') and ($monitor['ServerId']!=ZM_SERVER_ID) ) {
if (defined('ZM_SERVER_ID') and ($monitor['ServerId']!=ZM_SERVER_ID)) {
ZM\Error('Calling daemonControl for Monitor assigned to different server. Our server id '.ZM_SERVER_ID.' != '.$monitor['ServerId']);
return;
}
$daemons = array();
if ( ! $daemon ) {
if (!$daemon) {
array_push($daemons, 'zmc');
} else {
array_push($daemons, $daemon);
}
$status_text = '';
foreach ( $daemons as $daemon ) {
foreach ($daemons as $daemon) {
$args = '';
if ( $daemon == 'zmc' and $monitor['Type'] == 'Local' ) {
if ($daemon == 'zmc' and $monitor['Type'] == 'Local') {
$args = '-d ' . $monitor['Device'];
} else if ( $daemon == 'zmcontrol.pl' ) {
} else if ($daemon == 'zmcontrol.pl') {
$args = '--id '.$monitor['Id'];
} else {
$args = '-m ' . $monitor['Id'];