summaryrefslogtreecommitdiffhomepage
path: root/packages/shared/src/util/identifier.ts
diff options
context:
space:
mode:
authorDax <[email protected]>2026-04-25 10:59:17 -0400
committerGitHub <[email protected]>2026-04-25 10:59:17 -0400
commit62ef2a220723a6d6cb050e523fcdfaa974dafdda (patch)
tree214b03d016e18e4d8fe1bfc7209c1edd86547bbd /packages/shared/src/util/identifier.ts
parent37aa8442dc023fad250f2573c8235a544789900c (diff)
downloadopencode-62ef2a220723a6d6cb050e523fcdfaa974dafdda.tar.gz
opencode-62ef2a220723a6d6cb050e523fcdfaa974dafdda.zip
refactor: rename shared package to core (#24309)
Diffstat (limited to 'packages/shared/src/util/identifier.ts')
-rw-r--r--packages/shared/src/util/identifier.ts48
1 files changed, 0 insertions, 48 deletions
diff --git a/packages/shared/src/util/identifier.ts b/packages/shared/src/util/identifier.ts
deleted file mode 100644
index ba28a351b..000000000
--- a/packages/shared/src/util/identifier.ts
+++ /dev/null
@@ -1,48 +0,0 @@
-import { randomBytes } from "crypto"
-
-export namespace Identifier {
- const LENGTH = 26
-
- // State for monotonic ID generation
- let lastTimestamp = 0
- let counter = 0
-
- export function ascending() {
- return create(false)
- }
-
- export function descending() {
- return create(true)
- }
-
- function randomBase62(length: number): string {
- const chars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"
- let result = ""
- const bytes = randomBytes(length)
- for (let i = 0; i < length; i++) {
- result += chars[bytes[i] % 62]
- }
- return result
- }
-
- export function create(descending: boolean, timestamp?: number): string {
- const currentTimestamp = timestamp ?? Date.now()
-
- if (currentTimestamp !== lastTimestamp) {
- lastTimestamp = currentTimestamp
- counter = 0
- }
- counter++
-
- let now = BigInt(currentTimestamp) * BigInt(0x1000) + BigInt(counter)
-
- now = descending ? ~now : now
-
- const timeBytes = Buffer.alloc(6)
- for (let i = 0; i < 6; i++) {
- timeBytes[i] = Number((now >> BigInt(40 - 8 * i)) & BigInt(0xff))
- }
-
- return timeBytes.toString("hex") + randomBase62(LENGTH - 12)
- }
-}