diff options
author | Madeline <46743919+MaddyUnderStars@users.noreply.github.com> | 2022-08-30 15:13:18 +1000 |
---|---|---|
committer | Madeline <46743919+MaddyUnderStars@users.noreply.github.com> | 2022-08-30 15:13:18 +1000 |
commit | c2931f61aa0adb682ab023d85ba599099024d62b (patch) | |
tree | 86de9071cbded565fe9e082bd2cc6c611a926c6c /src/api/util/handlers/Instance.ts | |
parent | Guild join messages (diff) | |
parent | Oop, deprecated typeorm call (diff) | |
download | server-c2931f61aa0adb682ab023d85ba599099024d62b.tar.xz |
Merge branch 'staging' into dev/Maddy/feat/welcomeMessages
Diffstat (limited to 'src/api/util/handlers/Instance.ts')
-rw-r--r-- | src/api/util/handlers/Instance.ts | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/src/api/util/handlers/Instance.ts b/src/api/util/handlers/Instance.ts new file mode 100644 index 00000000..e03c9488 --- /dev/null +++ b/src/api/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({ where: {}, order: { id: "ASC" } }); + if (guild) { + // @ts-ignore + await Config.set({ guild: { autoJoin: { guilds: [guild.id] } } }); + } + } + + // TODO: do no clear sessions for instance cluster + await Session.delete({}); +} |