summary refs log tree commit diff
path: root/api/src/util/handlers/Instance.ts
diff options
context:
space:
mode:
authorMadeline <46743919+MaddyUnderStars@users.noreply.github.com>2022-01-03 23:00:29 +1100
committerGitHub <noreply@github.com>2022-01-03 23:00:29 +1100
commit3f226340335e4610a93c9f2bc349c445b2ef8c0b (patch)
tree25dd4d9812637180c44b3a79acd6b1c761630620 /api/src/util/handlers/Instance.ts
parentCleaned up tsconfig.json a bit ( moved tsnode config to own file ). (diff)
parentFix schemas handler (diff)
downloadserver-3f226340335e4610a93c9f2bc349c445b2ef8c0b.tar.xz
Merge branch 'fosscord:master' into master
Diffstat (limited to 'api/src/util/handlers/Instance.ts')
-rw-r--r--api/src/util/handlers/Instance.ts21
1 files changed, 21 insertions, 0 deletions
diff --git a/api/src/util/handlers/Instance.ts b/api/src/util/handlers/Instance.ts
new file mode 100644

index 00000000..6bddfa98 --- /dev/null +++ b/api/src/util/handlers/Instance.ts
@@ -0,0 +1,21 @@ +import { Config, Guild, Session } from "@fosscord/util"; + +export async function initInstance() { + // TODO: clean up database and delete tombstone data + // TODO: set first user as instance administrator/or generate one if none exists and output it in the terminal + + // create default guild and add it to auto join + // TODO: check if any current user is not part of autoJoinGuilds + const { autoJoin } = Config.get().guild; + + if (autoJoin.enabled && !autoJoin.guilds?.length) { + let guild = await Guild.findOne({}); + if (guild) { + // @ts-ignore + await Config.set({ guild: { autoJoin: { guilds: [guild.id] } } }); + } + } + + // TODO: do no clear sessions for instance cluster + await Session.delete({}); +}