summary refs log tree commit diff
path: root/api/src
diff options
context:
space:
mode:
authorSamuel <34555296+Flam3rboy@users.noreply.github.com>2021-11-29 20:41:59 +0100
committerGitHub <noreply@github.com>2021-11-29 20:41:59 +0100
commitaf1411806e794ca045427623b369bc37e63f31ee (patch)
tree7312d9467581008345bf8f62b66c38f43e44688d /api/src
parentMerge pull request #518 from Xenorio/master (diff)
parentsnowflake-based invite generation (diff)
downloadserver-af1411806e794ca045427623b369bc37e63f31ee.tar.xz
Merge pull request #519 from erkinalp/master
Snowflake-based invite generation
Diffstat (limited to 'api/src')
-rw-r--r--api/src/util/RandomInviteID.ts19
1 files changed, 19 insertions, 0 deletions
diff --git a/api/src/util/RandomInviteID.ts b/api/src/util/RandomInviteID.ts

index b37994d8..45450b0d 100644 --- a/api/src/util/RandomInviteID.ts +++ b/api/src/util/RandomInviteID.ts
@@ -1,3 +1,5 @@ +import { Snowflake } from "@fosscord/util"; + export function random(length = 6) { // Declare all characters let chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"; @@ -10,3 +12,20 @@ export function random(length = 6) { return str; } + +export function snowflakeBasedInvite() { + // Declare all characters + let chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"; + + let snowflake = Snowflake.generateWorkerProcess(); + + // snowflakes hold ~10.75 characters worth of entropy; + // safe to generate a 8-char invite out of them + let str = ""; + for (let i=0; i < 10; i++) { + str += chars.charAt((snowflake % chars.length)); + snowflake /= chars.length; + } + + return str.substr(3,8).reverse(); // little-endianise for entropy +}