summary refs log tree commit diff
path: root/util/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 /util/src
parentMerge pull request #515 from Featyre/master (diff)
downloadserver-73c5141e0557fac183f074cac2c6254a1227d316.tar.xz
snowflake-based invite generation
Diffstat (limited to '')
-rw-r--r--util/src/util/Snowflake.ts11
1 files changed, 7 insertions, 4 deletions
diff --git a/util/src/util/Snowflake.ts b/util/src/util/Snowflake.ts

index 3f6e3c63..134d526e 100644 --- a/util/src/util/Snowflake.ts +++ b/util/src/util/Snowflake.ts
@@ -21,7 +21,7 @@ export class Snowflake { } /** - * A Twitter snowflake, except the epoch is 2015-01-01T00:00:00.000Z + * A Twitter-like snowflake, except the epoch is 2015-01-01T00:00:00.000Z * ``` * If we have a snowflake '266241948824764416' we can represent it as binary: * @@ -83,14 +83,17 @@ export class Snowflake { return dec; } - static generate() { + static generateWorkerProcess() { // worker process - returns a number var time = BigInt(Date.now() - Snowflake.EPOCH) << BigInt(22); var worker = Snowflake.workerId << 17n; var process = Snowflake.processId << 12n; var increment = Snowflake.INCREMENT++; - return (time | worker | process | increment).toString(); + return BigInt(time | worker | process | increment); + } + + static generate() { + return Snowflake.generateWorkerProcess().toString(); } - /** * A deconstructed snowflake. * @typedef {Object} DeconstructedSnowflake