summaryrefslogtreecommitdiff
path: root/packages/backend/src
diff options
context:
space:
mode:
authortamaina <tamaina@hotmail.co.jp>2022-05-29 10:58:54 +0900
committerGitHub <noreply@github.com>2022-05-29 10:58:54 +0900
commitf1d2398eacbc69a14d09ebe5e7040be891f9e143 (patch)
treebc86bdba607dff72841b835559fc7805bcb41f19 /packages/backend/src
parentpreload app css (#8752) (diff)
downloadsharkey-f1d2398eacbc69a14d09ebe5e7040be891f9e143.tar.gz
sharkey-f1d2398eacbc69a14d09ebe5e7040be891f9e143.tar.bz2
sharkey-f1d2398eacbc69a14d09ebe5e7040be891f9e143.zip
fix(client): Vite related boot mechanism revision (#8753)
* preload app css * remove salt * APP_FETCH_FAILED error * set max-age to 15s
Diffstat (limited to 'packages/backend/src')
-rw-r--r--packages/backend/src/server/web/boot.js13
-rw-r--r--packages/backend/src/server/web/index.ts14
-rw-r--r--packages/backend/src/server/web/views/base.pug4
3 files changed, 14 insertions, 17 deletions
diff --git a/packages/backend/src/server/web/boot.js b/packages/backend/src/server/web/boot.js
index a9ee0df4f1..94329e11c9 100644
--- a/packages/backend/src/server/web/boot.js
+++ b/packages/backend/src/server/web/boot.js
@@ -54,14 +54,10 @@
//#endregion
//#region Script
- const salt = localStorage.getItem('salt')
- ? `?salt=${localStorage.getItem('salt')}`
- : '';
-
- import(`/assets/${CLIENT_ENTRY}${salt}`)
- .catch(async () => {
+ import(`/assets/${CLIENT_ENTRY}`)
+ .catch(async e => {
await checkUpdate();
- renderError('APP_FETCH_FAILED');
+ renderError('APP_FETCH_FAILED', JSON.stringify(e));
})
//#endregion
@@ -142,9 +138,6 @@
// eslint-disable-next-line no-inner-declarations
function refresh() {
- // Random
- localStorage.setItem('salt', Math.random().toString().substr(2, 8));
-
// Clear cache (service worker)
try {
navigator.serviceWorker.controller.postMessage('clear');
diff --git a/packages/backend/src/server/web/index.ts b/packages/backend/src/server/web/index.ts
index 0b2c62c044..2feee72be7 100644
--- a/packages/backend/src/server/web/index.ts
+++ b/packages/backend/src/server/web/index.ts
@@ -247,7 +247,7 @@ router.get(['/@:user', '/@:user/:sub'], async (ctx, next) => {
icon: meta.iconUrl,
themeColor: meta.themeColor,
});
- ctx.set('Cache-Control', 'public, max-age=30');
+ ctx.set('Cache-Control', 'public, max-age=15');
} else {
// リモートユーザーなので
// モデレータがAPI経由で参照可能にするために404にはしない
@@ -292,7 +292,7 @@ router.get('/notes/:note', async (ctx, next) => {
themeColor: meta.themeColor,
});
- ctx.set('Cache-Control', 'public, max-age=180');
+ ctx.set('Cache-Control', 'public, max-age=15');
return;
}
@@ -329,7 +329,7 @@ router.get('/@:user/pages/:page', async (ctx, next) => {
});
if (['public'].includes(page.visibility)) {
- ctx.set('Cache-Control', 'public, max-age=180');
+ ctx.set('Cache-Control', 'public, max-age=15');
} else {
ctx.set('Cache-Control', 'private, max-age=0, must-revalidate');
}
@@ -360,7 +360,7 @@ router.get('/clips/:clip', async (ctx, next) => {
themeColor: meta.themeColor,
});
- ctx.set('Cache-Control', 'public, max-age=180');
+ ctx.set('Cache-Control', 'public, max-age=15');
return;
}
@@ -385,7 +385,7 @@ router.get('/gallery/:post', async (ctx, next) => {
themeColor: meta.themeColor,
});
- ctx.set('Cache-Control', 'public, max-age=180');
+ ctx.set('Cache-Control', 'public, max-age=15');
return;
}
@@ -409,7 +409,7 @@ router.get('/channels/:channel', async (ctx, next) => {
themeColor: meta.themeColor,
});
- ctx.set('Cache-Control', 'public, max-age=180');
+ ctx.set('Cache-Control', 'public, max-age=15');
return;
}
@@ -468,7 +468,7 @@ router.get('(.*)', async ctx => {
icon: meta.iconUrl,
themeColor: meta.themeColor,
});
- ctx.set('Cache-Control', 'public, max-age=300');
+ ctx.set('Cache-Control', 'public, max-age=15');
});
// Register router
diff --git a/packages/backend/src/server/web/views/base.pug b/packages/backend/src/server/web/views/base.pug
index 69ddb73c0a..230ed1578a 100644
--- a/packages/backend/src/server/web/views/base.pug
+++ b/packages/backend/src/server/web/views/base.pug
@@ -37,6 +37,10 @@ html
link(rel='prefetch' href='https://xn--931a.moe/assets/not-found.jpg')
link(rel='prefetch' href='https://xn--931a.moe/assets/error.jpg')
link(rel='stylesheet' href='/assets/fontawesome/css/all.css')
+ link(rel='modulepreload' href=`/assets/${clientEntry.file}`)
+
+ each href in clientEntry.css
+ link(rel='preload' href=`/assets/${href}` as='style')
each href in clientEntry.css
link(rel='preload' href=`/assets/${href}` as='style')