Diskernet/public/injection.js

66 lines
2.1 KiB
JavaScript
Raw Normal View History

2021-11-03 04:51:04 +00:00
export function getInjection({sessionId}) {
2021-12-15 05:16:16 +00:00
// Notes:
// say() function
// why aliased? Resistant to page overwriting
// just a precaution as we are already in an isolated world here, but this makes
// this script more portable if it were introduced globally as well as robust
// against API or behaviour changes of the browser or its remote debugging protocol
// in future
2021-11-03 04:51:04 +00:00
return `
{
if ( top === self ) {
2021-12-15 05:16:16 +00:00
const ConsoleInfo = console.info.bind(console);
const JSONStringify = JSON.stringify.bind(JSON);
const TITLE_CHANGES = 10;
const INITIAL_CHECK_TIME = 500;
const TIME_MULTIPLIER = Math.E;
2021-11-03 04:51:04 +00:00
const sessionId = "${sessionId}";
const sleep = ms => new Promise(res => setTimeout(res, ms));
install();
async function install() {
console.log("Installing...");
2021-12-15 05:16:16 +00:00
self.startUrl = location.href;
say({install: { sessionId, startUrl }});
2021-11-03 04:51:04 +00:00
await sleep(500);
2021-12-15 05:16:16 +00:00
beginTitleChecks();
2021-11-03 04:51:04 +00:00
console.log("Installed.");
}
2021-12-15 05:16:16 +00:00
function beginTitleChecks() {
let lastTitle = null;
let checker;
let timeToNextCheck = INITIAL_CHECK_TIME;
let changesLogged = 0;
check();
console.log('Begun logging title changes.');
function check() {
clearTimeout(checker);
const currentTitle = document.title;
if ( lastTitle !== currentTitle ) {
say({titleChange: {lastTitle, currentTitle, url: location.href, sessionId}});
lastTitle = currentTitle;
changesLogged++;
} else {
// increase check time if there's no change
timeToNextCheck *= TIME_MULTIPLIER;
}
if ( changesLogged < TITLE_CHANGES ) {
checker = setTimeout(check, timeToNextCheck);
} else {
console.log('Finished logging title changes.');
}
}
}
function say(thing) {
ConsoleInfo(JSONStringify(thing));
}
2021-11-03 04:51:04 +00:00
}
}
`;
}