1 | // This alphabet uses a-z A-Z 0-9 _- symbols.
|
2 | // Symbols are generated for smaller size.
|
3 | // -_zyxwvutsrqponmlkjihgfedcba9876543210ZYXWVUTSRQPONMLKJIHGFEDCBA
|
4 | var url = '-_'
|
5 | // Loop from 36 to 0 (from z to a and 9 to 0 in Base36).
|
6 | var i = 36
|
7 | while (i--) {
|
8 | // 36 is radix. Number.prototype.toString(36) returns number
|
9 | // in Base36 representation. Base36 is like hex, but it uses 0–9 and a-z.
|
10 | url += i.toString(36)
|
11 | }
|
12 | // Loop from 36 to 10 (from Z to A in Base36).
|
13 | i = 36
|
14 | while (i-- - 10) {
|
15 | url += i.toString(36).toUpperCase()
|
16 | }
|
17 |
|
18 | /**
|
19 | * Generate URL-friendly unique ID. This method use non-secure predictable
|
20 | * random generator with bigger collision probability.
|
21 | *
|
22 | * @param {number} [size=21] The number of symbols in ID.
|
23 | *
|
24 | * @return {string} Random string.
|
25 | *
|
26 | * @example
|
27 | * const nanoid = require('nanoid/non-secure')
|
28 | * model.id = nanoid() //=> "Uakgb_J5m9g-0JDMbcJqL"
|
29 | *
|
30 | * @name nonSecure
|
31 | * @function
|
32 | */
|
33 | module.exports = function (size) {
|
34 | var id = ''
|
35 | i = size || 21
|
36 | // Compact alternative for `for (var i = 0; i < size; i++)`
|
37 | while (i--) {
|
38 | // `| 0` is compact and faster alternative for `Math.floor()`
|
39 | id += url[Math.random() * 64 | 0]
|
40 | }
|
41 | return id
|
42 | }
|