summary refs log tree commit diff
path: root/util/src/entities/Session.ts
diff options
context:
space:
mode:
authorFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-09-02 20:20:15 +0200
committerGitHub <noreply@github.com>2021-09-02 20:20:15 +0200
commit6cd7d7230e8918ff292e7a48f1b7426d0e53e6ca (patch)
tree46fd326a827a2586428a8e4fca951e9f5366120a /util/src/entities/Session.ts
parent:art: update openapi title (diff)
parent:sparkles: add editor config (diff)
downloadserver-6cd7d7230e8918ff292e7a48f1b7426d0e53e6ca.tar.xz
Merge pull request #306 from AlTech98/master
Gateway VOICE_STATE_UPDATE and sessions implementation, fix #210
Diffstat (limited to '')
-rw-r--r--util/src/entities/Session.ts32
1 files changed, 32 insertions, 0 deletions
diff --git a/util/src/entities/Session.ts b/util/src/entities/Session.ts
new file mode 100644

index 00000000..d42a8f98 --- /dev/null +++ b/util/src/entities/Session.ts
@@ -0,0 +1,32 @@ +import { User } from "./User"; +import { BaseClass } from "./BaseClass"; +import { Column, Entity, JoinColumn, ManyToOne, RelationId } from "typeorm"; + +//TODO we need to remove all sessions on server start because if the server crashes without closing websockets it won't delete them + +@Entity("sessions") +export class Session extends BaseClass { + @Column({ nullable: true }) + @RelationId((session: Session) => session.user) + user_id: string; + + @JoinColumn({ name: "user_id" }) + @ManyToOne(() => User) + user: User; + + //TODO check, should be 32 char long hex string + @Column({ nullable: false }) + session_id: string; + + activities: []; //TODO + + @Column({ type: "simple-json", select: false }) + client_info: { + client: string; + os: string; + version: number; + }; + + @Column({ nullable: false }) + status: string; //TODO enum +}