This commit is contained in:
choelzl 2022-02-09 11:12:40 +01:00
parent d34b30abf7
commit 4c8b17b4d1
Signed by: sora
GPG Key ID: A362EA0491E2EEA0
2 changed files with 112 additions and 113 deletions

View File

@ -1,7 +1,5 @@
(function() {
function fetchSeed(id) {
var HttpRequest = Packages.com.gmt2001.HttpRequest,
HashMap = Packages.java.util.HashMap,
@ -164,7 +162,6 @@
}else if(action.equalsIgnoreCase('refresh')){
var newseed = GameHelper.fetchSeed(args[1]);
}else if(action.equalsIgnoreCase('gg')){
console.log("GOT: GG")
sendData('guesses',JSON.stringify(guesses));
}
}

View File

@ -1,5 +1,5 @@
/*
* Copyright (C) 2016-2019 phantombot.tv
* Copyright (C) 2016-2021 phantombot.github.io/PhantomBot
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@ -15,53 +15,30 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
//NOTE: this is straight copied from panel's index.js
// Main socket and functions.
$(function () {
var helpers = {};
helpers.DEBUG_STATES = {
NONE: 0,
DEBUG: 1,
INFO: 2,
FORCE: 3
};
// Debug status. 0 = off | 1 = on.
helpers.DEBUG_STATE = (localStorage.getItem('phantombot_debug_state') !== null ? parseInt(localStorage.getItem('phantombot_debug_state')) : helpers.DEBUG_STATES.NONE);
// Debug types.
helpers.LOG_TYPE = helpers.DEBUG_STATES;
/*
* @function Used to print debug messages in the console.
*
* @param {String} message
* @param {Number} type
*/
helpers.log = function(message, type) {
if (helpers.DEBUG_STATE === helpers.DEBUG_STATES.DEBUG || type === helpers.DEBUG_STATE || type === helpers.LOG_TYPE.FORCE) {
console.log('%c[PhantomBot Log]', 'color: #6441a5; font-weight: 900;', message);
if (!helpers.isLocalPanel()) {
$.ajax(
{
type: 'GET',
url: 'https://' + helpers.getBotHost() + '/sslcheck',
crossDomain: true,
dataType: 'text',
async: false,
success: function (data) {
if (data === 'false') {
window.location = window.location.origin + window.location.pathname + 'login/#sslFail=true';
}
};
/*
* @function Used to print error messages in the console.
*
* @param {String} message
* @param {Number} type
*/
helpers.logError = function(message, type) {
console.log('%c[PhantomBot Error]', 'color: red; font-weight: 900;', message);
};
var webSocket = new ReconnectingWebSocket((getProtocol() === 'https://' || window.location.protocol === 'https:' ? 'wss://' : 'ws://') + 'twitchbot.helcel.net' + '/ws/panel', null, { reconnectInterval: 500 }),
},
error: function () {
window.location = window.location.origin + window.location.pathname + 'login/#sslFail=true';
}
}
);
}
var webSocket = new ReconnectingWebSocket((window.location.protocol === 'https:' ? 'wss://' : 'ws://') + helpers.getBotHost() + '/ws/panel?target=' + helpers.getBotHost(), null, {reconnectInterval: 500}),
callbacks = [],
listeners = [],
familyHandlers = {},
socket = {};
/*
@ -110,7 +87,7 @@ $(function() {
callback(e);
} catch (ex) {
// Line number won't be accurate, function will by anonymous, but we get the stack so it should be fine.
helpers.logError('Failed to run callback: ' + ex.stack, helpers.LOG_TYPE.FORCE);
helpers.logError('Failed to run callback: (' + ex.name + ') ' + ex.message + ' >> ' + ex.stack, helpers.LOG_TYPE.FORCE);
}
},
storeKey: storeKey,
@ -127,13 +104,13 @@ $(function() {
*/
socket.addListener = function (listener_id, callback) {
if (listeners[listener_id] === undefined) {
helpers.log('Adding listener with id ' + listener_id);
helpers.log('Added listener with id ' + listener_id);
listeners[listener_id] = function (e) {
try {
callback(e);
} catch (ex) {
// Line number won't be accurate, function will by anonymous, but we get the stack so it should be fine.
helpers.logError('Failed to run listener: ' + ex.stack, helpers.LOG_TYPE.FORCE);
helpers.logError('Failed to run listener: (' + ex.name + ') ' + ex.message + ' >> ' + ex.stack, helpers.LOG_TYPE.FORCE);
}
};
}
@ -150,23 +127,6 @@ $(function() {
}
};
socket.addFamilyHandler = function(familyName, callback) {
familyHandlers[familyName] = function(e) {
try {
callback(e);
} catch (ex) {
// Line number won't be accurate, function will by anonymous, but we get the stack so it should be fine.
helpers.logError('Failed to run family handler: ' + ex.stack, helpers.LOG_TYPE.FORCE);
}
};
}
socket.removeFamilyHandler = function(familyName) {
if (familyHandlers[familyName] !== undefined) {
delete listeners[familyName];
}
};
/*
* @function Runs a bot commands as the bot in async, thus returning right away.
*
@ -243,6 +203,16 @@ $(function() {
});
};
socket.getDiscordChannelList = function (callback_id, callback) {
// Genetate a callback.
socket.addListener(callback_id, callback);
// Send event.
sendToSocket({
discordchannellist: callback_id
});
};
/*
* @function Updates a value in the database of the bot.
*
@ -373,7 +343,7 @@ $(function() {
callback = (callback === undefined ? storeKey : callback);
// Genetate a callback.
generateCallBack(callback_id, dataObj.tables, false, false, callback, (typeof storeKey === 'function' ? false : true));
generateCallBack(callback_id, dataObj.tables, false, false, callback, (typeof storeKey !== 'function'));
// Start sending the updates to the socket.
for (let i = 0; i < dataObj.tables.length; i++) {
@ -497,15 +467,40 @@ $(function() {
}
};
// WebSocket events.
/*
* @function Sends a remote panel query.
*
* @param {String} query_id
* @param {String} query
* @param {Object} params
* @param {Function} callback
*/
socket.doRemote = function (query_id, query, params, callback) {
generateCallBack(query_id, [], false, true, callback);
socket.getReadyState = function() {return webSocket.readyState;}
sendToSocket({
remote: true,
id: query_id,
query: query,
params: params
});
};
socket.close = function () {
webSocket.close(1000);
};
// WebSocket events.
/*
* @function Called when the socket opens.
*/
webSocket.onopen = function () {
helpers.log('Connection established with the websocket.', helpers.LOG_TYPE.FORCE);
// Restart Pace.
Pace.restart();
// Remove all alerts.
toastr.remove();
// Auth with the socket.
sendToSocket({
authenticate: getAuth()
@ -517,6 +512,8 @@ $(function() {
*/
webSocket.onclose = function () {
helpers.logError('Connection lost with the websocket.', helpers.LOG_TYPE.FORCE);
// Add error toast.
toastr.error('Connection lost with the websocket.', '', {timeOut: 0});
};
/*
@ -537,6 +534,7 @@ $(function() {
if (message.authresult !== undefined) {
if (message.authresult === 'false') {
helpers.logError('Failed to auth with the socket.', helpers.LOG_TYPE.FORCE);
toastr.error('Failed to auth with the socket.', '', {timeOut: 0});
} else {
// This is to stop a reconnect loading the main page.
if (helpers.isAuth === true) {
@ -545,22 +543,31 @@ $(function() {
helpers.isAuth = true;
}
// XXX: revent loading main page
//$.loadPage('dashboard', 'dashboard.html');
sendToSocket({
remote: true,
id: 'initLoad.panelSettings',
query: 'panelSettings'
});
}
return;
}
if (message.id !== undefined) {
if (message.id === 'initLoad.panelSettings') {
window.panelSettings.channelName = message.channelName;
window.panelSettings.displayName = message.displayName;
$.loadPage('dashboard', 'dashboard.html');
helpers.getUserLogo();
}
}
// Make sure this isn't a version request.
if (message.versionresult !== undefined) {
// Call the callback.
callbacks[message.versionresult].func(message);
// Delete the callback.
delete callbacks[message.versionresult];
} else if(message.query_id !== undefined) {
// console.log("base got websocket with data");
// console.log(e);
} else {
// Handle callbacks.
let callback = callbacks[message.query_id],
@ -595,7 +602,7 @@ $(function() {
if (message.query_id.indexOf('module_toggle') !== -1 || message.query_id.indexOf('module_status') !== -1
|| message.query_id.endsWith('module')) {
if (message.results.value == 'false') {
if (message.results !== undefined && message.results.value == 'false') {
$('.load-ajax').remove();
}
}
@ -606,11 +613,6 @@ $(function() {
// Call the listener.
listener(message.results);
}
} else if(message.eventFamily !== undefined) {
let handler = familyHandlers[message.eventFamily];
if(handler !== undefined) {
handler(e)
}
}
} catch (ex) {
// Line number won't be accurate, function will by anonymous, but we get the stack so it should be fine.