aboutsummaryrefslogtreecommitdiffhomepage
path: root/services/nuldoc/nuldoc-src/config.ts
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2025-11-02 17:49:34 +0900
committernsfisis <nsfisis@gmail.com>2025-11-02 17:49:34 +0900
commit57315c52be96d2a2c013f0cfb0de5429980e301a (patch)
tree5d691497772fddfe401cd970ead4e9a74b34ef38 /services/nuldoc/nuldoc-src/config.ts
parentcf4091a93ed831456e8b30e2a9e1fc2650dcae02 (diff)
downloadnsfisis.dev-57315c52be96d2a2c013f0cfb0de5429980e301a.tar.gz
nsfisis.dev-57315c52be96d2a2c013f0cfb0de5429980e301a.tar.zst
nsfisis.dev-57315c52be96d2a2c013f0cfb0de5429980e301a.zip
refactor(blog): rename directory, services/{blog => nuldoc}/
Diffstat (limited to 'services/nuldoc/nuldoc-src/config.ts')
-rw-r--r--services/nuldoc/nuldoc-src/config.ts41
1 files changed, 41 insertions, 0 deletions
diff --git a/services/nuldoc/nuldoc-src/config.ts b/services/nuldoc/nuldoc-src/config.ts
new file mode 100644
index 0000000..adcb563
--- /dev/null
+++ b/services/nuldoc/nuldoc-src/config.ts
@@ -0,0 +1,41 @@
+import { join } from "@std/path";
+import { parse as parseToml } from "@std/toml";
+import { z } from "zod/mod.ts";
+
+const ConfigSchema = z.object({
+ locations: z.object({
+ contentDir: z.string(),
+ destDir: z.string(),
+ staticDir: z.string(),
+ }),
+ rendering: z.object({
+ html: z.object({
+ indentWidth: z.number(),
+ }),
+ }),
+ blog: z.object({
+ author: z.string(),
+ fqdn: z.string(),
+ siteName: z.string(),
+ siteCopyrightYear: z.number(),
+ postsPerPage: z.number().default(10),
+ tagLabels: z.record(z.string(), z.string()),
+ }),
+});
+
+export type Config = z.infer<typeof ConfigSchema>;
+
+export function getTagLabel(c: Config, slug: string): string {
+ if (!(slug in c.blog.tagLabels)) {
+ throw new Error(`Unknown tag: ${slug}`);
+ }
+ return c.blog.tagLabels[slug];
+}
+
+export function getDefaultConfigPath(): string {
+ return join(Deno.cwd(), "nuldoc.toml");
+}
+
+export async function loadConfig(filePath: string): Promise<Config> {
+ return ConfigSchema.parse(parseToml(await Deno.readTextFile(filePath)));
+}