Script/Debug/Real-time-debug.js

64 lines
1.7 KiB
JavaScript

/*
* LAN script real-time debug
*
* PC: Use "Live Server" plugin in VSCode to create a LAN backend
* APP: After backend address is modified in script, use this script as script path
*/
!async function() {
const _$ = new nobyda();
const _r = await new Promise(e => {
_$.get({
url: 'http://192.168.1.66:5500/debug.js' // LAN backend address
}, (t, c, o) => {
if (c && c.status == 200 && o) {
_$.write(o, 'Real-time-debug');
e(o);
}
});
setTimeout(e, 100);
});
if (_r) {
console.log("🌐 Run local network script...");
eval(_r);
} else {
console.log("⚠️ Run cache script...");
eval(_$.read('Real-time-debug'))
}
function nobyda() {
const isSurge = typeof $httpClient != "undefined";
const isQuanX = typeof $task != "undefined";
const adapterStatus = (response) => {
if (response) {
if (response.status) {
response["statusCode"] = response.status
} else if (response.statusCode) {
response["status"] = response.statusCode
}
}
return response
};
this.write = (value, key) => {
if (isQuanX) return $prefs.setValueForKey(value, key);
if (isSurge) return $persistentStore.write(value, key);
};
this.read = (key) => {
if (isQuanX) return $prefs.valueForKey(key);
if (isSurge) return $persistentStore.read(key);
};
this.get = (options, callback) => {
if (isQuanX) {
$task.fetch(options).then(response => {
callback(null, adapterStatus(response), response.body)
}, reason => callback(reason.error, null, null))
}
if (isSurge) {
$httpClient.get(options, (error, response, body) => {
callback(error, adapterStatus(response), body)
})
}
};
this.done = (value = {}) => $done(value)
}
}();