summary refs log tree commit diff
path: root/src/gateway/opcodes/instanceOf.ts
diff options
context:
space:
mode:
authorMadeline <46743919+MaddyUnderStars@users.noreply.github.com>2022-08-30 15:13:18 +1000
committerMadeline <46743919+MaddyUnderStars@users.noreply.github.com>2022-08-30 15:13:18 +1000
commitc2931f61aa0adb682ab023d85ba599099024d62b (patch)
tree86de9071cbded565fe9e082bd2cc6c611a926c6c /src/gateway/opcodes/instanceOf.ts
parentGuild join messages (diff)
parentOop, deprecated typeorm call (diff)
downloadserver-ts-c2931f61aa0adb682ab023d85ba599099024d62b.tar.xz
Merge branch 'staging' into dev/Maddy/feat/welcomeMessages
Diffstat (limited to 'src/gateway/opcodes/instanceOf.ts')
-rw-r--r--src/gateway/opcodes/instanceOf.ts18
1 files changed, 18 insertions, 0 deletions
diff --git a/src/gateway/opcodes/instanceOf.ts b/src/gateway/opcodes/instanceOf.ts
new file mode 100644

index 00000000..95d74963 --- /dev/null +++ b/src/gateway/opcodes/instanceOf.ts
@@ -0,0 +1,18 @@ +import { WebSocket } from "@fosscord/gateway"; +import { instanceOf } from "@fosscord/util"; +import { CLOSECODES } from "../util/Constants"; + +export function check(this: WebSocket, schema: any, data: any) { + try { + const error = instanceOf(schema, data, { path: "body" }); + if (error !== true) { + throw error; + } + return true; + } catch (error) { + console.error(error); + // invalid payload + this.close(CLOSECODES.Decode_error); + throw error; + } +}