summary refs log tree commit diff
path: root/util/src/entities/Invite.ts
diff options
context:
space:
mode:
authorChris Chrome <christophercookman@gmail.com>2021-09-20 11:45:13 -0400
committerChris Chrome <christophercookman@gmail.com>2021-09-20 11:45:13 -0400
commit86cbd18ba497db84670859b553b2031062fd3988 (patch)
tree28bb21e9f525642fec5e4a1fb77dda1a3a4cd18b /util/src/entities/Invite.ts
parentFix one thing, another problem pops up (diff)
parentMerge branch 'master' of https://github.com/fosscord/fosscord-api (diff)
downloadserver-86cbd18ba497db84670859b553b2031062fd3988.tar.xz
Merge remote-tracking branch 'origin/master'
Diffstat (limited to '')
-rw-r--r--util/src/entities/Invite.ts10
1 files changed, 10 insertions, 0 deletions
diff --git a/util/src/entities/Invite.ts b/util/src/entities/Invite.ts

index afad9c02..1396004e 100644 --- a/util/src/entities/Invite.ts +++ b/util/src/entities/Invite.ts
@@ -1,4 +1,5 @@ import { Column, Entity, JoinColumn, ManyToOne, PrimaryColumn, RelationId } from "typeorm"; +import { Member } from "."; import { BaseClass } from "./BaseClass"; import { Channel } from "./Channel"; import { Guild } from "./Guild"; @@ -63,4 +64,13 @@ export class Invite extends BaseClass { @Column({ nullable: true }) target_user_type?: number; + + static async joinGuild(user_id: string, code: string) { + const invite = await Invite.findOneOrFail({ code }); + if (invite.uses++ >= invite.max_uses && invite.max_uses !== 0) await Invite.delete({ code }); + else await invite.save(); + + await Member.addToGuild(user_id, invite.guild_id); + return invite; + } }