iceshrimp/packages/backend/src/config/load.ts

100 lines
2.8 KiB
TypeScript
Raw Normal View History

2018-04-02 06:15:53 +02:00
/**
* Config loader
*/
2023-01-13 05:40:33 +01:00
import * as fs from "node:fs";
import { fileURLToPath } from "node:url";
import { dirname } from "node:path";
import * as yaml from "js-yaml";
import type { Source, Mixin } from "./types.js";
import Path from "node:path";
import parseDuration from 'parse-duration'
export default function load() {
const _filename = fileURLToPath(import.meta.url);
const _dirname = dirname(_filename);
2018-04-02 06:15:53 +02:00
const dir = `${_dirname}/../../../..`;
const {
ICESHRIMP_CONFIG: configFile,
ICESHRIMP_SECRETS: secretsFile,
ICESHRIMP_MEDIA_DIR: mediaDir,
} = process.env;
2018-04-02 06:15:53 +02:00
const path =
process.env.NODE_ENV === "test"
? `${dir}/.config/test.yml`
: configFile ?? `${dir}/.config/default.yml`;
2018-04-02 06:15:53 +02:00
2023-01-13 05:40:33 +01:00
const meta = JSON.parse(
fs.readFileSync(`${_dirname}/../../../../built/meta.json`, "utf-8"),
);
const clientManifest = JSON.parse(
fs.readFileSync(
`${_dirname}/../../../../built/_client_dist_/manifest.json`,
"utf-8",
),
);
let config = yaml.load(fs.readFileSync(path, "utf-8")) as Source;
if (secretsFile !== undefined)
config = Object.assign(config, yaml.load(fs.readFileSync(secretsFile, "utf-8")) as Source);
2018-04-02 06:15:53 +02:00
const mixin = {} as Mixin;
2018-04-02 06:15:53 +02:00
2019-04-09 17:40:10 +02:00
const url = tryCreateUrl(config.url);
2019-04-09 17:40:10 +02:00
config.url = url.origin;
2023-01-13 05:40:33 +01:00
config.port = config.port || parseInt(process.env.PORT || "", 10);
config.images = {
info: '/twemoji/1f440.svg',
notFound: '/twemoji/2049.svg',
error: '/twemoji/1f480.svg',
...config.images,
};
config.htmlCache = {
ttlSeconds: parseDuration(config.htmlCache?.ttl ?? '1h', 's')!,
prewarm: false,
dbFallback: false,
...config.htmlCache,
}
if (config.htmlCache.ttlSeconds == null) throw new Error('Failed to parse config.htmlCache.ttl');
config.wordMuteCache = {
ttlSeconds: parseDuration(config.wordMuteCache?.ttl ?? '24h', 's')!,
}
if (config.wordMuteCache.ttlSeconds == null) throw new Error('Failed to parse config.wordMuteCache.ttl');
config.searchEngine = config.searchEngine ?? 'https://duckduckgo.com/?q=';
mixin.version = meta.version;
2019-04-09 17:40:10 +02:00
mixin.host = url.host;
mixin.hostname = url.hostname;
mixin.domain = config.accountDomain ?? url.host;
2023-01-13 05:40:33 +01:00
mixin.scheme = url.protocol.replace(/:$/, "");
mixin.wsScheme = mixin.scheme.replace("http", "ws");
2019-02-24 04:53:22 +01:00
mixin.wsUrl = `${mixin.wsScheme}://${mixin.host}`;
mixin.apiUrl = `${mixin.scheme}://${mixin.host}/api`;
mixin.authUrl = `${mixin.scheme}://${mixin.host}/auth`;
mixin.driveUrl = `${mixin.scheme}://${mixin.host}/files`;
mixin.userAgent = `Iceshrimp/${meta.version} (${config.url})`;
2023-01-13 05:40:33 +01:00
mixin.clientEntry = clientManifest["src/init.ts"];
mixin.mediaDir = mediaDir ?? `${dir}/files`;
if (!config.redis.prefix) config.redis.prefix = mixin.hostname;
return Object.assign(config, mixin);
2018-04-02 06:15:53 +02:00
}
2019-02-06 05:37:20 +01:00
function tryCreateUrl(url: string) {
2019-02-03 16:09:24 +01:00
try {
return new URL(url);
} catch (e) {
2022-08-04 11:00:02 +02:00
throw new Error(`url="${url}" is not a valid URL.`);
2019-02-03 16:09:24 +01:00
}
}