nanoid 3.1.30 → 3.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -3,7 +3,7 @@
3
3
  <img src="https://ai.github.io/nanoid/logo.svg" align="right"
4
4
  alt="Nano ID logo by Anton Lovchikov" width="180" height="94">
5
5
 
6
- **English** | [Русский](./README.ru.md) | [简体中文](./README.zh-CN.md)
6
+ **English** | [Русский](./README.ru.md) | [简体中文](./README.zh-CN.md) | [Bahasa Indonesia](./README.id-ID.md)
7
7
 
8
8
  A tiny, secure, URL-friendly, unique string ID generator for JavaScript.
9
9
 
@@ -17,7 +17,7 @@ A tiny, secure, URL-friendly, unique string ID generator for JavaScript.
17
17
  * **Short IDs.** It uses a larger alphabet than UUID (`A-Za-z0-9_-`).
18
18
  So ID size was reduced from 36 to 21 symbols.
19
19
  * **Portable.** Nano ID was ported
20
- to [19 programming languages](#other-programming-languages).
20
+ to [20 programming languages](#other-programming-languages).
21
21
 
22
22
  ```js
23
23
  import { nanoid } from 'nanoid'
@@ -1,21 +1,20 @@
1
- let random = bytes =>
2
- Promise.resolve(crypto.getRandomValues(new Uint8Array(bytes)))
3
- let customAlphabet = (alphabet, size) => {
1
+ let random = async bytes => crypto.getRandomValues(new Uint8Array(bytes))
2
+ let customAlphabet = (alphabet, defaultSize = 21) => {
4
3
  let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1
5
- let step = -~((1.6 * mask * size) / alphabet.length)
6
- return () => {
4
+ let step = -~((1.6 * mask * defaultSize) / alphabet.length)
5
+ return async (size = defaultSize) => {
7
6
  let id = ''
8
7
  while (true) {
9
8
  let bytes = crypto.getRandomValues(new Uint8Array(step))
10
9
  let i = step
11
10
  while (i--) {
12
11
  id += alphabet[bytes[i] & mask] || ''
13
- if (id.length === size) return Promise.resolve(id)
12
+ if (id.length === size) return id
14
13
  }
15
14
  }
16
15
  }
17
16
  }
18
- let nanoid = (size = 21) => {
17
+ let nanoid = async (size = 21) => {
19
18
  let id = ''
20
19
  let bytes = crypto.getRandomValues(new Uint8Array(size))
21
20
  while (size--) {
@@ -30,6 +29,6 @@ let nanoid = (size = 21) => {
30
29
  id += '-'
31
30
  }
32
31
  }
33
- return Promise.resolve(id)
32
+ return id
34
33
  }
35
34
  module.exports = { nanoid, customAlphabet, random }
@@ -1,21 +1,20 @@
1
- let random = bytes =>
2
- Promise.resolve(crypto.getRandomValues(new Uint8Array(bytes)))
3
- let customAlphabet = (alphabet, size) => {
1
+ let random = async bytes => crypto.getRandomValues(new Uint8Array(bytes))
2
+ let customAlphabet = (alphabet, defaultSize = 21) => {
4
3
  let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1
5
- let step = -~((1.6 * mask * size) / alphabet.length)
6
- return () => {
4
+ let step = -~((1.6 * mask * defaultSize) / alphabet.length)
5
+ return async (size = defaultSize) => {
7
6
  let id = ''
8
7
  while (true) {
9
8
  let bytes = crypto.getRandomValues(new Uint8Array(step))
10
9
  let i = step
11
10
  while (i--) {
12
11
  id += alphabet[bytes[i] & mask] || ''
13
- if (id.length === size) return Promise.resolve(id)
12
+ if (id.length === size) return id
14
13
  }
15
14
  }
16
15
  }
17
16
  }
18
- let nanoid = (size = 21) => {
17
+ let nanoid = async (size = 21) => {
19
18
  let id = ''
20
19
  let bytes = crypto.getRandomValues(new Uint8Array(size))
21
20
  while (size--) {
@@ -30,6 +29,6 @@ let nanoid = (size = 21) => {
30
29
  id += '-'
31
30
  }
32
31
  }
33
- return Promise.resolve(id)
32
+ return id
34
33
  }
35
34
  export { nanoid, customAlphabet, random }
package/async/index.cjs CHANGED
@@ -10,19 +10,19 @@ let random = bytes =>
10
10
  }
11
11
  })
12
12
  })
13
- let customAlphabet = (alphabet, size) => {
13
+ let customAlphabet = (alphabet, defaultSize = 21) => {
14
14
  let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1
15
- let step = Math.ceil((1.6 * mask * size) / alphabet.length)
16
- let tick = id =>
15
+ let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length)
16
+ let tick = (id, size = defaultSize) =>
17
17
  random(step).then(bytes => {
18
18
  let i = step
19
19
  while (i--) {
20
20
  id += alphabet[bytes[i] & mask] || ''
21
21
  if (id.length === size) return id
22
22
  }
23
- return tick(id)
23
+ return tick(id, size)
24
24
  })
25
- return () => tick('')
25
+ return size => tick('', size)
26
26
  }
27
27
  let nanoid = (size = 21) =>
28
28
  random(size).then(bytes => {
package/async/index.d.ts CHANGED
@@ -24,8 +24,8 @@ export function nanoid(size?: number): Promise<string>
24
24
  * will not be secure.
25
25
  *
26
26
  * @param alphabet Alphabet used to generate the ID.
27
- * @param size Size of the ID.
28
- * @returns A promise with a random string.
27
+ * @param defaultSize Size of the ID. The default size is 21.
28
+ * @returns A function that returns a promise with a random string.
29
29
  *
30
30
  * ```js
31
31
  * import { customAlphabet } from 'nanoid/async'
@@ -37,8 +37,8 @@ export function nanoid(size?: number): Promise<string>
37
37
  */
38
38
  export function customAlphabet(
39
39
  alphabet: string,
40
- size: number
41
- ): () => Promise<string>
40
+ defaultSize?: number
41
+ ): (size?: number) => Promise<string>
42
42
 
43
43
  /**
44
44
  * Generate an array of random bytes collected from hardware noise.
package/async/index.js CHANGED
@@ -10,19 +10,19 @@ let random = bytes =>
10
10
  }
11
11
  })
12
12
  })
13
- let customAlphabet = (alphabet, size) => {
13
+ let customAlphabet = (alphabet, defaultSize = 21) => {
14
14
  let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1
15
- let step = Math.ceil((1.6 * mask * size) / alphabet.length)
16
- let tick = id =>
15
+ let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length)
16
+ let tick = (id, size = defaultSize) =>
17
17
  random(step).then(bytes => {
18
18
  let i = step
19
19
  while (i--) {
20
20
  id += alphabet[bytes[i] & mask] || ''
21
21
  if (id.length === size) return id
22
22
  }
23
- return tick(id)
23
+ return tick(id, size)
24
24
  })
25
- return () => tick('')
25
+ return size => tick('', size)
26
26
  }
27
27
  let nanoid = (size = 21) =>
28
28
  random(size).then(bytes => {
@@ -1,19 +1,19 @@
1
1
  import { getRandomBytesAsync } from 'expo-random'
2
2
  import { urlAlphabet } from '../url-alphabet/index.js'
3
3
  let random = getRandomBytesAsync
4
- let customAlphabet = (alphabet, size) => {
4
+ let customAlphabet = (alphabet, defaultSize = 21) => {
5
5
  let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1
6
- let step = Math.ceil((1.6 * mask * size) / alphabet.length)
7
- let tick = id =>
6
+ let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length)
7
+ let tick = (id, size = defaultSize) =>
8
8
  random(step).then(bytes => {
9
9
  let i = step
10
10
  while (i--) {
11
11
  id += alphabet[bytes[i] & mask] || ''
12
12
  if (id.length === size) return id
13
13
  }
14
- return tick(id)
14
+ return tick(id, size)
15
15
  })
16
- return () => tick('')
16
+ return size => tick('', size)
17
17
  }
18
18
  let nanoid = (size = 21) =>
19
19
  random(size).then(bytes => {
package/bin/nanoid.cjs CHANGED
@@ -1,5 +1,55 @@
1
1
  #!/usr/bin/env node
2
2
 
3
- let { nanoid } = require('..')
3
+ let { nanoid, customAlphabet } = require('..')
4
4
 
5
- process.stdout.write(nanoid() + '\n')
5
+ function print(msg) {
6
+ process.stdout.write(msg + '\n')
7
+ }
8
+
9
+ function error(msg) {
10
+ process.stderr.write(msg + '\n')
11
+ process.exit(1)
12
+ }
13
+
14
+ if (process.argv.includes('--help') || process.argv.includes('-h')) {
15
+ print(`
16
+ Usage
17
+ $ nanoid [options]
18
+
19
+ Options
20
+ -s, --size Generated ID size
21
+ -a, --alphabet Alphabet to use
22
+ -h, --help Show this help
23
+
24
+ Examples
25
+ $ nano --s 15
26
+ S9sBF77U6sDB8Yg
27
+
28
+ $ nano --size 10 --alphabet abc
29
+ bcabababca`)
30
+ process.exit()
31
+ }
32
+
33
+ let alphabet, size
34
+ for (let i = 2; i < process.argv.length; i++) {
35
+ let arg = process.argv[i]
36
+ if (arg === '--size' || arg === '-s') {
37
+ size = Number(process.argv[i + 1])
38
+ i += 1
39
+ if (Number.isNaN(size) || size <= 0) {
40
+ error('Size must be positive integer')
41
+ }
42
+ } else if (arg === '--alphabet' || arg === '-a') {
43
+ alphabet = process.argv[i + 1]
44
+ i += 1
45
+ } else {
46
+ error('Unknown argument ' + arg)
47
+ }
48
+ }
49
+
50
+ if (alphabet) {
51
+ let customNanoid = customAlphabet(alphabet, size)
52
+ print(customNanoid())
53
+ } else {
54
+ print(nanoid(size))
55
+ }
package/index.browser.cjs CHANGED
@@ -26,10 +26,10 @@ if (process.env.NODE_ENV !== 'production') {
26
26
  }
27
27
  }
28
28
  let random = bytes => crypto.getRandomValues(new Uint8Array(bytes))
29
- let customRandom = (alphabet, size, getRandom) => {
29
+ let customRandom = (alphabet, defaultSize, getRandom) => {
30
30
  let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1
31
- let step = -~((1.6 * mask * size) / alphabet.length)
32
- return () => {
31
+ let step = -~((1.6 * mask * defaultSize) / alphabet.length)
32
+ return (size = defaultSize) => {
33
33
  let id = ''
34
34
  while (true) {
35
35
  let bytes = getRandom(step)
@@ -41,7 +41,8 @@ let customRandom = (alphabet, size, getRandom) => {
41
41
  }
42
42
  }
43
43
  }
44
- let customAlphabet = (alphabet, size) => customRandom(alphabet, size, random)
44
+ let customAlphabet = (alphabet, size = 21) =>
45
+ customRandom(alphabet, size, random)
45
46
  let nanoid = (size = 21) => {
46
47
  let id = ''
47
48
  let bytes = crypto.getRandomValues(new Uint8Array(size))
package/index.browser.js CHANGED
@@ -26,10 +26,10 @@ if (process.env.NODE_ENV !== 'production') {
26
26
  }
27
27
  }
28
28
  let random = bytes => crypto.getRandomValues(new Uint8Array(bytes))
29
- let customRandom = (alphabet, size, getRandom) => {
29
+ let customRandom = (alphabet, defaultSize, getRandom) => {
30
30
  let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1
31
- let step = -~((1.6 * mask * size) / alphabet.length)
32
- return () => {
31
+ let step = -~((1.6 * mask * defaultSize) / alphabet.length)
32
+ return (size = defaultSize) => {
33
33
  let id = ''
34
34
  while (true) {
35
35
  let bytes = getRandom(step)
@@ -41,7 +41,8 @@ let customRandom = (alphabet, size, getRandom) => {
41
41
  }
42
42
  }
43
43
  }
44
- let customAlphabet = (alphabet, size) => customRandom(alphabet, size, random)
44
+ let customAlphabet = (alphabet, size = 21) =>
45
+ customRandom(alphabet, size, random)
45
46
  let nanoid = (size = 21) => {
46
47
  let id = ''
47
48
  let bytes = crypto.getRandomValues(new Uint8Array(size))
package/index.cjs CHANGED
@@ -14,13 +14,13 @@ let fillPool = bytes => {
14
14
  poolOffset += bytes
15
15
  }
16
16
  let random = bytes => {
17
- fillPool(bytes)
17
+ fillPool((bytes -= 0))
18
18
  return pool.subarray(poolOffset - bytes, poolOffset)
19
19
  }
20
- let customRandom = (alphabet, size, getRandom) => {
20
+ let customRandom = (alphabet, defaultSize, getRandom) => {
21
21
  let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1
22
- let step = Math.ceil((1.6 * mask * size) / alphabet.length)
23
- return () => {
22
+ let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length)
23
+ return (size = defaultSize) => {
24
24
  let id = ''
25
25
  while (true) {
26
26
  let bytes = getRandom(step)
@@ -32,9 +32,10 @@ let customRandom = (alphabet, size, getRandom) => {
32
32
  }
33
33
  }
34
34
  }
35
- let customAlphabet = (alphabet, size) => customRandom(alphabet, size, random)
35
+ let customAlphabet = (alphabet, size = 21) =>
36
+ customRandom(alphabet, size, random)
36
37
  let nanoid = (size = 21) => {
37
- fillPool(size)
38
+ fillPool((size -= 0))
38
39
  let id = ''
39
40
  for (let i = poolOffset - size; i < poolOffset; i++) {
40
41
  id += urlAlphabet[pool[i] & 63]
package/index.d.ts CHANGED
@@ -21,7 +21,7 @@ export function nanoid(size?: number): string
21
21
  * will not be secure.
22
22
  *
23
23
  * @param alphabet Alphabet used to generate the ID.
24
- * @param size Size of the ID.
24
+ * @param defaultSize Size of the ID. The default size is 21.
25
25
  * @returns A random string generator.
26
26
  *
27
27
  * ```js
@@ -30,7 +30,10 @@ export function nanoid(size?: number): string
30
30
  * nanoid() //=> "8ё56а"
31
31
  * ```
32
32
  */
33
- export function customAlphabet(alphabet: string, size: number): () => string
33
+ export function customAlphabet(
34
+ alphabet: string,
35
+ defaultSize?: number
36
+ ): (size?: number) => string
34
37
 
35
38
  /**
36
39
  * Generate unique ID with custom random generator and alphabet.
package/index.dev.js CHANGED
@@ -26,10 +26,10 @@ if (true) {
26
26
  }
27
27
  }
28
28
  let random = bytes => crypto.getRandomValues(new Uint8Array(bytes))
29
- let customRandom = (alphabet, size, getRandom) => {
29
+ let customRandom = (alphabet, defaultSize, getRandom) => {
30
30
  let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1
31
- let step = -~((1.6 * mask * size) / alphabet.length)
32
- return () => {
31
+ let step = -~((1.6 * mask * defaultSize) / alphabet.length)
32
+ return (size = defaultSize) => {
33
33
  let id = ''
34
34
  while (true) {
35
35
  let bytes = getRandom(step)
@@ -41,7 +41,8 @@ let customRandom = (alphabet, size, getRandom) => {
41
41
  }
42
42
  }
43
43
  }
44
- let customAlphabet = (alphabet, size) => customRandom(alphabet, size, random)
44
+ let customAlphabet = (alphabet, size = 21) =>
45
+ customRandom(alphabet, size, random)
45
46
  let nanoid = (size = 21) => {
46
47
  let id = ''
47
48
  let bytes = crypto.getRandomValues(new Uint8Array(size))
package/index.js CHANGED
@@ -14,13 +14,13 @@ let fillPool = bytes => {
14
14
  poolOffset += bytes
15
15
  }
16
16
  let random = bytes => {
17
- fillPool(bytes)
17
+ fillPool((bytes -= 0))
18
18
  return pool.subarray(poolOffset - bytes, poolOffset)
19
19
  }
20
- let customRandom = (alphabet, size, getRandom) => {
20
+ let customRandom = (alphabet, defaultSize, getRandom) => {
21
21
  let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1
22
- let step = Math.ceil((1.6 * mask * size) / alphabet.length)
23
- return () => {
22
+ let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length)
23
+ return (size = defaultSize) => {
24
24
  let id = ''
25
25
  while (true) {
26
26
  let bytes = getRandom(step)
@@ -32,9 +32,10 @@ let customRandom = (alphabet, size, getRandom) => {
32
32
  }
33
33
  }
34
34
  }
35
- let customAlphabet = (alphabet, size) => customRandom(alphabet, size, random)
35
+ let customAlphabet = (alphabet, size = 21) =>
36
+ customRandom(alphabet, size, random)
36
37
  let nanoid = (size = 21) => {
37
- fillPool(size)
38
+ fillPool((size -= 0))
38
39
  let id = ''
39
40
  for (let i = poolOffset - size; i < poolOffset; i++) {
40
41
  id += urlAlphabet[pool[i] & 63]
package/index.prod.js CHANGED
@@ -26,10 +26,10 @@ if (false) {
26
26
  }
27
27
  }
28
28
  let random = bytes => crypto.getRandomValues(new Uint8Array(bytes))
29
- let customRandom = (alphabet, size, getRandom) => {
29
+ let customRandom = (alphabet, defaultSize, getRandom) => {
30
30
  let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1
31
- let step = -~((1.6 * mask * size) / alphabet.length)
32
- return () => {
31
+ let step = -~((1.6 * mask * defaultSize) / alphabet.length)
32
+ return (size = defaultSize) => {
33
33
  let id = ''
34
34
  while (true) {
35
35
  let bytes = getRandom(step)
@@ -41,7 +41,8 @@ let customRandom = (alphabet, size, getRandom) => {
41
41
  }
42
42
  }
43
43
  }
44
- let customAlphabet = (alphabet, size) => customRandom(alphabet, size, random)
44
+ let customAlphabet = (alphabet, size = 21) =>
45
+ customRandom(alphabet, size, random)
45
46
  let nanoid = (size = 21) => {
46
47
  let id = ''
47
48
  let bytes = crypto.getRandomValues(new Uint8Array(size))
@@ -1,7 +1,7 @@
1
1
  let urlAlphabet =
2
2
  'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'
3
- let customAlphabet = (alphabet, size) => {
4
- return () => {
3
+ let customAlphabet = (alphabet, defaultSize = 21) => {
4
+ return (size = defaultSize) => {
5
5
  let id = ''
6
6
  let i = size
7
7
  while (i--) {
@@ -13,13 +13,13 @@
13
13
  export function nanoid(size?: number): string
14
14
 
15
15
  /**
16
- * Generate URL-friendly unique ID based on the custom alphabet.
16
+ * Generate a unique ID based on a custom alphabet.
17
17
  * This method uses the non-secure predictable random generator
18
18
  * with bigger collision probability.
19
19
  *
20
20
  * @param alphabet Alphabet used to generate the ID.
21
- * @param size Size of the ID.
22
- * @returns A random string.
21
+ * @param defaultSize Size of the ID. The default size is 21.
22
+ * @returns A random string generator.
23
23
  *
24
24
  * ```js
25
25
  * import { customAlphabet } from 'nanoid/non-secure'
@@ -27,4 +27,7 @@ export function nanoid(size?: number): string
27
27
  * model.id = //=> "8ё56а"
28
28
  * ```
29
29
  */
30
- export function customAlphabet(alphabet: string, size: number): () => string
30
+ export function customAlphabet(
31
+ alphabet: string,
32
+ defaultSize?: number
33
+ ): (size?: number) => string
@@ -1,7 +1,7 @@
1
1
  let urlAlphabet =
2
2
  'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'
3
- let customAlphabet = (alphabet, size) => {
4
- return () => {
3
+ let customAlphabet = (alphabet, defaultSize = 21) => {
4
+ return (size = defaultSize) => {
5
5
  let id = ''
6
6
  let i = size
7
7
  while (i--) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nanoid",
3
- "version": "3.1.30",
3
+ "version": "3.3.0",
4
4
  "description": "A tiny (130 bytes), secure URL-friendly unique string ID generator",
5
5
  "keywords": [
6
6
  "uuid",