summary refs log tree commit diff
path: root/api/src
diff options
context:
space:
mode:
authorErkin Alp Güney <erkinalp9035@gmail.com>2021-11-28 11:25:41 +0300
committerErkin Alp Güney <erkinalp9035@gmail.com>2021-11-28 11:25:41 +0300
commit73c5141e0557fac183f074cac2c6254a1227d316 (patch)
treebb3f59ba61bbfe2e7b8e99cb95ae53b2ac1a250b /api/src
parentMerge pull request #515 from Featyre/master (diff)
downloadserver-73c5141e0557fac183f074cac2c6254a1227d316.tar.xz
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 +}