summaryrefslogtreecommitdiff
path: root/src/misc/id
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2019-04-14 01:08:26 +0900
committersyuilo <syuilotan@yahoo.co.jp>2019-04-14 01:08:26 +0900
commite64912545a61b89ecff5f300d2a36f7f9cfa1fdd (patch)
treeb66c0b25d93d7c08b9684a601a21714920fc275f /src/misc/id
parent11.0.0-beta.11 (diff)
downloadsharkey-e64912545a61b89ecff5f300d2a36f7f9cfa1fdd.tar.gz
sharkey-e64912545a61b89ecff5f300d2a36f7f9cfa1fdd.tar.bz2
sharkey-e64912545a61b89ecff5f300d2a36f7f9cfa1fdd.zip
Update id generation methods
Diffstat (limited to 'src/misc/id')
-rw-r--r--src/misc/id/aid.ts23
-rw-r--r--src/misc/id/object-id.ts26
2 files changed, 49 insertions, 0 deletions
diff --git a/src/misc/id/aid.ts b/src/misc/id/aid.ts
new file mode 100644
index 0000000000..7ab0a148eb
--- /dev/null
+++ b/src/misc/id/aid.ts
@@ -0,0 +1,23 @@
+// AID
+// 長さ8の[2000年1月1日からの経過ミリ秒をbase36でエンコードしたもの] + 長さ2の[ノイズ文字列]
+
+import * as cluster from 'cluster';
+
+const TIME2000 = 946684800000;
+let counter = process.pid + (cluster.isMaster ? 0 : cluster.worker.id);
+
+function getTime(time: number) {
+ time = time - TIME2000;
+ if (time < 0) time = 0;
+
+ return time.toString(36).padStart(8, '0');
+}
+
+function getRandom() {
+ return counter.toString(36).padStart(length, '0').substr(2);
+}
+
+export function genAid(date: Date): string {
+ counter++;
+ return getTime(date.getTime()) + getRandom();
+}
diff --git a/src/misc/id/object-id.ts b/src/misc/id/object-id.ts
new file mode 100644
index 0000000000..392ea43301
--- /dev/null
+++ b/src/misc/id/object-id.ts
@@ -0,0 +1,26 @@
+const CHARS = '0123456789abcdef';
+
+function getTime(time: number) {
+ if (time < 0) time = 0;
+ if (time === 0) {
+ return CHARS[0];
+ }
+
+ time = Math.floor(time / 1000);
+
+ return time.toString(16).padStart(8, CHARS[0]);
+}
+
+function getRandom() {
+ let str = '';
+
+ for (let i = 0; i < 16; i++) {
+ str += CHARS[Math.floor(Math.random() * CHARS.length)];
+ }
+
+ return str;
+}
+
+export function genObjectId(date: Date): string {
+ return getTime(date.getTime()) + getRandom();
+}