nanoid 3.2.0 → 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/async/index.browser.cjs +3 -3
- package/async/index.browser.js +3 -3
- package/async/index.cjs +5 -5
- package/async/index.d.ts +4 -4
- package/async/index.js +5 -5
- package/async/index.native.js +5 -5
- package/bin/nanoid.cjs +0 -3
- package/index.browser.cjs +5 -4
- package/index.browser.js +5 -4
- package/index.cjs +5 -4
- package/index.d.ts +5 -2
- package/index.dev.js +5 -4
- package/index.js +5 -4
- package/index.prod.js +5 -4
- package/non-secure/index.cjs +2 -2
- package/non-secure/index.d.ts +7 -4
- package/non-secure/index.js +2 -2
- package/package.json +1 -1
package/async/index.browser.cjs
CHANGED
@@ -1,8 +1,8 @@
|
|
1
1
|
let random = async bytes => crypto.getRandomValues(new Uint8Array(bytes))
|
2
|
-
let customAlphabet = (alphabet,
|
2
|
+
let customAlphabet = (alphabet, defaultSize = 21) => {
|
3
3
|
let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1
|
4
|
-
let step = -~((1.6 * mask *
|
5
|
-
return async () => {
|
4
|
+
let step = -~((1.6 * mask * defaultSize) / alphabet.length)
|
5
|
+
return async (size = defaultSize) => {
|
6
6
|
let id = ''
|
7
7
|
while (true) {
|
8
8
|
let bytes = crypto.getRandomValues(new Uint8Array(step))
|
package/async/index.browser.js
CHANGED
@@ -1,8 +1,8 @@
|
|
1
1
|
let random = async bytes => crypto.getRandomValues(new Uint8Array(bytes))
|
2
|
-
let customAlphabet = (alphabet,
|
2
|
+
let customAlphabet = (alphabet, defaultSize = 21) => {
|
3
3
|
let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1
|
4
|
-
let step = -~((1.6 * mask *
|
5
|
-
return async () => {
|
4
|
+
let step = -~((1.6 * mask * defaultSize) / alphabet.length)
|
5
|
+
return async (size = defaultSize) => {
|
6
6
|
let id = ''
|
7
7
|
while (true) {
|
8
8
|
let bytes = crypto.getRandomValues(new Uint8Array(step))
|
package/async/index.cjs
CHANGED
@@ -10,19 +10,19 @@ let random = bytes =>
|
|
10
10
|
}
|
11
11
|
})
|
12
12
|
})
|
13
|
-
let customAlphabet = (alphabet,
|
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 *
|
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
|
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
|
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
|
-
|
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,
|
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 *
|
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
|
25
|
+
return size => tick('', size)
|
26
26
|
}
|
27
27
|
let nanoid = (size = 21) =>
|
28
28
|
random(size).then(bytes => {
|
package/async/index.native.js
CHANGED
@@ -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,
|
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 *
|
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
|
16
|
+
return size => tick('', size)
|
17
17
|
}
|
18
18
|
let nanoid = (size = 21) =>
|
19
19
|
random(size).then(bytes => {
|
package/bin/nanoid.cjs
CHANGED
@@ -48,9 +48,6 @@ for (let i = 2; i < process.argv.length; i++) {
|
|
48
48
|
}
|
49
49
|
|
50
50
|
if (alphabet) {
|
51
|
-
if (typeof size === 'undefined') {
|
52
|
-
error('You must also specify size option, when using custom alphabet')
|
53
|
-
}
|
54
51
|
let customNanoid = customAlphabet(alphabet, size)
|
55
52
|
print(customNanoid())
|
56
53
|
} else {
|
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,
|
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 *
|
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) =>
|
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,
|
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 *
|
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) =>
|
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
@@ -17,10 +17,10 @@ let random = bytes => {
|
|
17
17
|
fillPool((bytes -= 0))
|
18
18
|
return pool.subarray(poolOffset - bytes, poolOffset)
|
19
19
|
}
|
20
|
-
let customRandom = (alphabet,
|
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 *
|
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,7 +32,8 @@ let customRandom = (alphabet, size, getRandom) => {
|
|
32
32
|
}
|
33
33
|
}
|
34
34
|
}
|
35
|
-
let customAlphabet = (alphabet, size) =>
|
35
|
+
let customAlphabet = (alphabet, size = 21) =>
|
36
|
+
customRandom(alphabet, size, random)
|
36
37
|
let nanoid = (size = 21) => {
|
37
38
|
fillPool((size -= 0))
|
38
39
|
let id = ''
|
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
|
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(
|
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,
|
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 *
|
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) =>
|
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
@@ -17,10 +17,10 @@ let random = bytes => {
|
|
17
17
|
fillPool((bytes -= 0))
|
18
18
|
return pool.subarray(poolOffset - bytes, poolOffset)
|
19
19
|
}
|
20
|
-
let customRandom = (alphabet,
|
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 *
|
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,7 +32,8 @@ let customRandom = (alphabet, size, getRandom) => {
|
|
32
32
|
}
|
33
33
|
}
|
34
34
|
}
|
35
|
-
let customAlphabet = (alphabet, size) =>
|
35
|
+
let customAlphabet = (alphabet, size = 21) =>
|
36
|
+
customRandom(alphabet, size, random)
|
36
37
|
let nanoid = (size = 21) => {
|
37
38
|
fillPool((size -= 0))
|
38
39
|
let id = ''
|
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,
|
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 *
|
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) =>
|
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/non-secure/index.cjs
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
let urlAlphabet =
|
2
2
|
'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'
|
3
|
-
let customAlphabet = (alphabet,
|
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/non-secure/index.d.ts
CHANGED
@@ -13,13 +13,13 @@
|
|
13
13
|
export function nanoid(size?: number): string
|
14
14
|
|
15
15
|
/**
|
16
|
-
* Generate
|
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
|
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(
|
30
|
+
export function customAlphabet(
|
31
|
+
alphabet: string,
|
32
|
+
defaultSize?: number
|
33
|
+
): (size?: number) => string
|
package/non-secure/index.js
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
let urlAlphabet =
|
2
2
|
'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'
|
3
|
-
let customAlphabet = (alphabet,
|
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--) {
|