2023-03-29 12:54:07 +00:00
|
|
|
import * as plugins from './typedserver_web.plugins.js';
|
|
|
|
import * as interfaces from '../ts/interfaces/index.js';
|
|
|
|
import { logger } from './typedserver_web.logger.js';
|
|
|
|
logger.log('info', `TypedServer-Devtools initialized!`);
|
|
|
|
|
|
|
|
import { TypedserverInfoscreen } from './typedserver_web.infoscreen.js';
|
|
|
|
|
|
|
|
export class ReloadChecker {
|
|
|
|
public reloadJustified = false;
|
|
|
|
public backendConnectionLost = false;
|
|
|
|
public infoscreen = new TypedserverInfoscreen();
|
|
|
|
public store = new plugins.webstore.WebStore({
|
|
|
|
dbName: 'apiglobal__typedserver',
|
|
|
|
storeName: 'apiglobal__typedserver',
|
|
|
|
});
|
|
|
|
public storeKey = 'lastServerChange';
|
|
|
|
|
|
|
|
public typedsocket: plugins.typedsocket.TypedSocket;
|
|
|
|
public typedrouter = new plugins.typedrequest.TypedRouter();
|
|
|
|
|
|
|
|
constructor() {}
|
|
|
|
|
|
|
|
public async reload() {
|
|
|
|
// this looks a bit hacky, but apparently is the safest way to really reload stuff
|
|
|
|
window.location.reload();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* starts the reload checker
|
|
|
|
*/
|
|
|
|
public async performHttpRequest() {
|
|
|
|
logger.log('info', 'performing http check...');
|
|
|
|
(await this.store.get(this.storeKey))
|
|
|
|
? null
|
|
|
|
: await this.store.set(this.storeKey, globalThis.typedserver.lastReload);
|
|
|
|
|
|
|
|
let response: Response;
|
|
|
|
|
|
|
|
try {
|
|
|
|
const controller = new AbortController();
|
|
|
|
plugins.smartdelay.delayFor(5000).then(() => {
|
|
|
|
controller.abort();
|
|
|
|
});
|
|
|
|
response = await fetch('/typedserver/reloadcheck', {
|
|
|
|
method: 'POST',
|
|
|
|
signal: controller.signal,
|
|
|
|
});
|
|
|
|
} catch (err: any) {}
|
|
|
|
|
|
|
|
if (response?.status !== 200) {
|
|
|
|
this.backendConnectionLost = true;
|
|
|
|
logger.log('warn', `got a status ${response?.status}.`);
|
|
|
|
this.infoscreen.setText(`backend connection lost... Status ${response?.status}`);
|
|
|
|
}
|
2023-03-29 17:26:42 +00:00
|
|
|
if (response?.status === 200 && this.backendConnectionLost) {
|
2023-03-29 12:54:07 +00:00
|
|
|
this.backendConnectionLost = false;
|
|
|
|
this.infoscreen.setSuccess('regained connection to backend...');
|
|
|
|
}
|
|
|
|
return response;
|
|
|
|
}
|
|
|
|
|
|
|
|
public async checkReload(lastServerChange: number) {
|
|
|
|
let reloadJustified = false;
|
2023-04-09 21:04:35 +00:00
|
|
|
let storedLastServerChange = await this.store.get(this.storeKey);
|
2023-04-09 22:55:16 +00:00
|
|
|
if (storedLastServerChange && storedLastServerChange !== lastServerChange) {
|
|
|
|
reloadJustified = true;
|
|
|
|
} else {
|
|
|
|
}
|
2023-03-29 12:54:07 +00:00
|
|
|
|
|
|
|
if (reloadJustified) {
|
|
|
|
this.store.set(this.storeKey, lastServerChange);
|
2023-04-01 13:12:54 +00:00
|
|
|
const reloadText = `upgrading... ${
|
2023-03-29 12:54:07 +00:00
|
|
|
globalThis.globalSw ? '(purging the sw cache first...)' : ''
|
|
|
|
}`;
|
|
|
|
this.infoscreen.setText(reloadText);
|
|
|
|
if (globalThis.globalSw?.purgeCache) {
|
|
|
|
await globalThis.globalSw.purgeCache();
|
|
|
|
} else {
|
|
|
|
console.log('globalThis.globalSw not found...');
|
|
|
|
}
|
|
|
|
this.infoscreen.setText(`cleaned caches`);
|
|
|
|
await plugins.smartdelay.delayFor(200);
|
|
|
|
this.reload();
|
|
|
|
return;
|
|
|
|
} else {
|
|
|
|
if (this.infoscreen) {
|
|
|
|
this.infoscreen.hide();
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public async connectTypedsocket() {
|
|
|
|
if (!this.typedsocket) {
|
|
|
|
this.typedrouter.addTypedHandler<interfaces.IReq_PushLatestServerChangeTime>(
|
|
|
|
new plugins.typedrequest.TypedHandler('pushLatestServerChangeTime', async (dataArg) => {
|
|
|
|
this.checkReload(dataArg.time);
|
|
|
|
return {};
|
|
|
|
})
|
|
|
|
);
|
|
|
|
this.typedsocket = await plugins.typedsocket.TypedSocket.createClient(
|
|
|
|
this.typedrouter,
|
|
|
|
plugins.typedsocket.TypedSocket.useWindowLocationOriginUrl()
|
|
|
|
);
|
2023-04-04 15:14:54 +00:00
|
|
|
this.typedsocket.addTag('typedserver_frontend', {});
|
2023-04-09 22:55:16 +00:00
|
|
|
this.typedsocket.eventSubject.subscribe(async (eventArg) => {
|
2023-03-29 17:51:52 +00:00
|
|
|
console.log(`typedsocket event subscription: ${eventArg}`);
|
2023-04-09 22:55:16 +00:00
|
|
|
if (
|
|
|
|
eventArg === 'disconnected' ||
|
|
|
|
eventArg === 'disconnecting' ||
|
|
|
|
eventArg === 'timedOut'
|
|
|
|
) {
|
2023-03-29 17:51:52 +00:00
|
|
|
this.backendConnectionLost = true;
|
2023-04-09 22:55:16 +00:00
|
|
|
this.infoscreen.setText(`typedsocket ${eventArg}!`);
|
2023-03-29 17:51:52 +00:00
|
|
|
} else if (eventArg === 'connected' && this.backendConnectionLost) {
|
|
|
|
this.backendConnectionLost = false;
|
2023-03-31 11:18:23 +00:00
|
|
|
this.infoscreen.setSuccess('typedsocket connected!');
|
|
|
|
// lets check if a reload is necessary
|
2023-04-09 22:55:16 +00:00
|
|
|
const getLatestServerChangeTime =
|
|
|
|
this.typedsocket.createTypedRequest<interfaces.IReq_GetLatestServerChangeTime>(
|
|
|
|
'getLatestServerChangeTime'
|
|
|
|
);
|
2023-03-31 11:18:23 +00:00
|
|
|
const response = await getLatestServerChangeTime.fire({});
|
|
|
|
this.checkReload(response.time);
|
2023-03-29 17:51:52 +00:00
|
|
|
}
|
|
|
|
});
|
2023-04-09 22:55:16 +00:00
|
|
|
logger.log('success', `ReloadChecker connected through typedsocket!`);
|
2023-03-29 12:54:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public started = false;
|
|
|
|
public async start() {
|
|
|
|
this.started = true;
|
|
|
|
logger.log('info', `starting ReloadChecker...`);
|
|
|
|
while (this.started) {
|
|
|
|
const response = await this.performHttpRequest();
|
|
|
|
if (response.status === 200) {
|
|
|
|
logger.log('info', `ReloadChecker reached backend!`);
|
|
|
|
await this.checkReload(parseInt(await response.text()));
|
|
|
|
await this.connectTypedsocket();
|
|
|
|
}
|
2023-03-29 17:26:42 +00:00
|
|
|
await plugins.smartdelay.delayFor(120000);
|
2023-03-29 12:54:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public async stop() {
|
|
|
|
this.started = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const reloadCheckInstance = new ReloadChecker();
|
|
|
|
reloadCheckInstance.start();
|