2020-09-01 06:30:05 +08:00
|
|
|
|
|
|
|
function MonitorStream(monitorData) {
|
|
|
|
this.id = monitorData.id;
|
|
|
|
this.connKey = monitorData.connKey;
|
|
|
|
this.url = monitorData.url;
|
|
|
|
this.width = monitorData.width;
|
|
|
|
this.height = monitorData.height;
|
|
|
|
this.status = null;
|
|
|
|
this.alarmState = STATE_IDLE;
|
|
|
|
this.lastAlarmState = STATE_IDLE;
|
2021-01-07 05:57:30 +08:00
|
|
|
this.streamCmdParms = {
|
2021-01-07 04:19:25 +08:00
|
|
|
view: 'request',
|
|
|
|
request: 'stream',
|
|
|
|
connkey: this.connKey
|
|
|
|
};
|
2020-09-01 06:30:05 +08:00
|
|
|
if ( auth_hash ) {
|
2021-01-07 04:19:25 +08:00
|
|
|
this.streamCmdParms.auth = auth_hash;
|
2020-09-01 06:30:05 +08:00
|
|
|
} else if ( auth_relay ) {
|
2021-01-07 04:19:25 +08:00
|
|
|
this.streamCmdParms.auth_relay = '';
|
2020-09-01 06:30:05 +08:00
|
|
|
}
|
|
|
|
this.type = monitorData.type;
|
|
|
|
this.refresh = monitorData.refresh;
|
|
|
|
this.start = function(delay) {
|
2020-09-03 02:37:48 +08:00
|
|
|
// Step 1 make sure we are streaming instead of a static image
|
|
|
|
var stream = $j('#liveStream'+this.id)[0];
|
|
|
|
if ( ! stream ) {
|
|
|
|
console.log('No live stream');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
src = stream.src.replace(/mode=single/i, 'mode=jpeg');
|
|
|
|
if ( -1 == src.search('connkey') ) {
|
|
|
|
src += '&connkey='+this.connKey;
|
|
|
|
}
|
|
|
|
if ( stream.src != src ) {
|
|
|
|
console.log("Setting to streaming");
|
|
|
|
stream.src = '';
|
|
|
|
stream.src = src;
|
|
|
|
}
|
2021-01-07 05:57:30 +08:00
|
|
|
this.streamCmdQuery.delay(delay, this);
|
2020-09-01 06:30:05 +08:00
|
|
|
};
|
2020-09-03 02:37:48 +08:00
|
|
|
this.stop = function() {
|
|
|
|
if ( 0 ) {
|
|
|
|
var stream = $j('#liveStream'+this.id)[0];
|
|
|
|
if ( ! stream ) {
|
|
|
|
console.log('No live stream');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
src = stream.src.replace(/mode=jpeg/i, 'mode=single');
|
|
|
|
if ( stream.src != src ) {
|
|
|
|
console.log("Setting to stopped");
|
|
|
|
stream.src = '';
|
|
|
|
stream.src = src;
|
|
|
|
}
|
|
|
|
}
|
2021-01-07 04:19:25 +08:00
|
|
|
this.streamCmdParms.command = CMD_STOP;
|
|
|
|
this.streamCmdReq(this.streamCmdParms);
|
2020-09-03 02:37:48 +08:00
|
|
|
};
|
|
|
|
this.pause = function() {
|
2021-01-07 04:19:25 +08:00
|
|
|
this.streamCmdParms.command = CMD_PAUSE;
|
|
|
|
this.streamCmdReq(this.streamCmdParms);
|
2020-09-04 22:02:43 +08:00
|
|
|
};
|
2020-09-03 02:37:48 +08:00
|
|
|
this.play = function() {
|
2021-01-07 04:19:25 +08:00
|
|
|
this.streamCmdParms.command = CMD_PLAY;
|
|
|
|
this.streamCmdReq(this.streamCmdParms);
|
2020-09-04 22:02:43 +08:00
|
|
|
};
|
2020-09-01 06:30:05 +08:00
|
|
|
|
|
|
|
this.eventHandler = function(event) {
|
|
|
|
console.log(event);
|
|
|
|
};
|
|
|
|
|
|
|
|
this.onclick = function(evt) {
|
|
|
|
var el = evt.currentTarget;
|
|
|
|
var id = el.getAttribute("data-monitor-id");
|
|
|
|
var url = '?view=watch&mid='+id;
|
|
|
|
evt.preventDefault();
|
2020-10-13 01:37:23 +08:00
|
|
|
window.location.assign(url);
|
2020-09-01 06:30:05 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
this.setup_onclick = function() {
|
|
|
|
var el = document.getElementById('imageFeed'+this.id);
|
|
|
|
if ( el ) el.addEventListener('click', this.onclick, false);
|
|
|
|
};
|
|
|
|
this.disable_onclick = function() {
|
|
|
|
document.getElementById('imageFeed'+this.id).removeEventListener('click', this.onclick );
|
|
|
|
};
|
|
|
|
|
2021-01-07 04:19:25 +08:00
|
|
|
this.setStateClass = function(jobj, stateClass) {
|
|
|
|
if ( !jobj ) {
|
2020-09-03 02:37:48 +08:00
|
|
|
return;
|
2020-09-04 22:02:43 +08:00
|
|
|
}
|
2021-01-07 04:19:25 +08:00
|
|
|
if ( !jobj.hasClass( stateClass ) ) {
|
|
|
|
if ( stateClass != 'alarm' ) jobj.removeClass('alarm');
|
|
|
|
if ( stateClass != 'alert' ) jobj.removeClass('alert');
|
|
|
|
if ( stateClass != 'idle' ) jobj.removeClass('idle');
|
|
|
|
|
|
|
|
jobj.addClass(stateClass);
|
2020-09-01 06:30:05 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-01-07 04:19:25 +08:00
|
|
|
this.onFailure = function(jqxhr, textStatus, error) {
|
|
|
|
this.streamCmdQuery.delay(1000*statusRefreshTimeout, this);
|
|
|
|
logAjaxFail(jqxhr, textStatus, error);
|
2020-09-01 06:30:05 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
this.getStreamCmdResponse = function(respObj, respText) {
|
|
|
|
var stream = $j('#liveStream'+this.id)[0];
|
2021-01-07 04:19:25 +08:00
|
|
|
|
2020-09-03 02:37:48 +08:00
|
|
|
if ( ! stream ) {
|
|
|
|
console.log('No live stream');
|
|
|
|
return;
|
|
|
|
}
|
2020-09-01 06:30:05 +08:00
|
|
|
|
|
|
|
if ( respObj.result == 'Ok' ) {
|
|
|
|
if ( respObj.status ) {
|
|
|
|
this.status = respObj.status;
|
|
|
|
this.alarmState = this.status.state;
|
|
|
|
|
2020-09-03 02:37:48 +08:00
|
|
|
var stateClass = '';
|
2020-09-01 06:30:05 +08:00
|
|
|
if ( this.alarmState == STATE_ALARM ) {
|
2020-09-03 02:37:48 +08:00
|
|
|
stateClass = 'alarm';
|
2020-09-01 06:30:05 +08:00
|
|
|
} else if ( this.alarmState == STATE_ALERT ) {
|
2020-09-03 02:37:48 +08:00
|
|
|
stateClass = 'alert';
|
2020-09-01 06:30:05 +08:00
|
|
|
} else {
|
2020-09-03 02:37:48 +08:00
|
|
|
stateClass = 'idle';
|
2020-09-01 06:30:05 +08:00
|
|
|
}
|
|
|
|
|
2020-09-03 02:37:48 +08:00
|
|
|
if ( (
|
2020-09-04 22:02:43 +08:00
|
|
|
(typeof COMPACT_MONTAGE === 'undefined') ||
|
|
|
|
!COMPACT_MONTAGE) &&
|
|
|
|
(this.type != 'WebSite')
|
2020-09-03 02:37:48 +08:00
|
|
|
) {
|
2021-01-07 04:19:25 +08:00
|
|
|
var fpsValue = $j('#fpsValue'+this.id);
|
|
|
|
var stateValue = $j('#stateValue'+this.id);
|
|
|
|
var monitorState = $j('#monitorState'+this.id);
|
2021-01-07 05:57:30 +08:00
|
|
|
|
2021-01-07 04:19:25 +08:00
|
|
|
if ( fpsValue.length ) fpsValue.text(this.status.fps);
|
|
|
|
if ( stateValue.length ) stateValue.text(stateStrings[this.alarmState]);
|
|
|
|
if ( monitorState.length ) this.setStateClass(monitorState, stateClass);
|
2020-09-01 06:30:05 +08:00
|
|
|
}
|
2020-09-03 02:37:48 +08:00
|
|
|
|
2021-01-07 04:19:25 +08:00
|
|
|
this.setStateClass($j('#monitor'+this.id), stateClass);
|
2020-09-01 06:30:05 +08:00
|
|
|
|
|
|
|
/*Stream could be an applet so can't use moo tools*/
|
2020-09-03 02:37:48 +08:00
|
|
|
//stream.parentNode().className = stateClass;
|
2020-09-01 06:30:05 +08:00
|
|
|
|
|
|
|
var isAlarmed = ( this.alarmState == STATE_ALARM || this.alarmState == STATE_ALERT );
|
|
|
|
var wasAlarmed = ( this.lastAlarmState == STATE_ALARM || this.lastAlarmState == STATE_ALERT );
|
|
|
|
|
|
|
|
var newAlarm = ( isAlarmed && !wasAlarmed );
|
|
|
|
var oldAlarm = ( !isAlarmed && wasAlarmed );
|
|
|
|
|
|
|
|
if ( newAlarm ) {
|
|
|
|
if ( false && SOUND_ON_ALARM ) {
|
|
|
|
// Enable the alarm sound
|
2021-01-07 04:19:25 +08:00
|
|
|
$j('#alarmSound').removeClass('hidden');
|
2020-09-01 06:30:05 +08:00
|
|
|
}
|
2020-09-03 02:37:48 +08:00
|
|
|
if ( (typeof POPUP_ON_ALARM !== 'undefined') && POPUP_ON_ALARM ) {
|
2020-09-01 06:30:05 +08:00
|
|
|
windowToFront();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ( false && SOUND_ON_ALARM ) {
|
|
|
|
if ( oldAlarm ) {
|
|
|
|
// Disable alarm sound
|
2021-01-07 04:19:25 +08:00
|
|
|
$j('#alarmSound').addClass('hidden');
|
2020-09-01 06:30:05 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if ( this.status.auth ) {
|
|
|
|
if ( this.status.auth != auth_hash ) {
|
|
|
|
// Try to reload the image stream.
|
|
|
|
if ( stream ) {
|
|
|
|
stream.src = stream.src.replace(/auth=\w+/i, 'auth='+this.status.auth);
|
|
|
|
}
|
|
|
|
console.log("Changed auth from " + auth_hash + " to " + this.status.auth);
|
|
|
|
auth_hash = this.status.auth;
|
|
|
|
}
|
|
|
|
} // end if have a new auth hash
|
|
|
|
} // end if has state
|
|
|
|
} else {
|
|
|
|
console.error(respObj.message);
|
|
|
|
// Try to reload the image stream.
|
|
|
|
if ( stream ) {
|
|
|
|
if ( stream.src ) {
|
|
|
|
console.log('Reloading stream: ' + stream.src);
|
2020-09-03 02:37:48 +08:00
|
|
|
src = stream.src.replace(/rand=\d+/i, 'rand='+Math.floor((Math.random() * 1000000) ));
|
|
|
|
if ( src != stream.src ) {
|
|
|
|
stream.src = src;
|
|
|
|
} else {
|
|
|
|
console.log("Failed to update rand on stream src");
|
|
|
|
}
|
2020-09-01 06:30:05 +08:00
|
|
|
} else {
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
console.log('No stream to reload?');
|
|
|
|
}
|
|
|
|
} // end if Ok or not
|
|
|
|
|
2021-01-07 05:57:30 +08:00
|
|
|
this.lastAlarmState = this.alarmState;
|
2021-01-07 04:19:25 +08:00
|
|
|
this.streamCmdQuery.delay(statusRefreshTimeout, this);
|
2020-09-01 06:30:05 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
this.streamCmdQuery = function(resent) {
|
|
|
|
//console.log("Starting CmdQuery for " + this.connKey );
|
|
|
|
if ( this.type != 'WebSite' ) {
|
2021-01-07 04:19:25 +08:00
|
|
|
this.streamCmdParms.command = CMD_QUERY;
|
|
|
|
this.streamCmdReq(this.streamCmdParms);
|
2020-09-01 06:30:05 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
if ( this.type != 'WebSite' ) {
|
2021-01-07 04:19:25 +08:00
|
|
|
this.streamCmdReq = function(streamCmdParms) {
|
|
|
|
$j.ajaxSetup({timeout: AJAX_TIMEOUT});
|
|
|
|
$j.getJSON(this.url, streamCmdParms)
|
|
|
|
.done(this.getStreamCmdResponse.bind(this))
|
|
|
|
.fail(this.onFailure.bind(this));
|
|
|
|
};
|
2020-09-01 06:30:05 +08:00
|
|
|
}
|
|
|
|
} // end function MonitorStream
|