2021-02-05 16:24:51 +01:00
|
|
|
import { Config } from "discord-server-util";
|
|
|
|
import crypto from "crypto";
|
|
|
|
import fs from "fs";
|
2021-01-30 19:58:15 +01:00
|
|
|
|
2021-02-05 16:24:51 +01:00
|
|
|
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,
|
|
|
|
};
|
2021-01-30 19:58:15 +01:00
|
|
|
|
2021-02-05 16:24:51 +01:00
|
|
|
export interface RateLimit {
|
|
|
|
count: number;
|
|
|
|
timespan: number;
|
2021-01-30 19:58:15 +01:00
|
|
|
}
|
|
|
|
|
2021-02-05 16:24:51 +01:00
|
|
|
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
|
|
|
|
};
|
|
|
|
};
|
2021-01-30 19:58:15 +01:00
|
|
|
}
|
|
|
|
|
2021-02-05 16:24:51 +01:00
|
|
|
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,
|
|
|
|
},
|
|
|
|
},
|
2021-01-30 19:58:15 +01:00
|
|
|
};
|