The globally unique ID for the modern software. Fully configurable. Stripe inspired.
Prefix := user defined string
Timestamp := base62(unix time - 2024-01-01), T: default is 5 digits.
Random := base62(N length of random digits), N: default is 12
Checksum := base62(C length of checksum digits), C: default is 2
Total length = Prefix + T + N + C
- Human-readable prefix
- More compact than UUID while maintaining collision resistance
- when random digits length is 16, total length is near 26 bytes
- shorter than UUID, the same collision resistance with UUID.
- B-tree optimized with built-in timestamps
- Built-in checksum verification
- Detects errors with a probability of 99.97%
- Cryptographically random
- URL friendly with base62 encoding
- Fully configurable
- prefix: any string
- delimiter: any single character
- timestamp length: 4 ~ 6
- checksum length: 1 ~ 3
- checksum token: any 64-bit integer
- random digits length: 1 ~ 16
import "github.com/RyosukeCla/sleekid"
// Setup generator, before using sleekid.
sleekid.Setup(sleekid.GeneratorInit{
// Change this token on your production environment.
// and keep it secret.
ChecksumToken: 729823908348,
// Optional
RandomDigitsLength: 12,
Delimiter: '_',
ChecksumLength: 2,
TimestampLength: 5,
})
// Generate id.
id, err := sleekid.New("usr")
// Generate id with custom random digits length
id, err := sleekid.New("usr", sleekid.WithRandomDigits(27))
// Validate id.
sleekid.Validate(id)
sleekid.ValidateWithPrefix("usr", id)
// Get Prefix
prefix := sleekid.Prefix(id)
// Get Timestamp
timestamp := sleekid.Timestamp(id)
// Custom Generator
gen := sleekid.NewGenerator(sleekid.GeneratorInit{
// ...
})
id, err := gen.New("usr")
gen.Validate(id)
timestamp part with 4 ~ 6 digits.
- Each character: 62 possibilities (0-9, a-z, A-Z)
- 6 digits: 62^6 ≈ 56.8 quadrillion combinations
random digits part with N length
- Each character: 62 possibilities (0-9, a-z, A-Z)
- N characters: 62^N possible combinations
- For N=12: 62^12 ≈ 3.22 × 10^21 combinations
total space
- Combined unique possibilities: 62^6 * 62^N = 62^(6+N)
- For N=12: 62^18 ≈ 1.83 × 10^32 combinations
For a 50% collision probability:
- √(π/2 * 62^N) attempts needed
- For N=12: √(π/2 * 62^12) ≈ 2.8 trillion attempts
- Tamper detection probability is 99.97% when checksum length is 2 digits
- where 1 - 1/62^2 ≈ 0.9997
- This helps to prevent brute-force attacks / DDoS / etc.
- For small scale systems (<100K IDs/day): N=10
- For medium scale systems (<10M IDs/day): N=12
- For large scale systems (>10M IDs/day): N=14
- For extreme scale systems (>1B IDs/day): N=16
$ go test -bench . -benchmem
goos: darwin
goarch: arm64
pkg: github.com/RyosukeCla/sleekid
cpu: Apple M1 Max
BenchmarkNew-10 2786331 424.1 ns/op 96 B/op 5 allocs/op
BenchmarkPrefix-10 50602398 22.73 ns/op 16 B/op 2 allocs/op
BenchmarkTimestamp-10 28589920 41.83 ns/op 0 B/op 0 allocs/op
BenchmarkValidate-10 29047572 40.60 ns/op 2 B/op 1 allocs/op
BenchmarkValidateWithPrefix-10 26366164 44.81 ns/op 2 B/op 1 allocs/op
BenchmarkNewUUID-10 4284284 282.4 ns/op 16 B/op 1 allocs/op
BenchmarkNewXid-10 24377856 47.75 ns/op 0 B/op 0 allocs/op