var socketConnectRequested = 0; var totalDevicesOnline = 0; var yptSocketResponse; var socketResourceId; var socketConnectTimeout; var users_id_online = []; var socketConnectRetryTimeout = 15000; function socketConnect() { if (socketConnectRequested) { //console.log('socketConnect: already requested'); return false; } clearTimeout(socketConnectTimeout); if (!isOnline()) { //console.log('socketConnect: Not Online'); socketConnectRequested = 0; socketConnectTimeout = setTimeout(function () { socketConnect(); }, 1000); return false; } socketConnectRequested = 1; var url = addGetParam(webSocketURL, 'page_title', $('').html($(document).find("title").text()).text()); ////console.log('Trying to reconnect on socket... '); if (!isValidURL(url)) { socketConnectRequested = 0; //console.log("socketConnect: Invalid URL ", url); socketConnectTimeout = setTimeout(function () { socketConnect(); }, 30000); return false; } conn = new WebSocket(url); setSocketIconStatus('loading'); try { conn.onopen = function (e) { socketConnectRequested = 0; socketConnectRetryTimeout = 2000; clearTimeout(socketConnectTimeout); console.log("socketConnect: Socket onopen"); onSocketOpen(); return false; }; } catch (e) { console.log("socketConnect: Error onopen", e); } conn.onmessage = function (e) { var json = JSON.parse(e.data); consolelog("Socket onmessage conn.onmessage", json); socketResourceId = json.resourceId; yptSocketResponse = json; parseSocketResponse(); if (json.type == webSocketTypes.ON_VIDEO_MSG) { console.log("Socket onmessage ON_VIDEO_MSG", json); $('.videoUsersOnline, .videoUsersOnline_' + json.videos_id).text(json.total); } if (json.type == webSocketTypes.ON_LIVE_MSG && typeof json.is_live !== 'undefined') { console.log("Socket onmessage ON_LIVE_MSG", json); var selector = '#liveViewStatusID_' + json.live_key.key + '_' + json.live_key.live_servers_id; if (json.is_live) { onlineLabelOnline(selector); } else { onlineLabelOffline(selector); } } if (json.type == webSocketTypes.NEW_CONNECTION) { console.log("Socket onmessage NEW_CONNECTION", json); if (typeof onUserSocketConnect === 'function') { onUserSocketConnect(json); } } else if (json.type == webSocketTypes.NEW_DISCONNECTION) { console.log("Socket onmessage NEW_DISCONNECTION", json); if (typeof onUserSocketDisconnect === 'function') { onUserSocketDisconnect(json); } } else { var myfunc; if (json.callback) { //console.log("Socket onmessage json.callback ", json.resourceId, json.callback); var code = "if(typeof " + json.callback + " == 'function'){myfunc = " + json.callback + ";}else{myfunc = defaultCallback;}"; ////console.log(code); eval(code); } else { //console.log("onmessage: callback not found", json); myfunc = defaultCallback; } myfunc(json.msg); } }; conn.onclose = function (e) { socketConnectRequested = 0; console.log('Socket is closed. Reconnect will be attempted in ' + socketConnectRetryTimeout + ' seconds.', e.reason); socketConnectTimeout = setTimeout(function () { socketConnect(); }, socketConnectRetryTimeout); onSocketClose(); }; conn.onerror = function (err) { socketConnectRequested = 0; console.error('Socket encountered error: ', err, 'Closing socket'); conn.close(); }; } function onSocketOpen() { setSocketIconStatus('connected'); } function onSocketClose() { setSocketIconStatus('disconnected'); } function setSocketIconStatus(status) { var selector = '.socket_info'; if (status == 'connected') { $(selector).removeClass('socket_loading'); $(selector).removeClass('socket_disconnected'); $(selector).addClass('socket_connected'); } else if (status == 'disconnected') { $(selector).removeClass('socket_loading'); $(selector).addClass('socket_disconnected'); $(selector).removeClass('socket_connected'); } else { $(selector).addClass('socket_loading'); $(selector).removeClass('socket_disconnected'); $(selector).removeClass('socket_connected'); } } function sendSocketMessageToAll(msg, callback) { sendSocketMessageToUser(msg, callback, ""); } function sendSocketMessageToNone(msg, callback) { sendSocketMessageToUser(msg, callback, -1); } function sendSocketMessageToUser(msg, callback, to_users_id) { if (conn.readyState === 1) { conn.send(JSON.stringify({ msg: msg, webSocketToken: webSocketToken, callback: callback, to_users_id: to_users_id })); } else { //console.log('Socket not ready send message in 1 second'); setTimeout(function () { sendSocketMessageToUser(msg, to_users_id, callback); }, 1000); } } function sendSocketMessageToUser(msg, callback, to_users_id) { if (conn.readyState === 1) { conn.send(JSON.stringify({ msg: msg, webSocketToken: webSocketToken, callback: callback, to_users_id: to_users_id })); } else { //console.log('Socket not ready send message in 1 second'); setTimeout(function () { sendSocketMessageToUser(msg, to_users_id, callback); }, 1000); } } function sendSocketMessageToResourceId(msg, callback, resourceId) { if (conn.readyState === 1) { conn.send(JSON.stringify({ msg: msg, webSocketToken: webSocketToken, callback: callback, resourceId: resourceId })); } else { //console.log('Socket not ready send message in 1 second'); setTimeout(function () { sendSocketMessageToUser(msg, to_users_id, callback); }, 1000); } } function isSocketActive() { return isOnline() && typeof conn != 'undefined' && conn.readyState === 1; } function defaultCallback(json) { ////console.log('defaultCallback', json); } var socketAutoUpdateOnHTMLTimout; var globalAutoUpdateOnHTML = []; function socketAutoUpdateOnHTML(autoUpdateOnHTML) { globalAutoUpdateOnHTML = []; for (var prop in autoUpdateOnHTML) { if (autoUpdateOnHTML[prop] === false) { continue; } if (typeof autoUpdateOnHTML[prop] !== 'string' && typeof autoUpdateOnHTML[prop] !== 'number') { continue; } ////console.log('socketAutoUpdateOnHTML 1', prop, globalAutoUpdateOnHTML[prop], autoUpdateOnHTML[prop]); globalAutoUpdateOnHTML[prop] = autoUpdateOnHTML[prop]; } ////console.log('socketAutoUpdateOnHTML 1', autoUpdateOnHTML, globalAutoUpdateOnHTML); } async function AutoUpdateOnHTMLTimer() { var localAutoUpdateOnHTML = []; clearTimeout(socketAutoUpdateOnHTMLTimout); ////console.log('AutoUpdateOnHTMLTimer 1', empty(globalAutoUpdateOnHTML), globalAutoUpdateOnHTML); if (!empty(globalAutoUpdateOnHTML)) { $('.total_on').text(0); $('.total_on').parent().removeClass('text-success'); ////console.log("AutoUpdateOnHTMLTimer 2", $('.total_on'), globalAutoUpdateOnHTML); localAutoUpdateOnHTML = globalAutoUpdateOnHTML; globalAutoUpdateOnHTML = []; //console.log('AutoUpdateOnHTMLTimer localAutoUpdateOnHTML 1', globalAutoUpdateOnHTML, localAutoUpdateOnHTML); for (var prop in localAutoUpdateOnHTML) { if (localAutoUpdateOnHTML[prop] === false) { continue; } var val = localAutoUpdateOnHTML[prop]; if (typeof val == 'string' || typeof val == 'number') { ////console.log('AutoUpdateOnHTMLTimer 3', prop, val, $('.' + prop).text()); $('.' + prop).text(val); //console.log('AutoUpdateOnHTMLTimer 4', prop, val, $('.' + prop).text()); if (parseInt(val) > 0) { $('.' + prop).parent().addClass('text-success'); } } } } else { globalAutoUpdateOnHTML = []; } localAutoUpdateOnHTML = []; socketAutoUpdateOnHTMLTimout = setTimeout(function () { AutoUpdateOnHTMLTimer(); }, 2000); } var canShowSocketToast = true; function parseSocketResponse() { json = yptSocketResponse; yptSocketResponse = false; if (typeof json === 'undefined' || json === false) { return false; } console.log("parseSocketResponse", json); //console.trace(); if (json.isAdmin && webSocketServerVersion > json.webSocketServerVersion) { if (canShowSocketToast && typeof avideoToastWarning == 'function') { avideoToastWarning("Please restart your socket server. You are running (v" + json.webSocketServerVersion + ") and your client is expecting (v" + webSocketServerVersion + ")"); // Set the flag to false canShowSocketToast = false; // Reset the flag after 5 minutes setTimeout(function() { canShowSocketToast = true; }, 300000); // 300,000 milliseconds = 5 minutes } } if (json && typeof json.users_id_online !== 'undefined') { users_id_online = json.users_id_online; } if (json && typeof json.autoUpdateOnHTML !== 'undefined') { socketAutoUpdateOnHTML(json.autoUpdateOnHTML); } if (json && typeof json.msg.autoEvalCodeOnHTML !== 'undefined') { ////console.log("autoEvalCodeOnHTML", json.msg.autoEvalCodeOnHTML); eval(json.msg.autoEvalCodeOnHTML); } $('#socketUsersURI').empty(); if (json && $('#socket_info_container').length) { if (typeof json.users_uri !== 'undefined') { for (var prop in json.users_uri) { if (json.users_uri[prop] === false) { continue; } for (var prop2 in json.users_uri[prop]) { if (json.users_uri[prop][prop2] === false || typeof json.users_uri[prop][prop2] !== 'object') { continue; } for (var prop3 in json.users_uri[prop][prop2]) { if (json.users_uri[prop][prop2][prop3] === false || typeof json.users_uri[prop][prop2][prop3] !== 'object') { continue; } var socketUserDivID = 'socketUser' + json.users_uri[prop][prop2][prop3].users_id; if (!$('#' + socketUserDivID).length) { var html = '