summary refs log tree commit diff
path: root/src/util/Config.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/util/Config.ts')
-rw-r--r--src/util/Config.ts177
1 files changed, 159 insertions, 18 deletions
diff --git a/src/util/Config.ts b/src/util/Config.ts

index 4b644e2f..be0f4a3b 100644 --- a/src/util/Config.ts +++ b/src/util/Config.ts
@@ -1,25 +1,166 @@ -import "missing-native-js-functions"; -import db from "./Database"; -import { DefaultOptions } from "./Constants"; -import { ProviderCache } from "lambert-db"; -var Config: ProviderCache; +import { Config } from "discord-server-util"; +import crypto from "crypto"; +import fs from "fs"; -async function init() { - Config = db.data.config({}).cache(); - await Config.init(); - await Config.set(DefaultOptions.merge(Config.cache || {})); -} +export default { + init() { + return Config.init({ api: DefaultOptions }); + }, + get() { + return Config.getAll().api; + }, + set(val: any) { + return Config.setAll({ api: val }); + }, + getAll: Config.getAll, + setAll: Config.setAll, +}; -function get() { - return <DefaultOptions>Config.get(); +export interface RateLimit { + count: number; + timespan: number; } -function set(val: any) { - return Config.set(val); +export interface DefaultOptions { + limits: { + user: { + maxGuilds: number; + maxUsername: number; + maxFriends: number; + }; + guild: { + maxRoles: number; + maxMembers: number; + maxChannels: number; + maxChannelsInCategory: number; + hideOfflineMember: number; + }; + message: { + characters: number; + ttsCharacters: number; + maxReactions: number; + maxAttachmentSize: number; + }; + channel: { + maxPins: number; + maxTopic: number; + }; + rate: { + ip: { + enabled: boolean; + count: number; + timespan: number; + }; + routes: { + auth?: { + login?: RateLimit; + register?: RateLimit; + }; + channel?: {}; + // TODO: rate limit configuration for all routes + }; + }; + }; + security: { + jwtSecret: string; + forwadedFor: string | null; + captcha: { + enabled: boolean; + service: "recaptcha" | null; // TODO: hcaptcha, custom + sitekey: string | null; + }; + }; + register: { + email: { + required: boolean; + allowlist: boolean; + blocklist: boolean; + domains: string[]; + }; + dateOfBirth: { + required: boolean; + minimum: number; // in years + }; + requireCaptcha: boolean; + requireInvite: boolean; + allowNewRegistration: boolean; + allowMultipleAccounts: boolean; + password: { + minLength: number; + minNumbers: number; + minUpperCase: number; + minSymbols: number; + blockInsecureCommonPasswords: boolean; // TODO: efficiently save password blocklist in database + }; + }; } -export default { - init, - get: get, - set: set, +export const DefaultOptions: DefaultOptions = { + limits: { + user: { + maxGuilds: 100, + maxUsername: 32, + maxFriends: 1000, + }, + guild: { + maxRoles: 250, + maxMembers: 250000, + maxChannels: 500, + maxChannelsInCategory: 50, + hideOfflineMember: 1000, + }, + message: { + characters: 2000, + ttsCharacters: 200, + maxReactions: 20, + maxAttachmentSize: 8388608, + }, + channel: { + maxPins: 50, + maxTopic: 1024, + }, + rate: { + ip: { + enabled: true, + count: 1000, + timespan: 1000 * 60 * 10, + }, + routes: {}, + }, + }, + security: { + jwtSecret: crypto.randomBytes(256).toString("base64"), + forwadedFor: null, + // forwadedFor: "X-Forwarded-For" // nginx/reverse proxy + // forwadedFor: "CF-Connecting-IP" // cloudflare: + captcha: { + enabled: false, + service: null, + sitekey: null, + }, + }, + register: { + email: { + required: true, + allowlist: false, + blocklist: true, + domains: [], // TODO: efficiently save domain blocklist in database + // domains: fs.readFileSync(__dirname + "/blockedEmailDomains.txt", { encoding: "utf8" }).split("\n"), + }, + dateOfBirth: { + required: true, + minimum: 13, + }, + requireInvite: false, + requireCaptcha: true, + allowNewRegistration: true, + allowMultipleAccounts: true, + password: { + minLength: 8, + minNumbers: 2, + minUpperCase: 2, + minSymbols: 0, + blockInsecureCommonPasswords: false, + }, + }, };