Compare commits

..

4 Commits

Author SHA1 Message Date
monoid
9ea7f880f3 chore 2024-04-16 21:27:31 +09:00
monoid
4db00f3482 serve assets 2024-04-16 21:27:25 +09:00
monoid
dcafbada0d chore: ignore comic_config 2024-04-16 21:26:59 +09:00
monoid
0f233183ac fix: close before streaming 2024-04-16 21:24:27 +09:00
6 changed files with 43 additions and 44 deletions

2
.gitignore vendored
View File

@ -12,6 +12,8 @@ db.sqlite3
build/**
app/**
settings.json
comic_config.json
**/comic_config.json
.pnpm-store/**
.env

View File

@ -1,3 +0,0 @@
{
"watch": ["testdata"]
}

View File

@ -1,17 +0,0 @@
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8">
<title>Ionian</title>
<meta http-equiv="Content-Security-Policy" content="default-src 'self'; script-src 'self'; style-src 'self' 'unsafe-inline' fonts.googleapis.com;
font-src 'self' fonts.gstatic.com">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="stylesheet" href="/dist/bundle.css">
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700&display=swap" />
<!--MetaTag-Outlet-->
</head>
<body>
<div id="root"></div>
<script src="/dist/bundle.js"></script>
</body>
</html>

View File

@ -6,7 +6,7 @@
"scripts": {
"compile": "swc src --out-dir dist",
"dev": "nodemon -r @swc-node/register --enable-source-maps --exec node app.ts",
"start": "node build/app.js"
"start": "node dist/app.js"
},
"author": "",
"license": "ISC",

View File

@ -94,11 +94,15 @@ async function renderZipImage(ctx: Context, path: string, page: number) {
},
}));
nodeReadableStream.on("error", (err) => {
console.error(err);
releaseZip(path);
console.error("readalbe stream error",err);
setTimeout(()=>{
releaseZip(path)
},100);
});
nodeReadableStream.on("close", () => {
setTimeout(()=>{
releaseZip(path);
},100);
});
ctx.body = nodeReadableStream;

View File

@ -18,6 +18,7 @@ import type { DocumentAccessor, TagAccessor, UserAccessor } from "./model/mod";
import { getTagRounter } from "./route/tags";
import { config } from "dotenv";
import { extname, join } from "node:path";
config();
class ServerApplication {
@ -38,7 +39,7 @@ class ServerApplication {
this.diffManger = new DiffManager(this.documentController);
this.app = new Koa();
this.index_html = readFileSync("index.html", "utf-8");
this.index_html = readFileSync("dist/index.html", "utf-8");
}
private async setup() {
const setting = get_setting();
@ -195,26 +196,38 @@ class ServerApplication {
}
}
private serve_static_file(router: Router) {
const static_file_server = (path: string, type: string) => {
router.get(`/${path}`, async (ctx, next) => {
const setting = get_setting();
ctx.type = type;
ctx.body = createReadStream(path);
ctx.set("x-content-type-options", "no-sniff");
if (setting.mode === "development") {
ctx.set("cache-control", "no-cache");
} else {
ctx.set("cache-control", "public, max-age=3600");
}
});
};
const setting = get_setting();
static_file_server("dist/bundle.css", "css");
static_file_server("dist/bundle.js", "js");
if (setting.mode === "development") {
static_file_server("dist/bundle.js.map", "text");
static_file_server("dist/bundle.css.map", "text");
}
router.get("/assets/(.*)", async (ctx, next) => {
const setting = get_setting();
const ext = extname(ctx.path);
ctx.type = ext;
ctx.body = createReadStream(join("dist",`.${ctx.path}`));
ctx.set("x-content-type-options", "no-sniff");
if (setting.mode === "development") {
ctx.set("cache-control", "no-cache");
} else {
ctx.set("cache-control", "public, max-age=3600");
}
});
// const static_file_server = (path: string, type: string) => {
// router.get(`/${path}`, async (ctx, next) => {
// const setting = get_setting();
// ctx.type = type;
// ctx.body = createReadStream(path);
// ctx.set("x-content-type-options", "no-sniff");
// if (setting.mode === "development") {
// ctx.set("cache-control", "no-cache");
// } else {
// ctx.set("cache-control", "public, max-age=3600");
// }
// });
// };
// const setting = get_setting();
// static_file_server("dist/bundle.css", "css");
// static_file_server("dist/bundle.js", "js");
// if (setting.mode === "development") {
// static_file_server("dist/bundle.js.map", "text");
// static_file_server("dist/bundle.css.map", "text");
// }
}
start_server() {
const setting = get_setting();