iceshrimp/packages/backend/src/server/web/views/flush.pug

72 lines
2.2 KiB
Plaintext
Raw Normal View History

2020-02-09 12:47:50 +09:00
doctype html
html
head
meta(charset='utf-8')
meta(name='application-name' content='Calckey')
2022-07-07 15:16:15 +09:00
meta(name='viewport' content='width=device-width, initial-scale=1.0')
2022-07-07 13:47:01 +09:00
title Flush Misskey
2022-07-07 13:50:48 +09:00
style.
* {
font-family: BIZ UDGothic, Roboto, HelveticaNeue, Arial, sans-serif;
}
body,
html {
background-color: #222;
color: #dfddcc;
justify-content: center;
margin: auto;
padding: 10px;
text-align: center;
}
a {
color: rgb(134, 179, 0);
text-decoration: none;
}
2021-03-13 10:55:29 +09:00
2022-07-07 13:46:04 +09:00
body
#msg
2022-07-07 13:24:39 +09:00
script.
const msg = document.getElementById('msg');
const successText = `\nSuccess Flush! <a href="/">Back to Calckey</a>\n成功しました。<a href="/">Calckeyを開き直してください。</a>`;
2021-03-13 10:55:29 +09:00
2022-07-07 13:24:39 +09:00
message('Start flushing.');
(async function() {
try {
localStorage.clear();
message('localStorage cleared.');
const idbPromises = ['MisskeyClient', 'keyval-store'].map((name, i, arr) => new Promise((res, rej) => {
const delidb = indexedDB.deleteDatabase(name);
delidb.onsuccess = () => res(message(`indexedDB "${name}" cleared. (${i + 1}/${arr.length})`));
delidb.onerror = e => rej(e)
}));
2022-07-07 13:24:39 +09:00
await Promise.all(idbPromises);
if (navigator.serviceWorker.controller) {
navigator.serviceWorker.controller.postMessage('clear');
await navigator.serviceWorker.getRegistrations()
.then(registrations => {
return Promise.all(registrations.map(registration => registration.unregister()));
})
.catch(e => { throw Error(e) });
}
message(successText);
} catch (e) {
message(`\n${e}\n\nFlush Failed. <a href="/flush">Please retry.</a>\n失敗しました。<a href="/flush">もう一度試してみてください。</a>`);
message(`\nIf you retry more than 3 times, clear the browser cache or contact to instance admin.\n3回以上試しても失敗する場合、ブラウザのキャッシュを消去し、それでもだめならインスタンス管理者に連絡してみてください。\n`)
console.error(e);
setTimeout(() => {
location = '/';
}, 10000)
2021-03-13 10:55:29 +09:00
}
2022-07-07 13:24:39 +09:00
})();
2021-03-13 10:55:29 +09:00
2022-07-07 13:24:39 +09:00
function message(text) {
msg.insertAdjacentHTML('beforeend', `<p>[${(new Date()).toString()}] ${text.replace(/\n/g,'<br>')}</p>`)
2022-07-07 13:36:25 +09:00
}