plugin-build-guide-block 1.1.5 → 1.1.7

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.
Files changed (123) hide show
  1. package/client-v2.d.ts +2 -0
  2. package/client-v2.js +1 -0
  3. package/dist/client/index.js +2 -2
  4. package/dist/client-v2/73.6b8b2eda7d969c69.js +10 -0
  5. package/dist/client-v2/index.js +10 -0
  6. package/dist/externalVersion.js +9 -8
  7. package/dist/node_modules/sanitize-html/index.js +2 -2
  8. package/dist/node_modules/sanitize-html/package.json +1 -1
  9. package/dist/server/actions/build.js +687 -85
  10. package/dist/server/collections/ai-build-guide-spaces.js +20 -0
  11. package/dist/server/plugin.js +21 -19
  12. package/dist/server/tools/search-guides.js +41 -30
  13. package/package.json +7 -3
  14. package/src/client/components/BuildButton.tsx +20 -9
  15. package/src/client-v2/plugin.tsx +24 -0
  16. package/src/server/actions/build.ts +774 -88
  17. package/src/server/collections/ai-build-guide-spaces.ts +77 -57
  18. package/src/server/plugin.ts +170 -163
  19. package/src/server/tools/search-guides.ts +113 -95
  20. package/dist/client/UserGuideBlock.d.ts +0 -2
  21. package/dist/client/UserGuideBlockInitializer.d.ts +0 -2
  22. package/dist/client/UserGuideBlockProvider.d.ts +0 -2
  23. package/dist/client/UserGuideManager.d.ts +0 -2
  24. package/dist/client/components/BuildButton.d.ts +0 -2
  25. package/dist/client/components/LLMServiceSelect.d.ts +0 -2
  26. package/dist/client/components/ModelSelect.d.ts +0 -2
  27. package/dist/client/components/SpaceSelect.d.ts +0 -2
  28. package/dist/client/components/StatusTag.d.ts +0 -2
  29. package/dist/client/locale.d.ts +0 -3
  30. package/dist/client/models/UserGuideBlockModel.d.ts +0 -9
  31. package/dist/client/models/index.d.ts +0 -9
  32. package/dist/client/plugin.d.ts +0 -5
  33. package/dist/client/schemaSettings.d.ts +0 -2
  34. package/dist/client/schemas/spacesSchema.d.ts +0 -437
  35. package/dist/index.d.ts +0 -2
  36. package/dist/locale/namespace.d.ts +0 -6
  37. package/dist/node_modules/sanitize-html/node_modules/nanoid/async/index.browser.cjs +0 -34
  38. package/dist/node_modules/sanitize-html/node_modules/nanoid/async/index.browser.js +0 -34
  39. package/dist/node_modules/sanitize-html/node_modules/nanoid/async/index.cjs +0 -35
  40. package/dist/node_modules/sanitize-html/node_modules/nanoid/async/index.d.ts +0 -56
  41. package/dist/node_modules/sanitize-html/node_modules/nanoid/async/index.js +0 -35
  42. package/dist/node_modules/sanitize-html/node_modules/nanoid/async/index.native.js +0 -26
  43. package/dist/node_modules/sanitize-html/node_modules/nanoid/async/package.json +0 -12
  44. package/dist/node_modules/sanitize-html/node_modules/nanoid/bin/nanoid.cjs +0 -55
  45. package/dist/node_modules/sanitize-html/node_modules/nanoid/index.browser.cjs +0 -34
  46. package/dist/node_modules/sanitize-html/node_modules/nanoid/index.browser.js +0 -34
  47. package/dist/node_modules/sanitize-html/node_modules/nanoid/index.cjs +0 -45
  48. package/dist/node_modules/sanitize-html/node_modules/nanoid/index.d.cts +0 -91
  49. package/dist/node_modules/sanitize-html/node_modules/nanoid/index.d.ts +0 -91
  50. package/dist/node_modules/sanitize-html/node_modules/nanoid/index.js +0 -45
  51. package/dist/node_modules/sanitize-html/node_modules/nanoid/nanoid.js +0 -1
  52. package/dist/node_modules/sanitize-html/node_modules/nanoid/non-secure/index.cjs +0 -21
  53. package/dist/node_modules/sanitize-html/node_modules/nanoid/non-secure/index.d.ts +0 -33
  54. package/dist/node_modules/sanitize-html/node_modules/nanoid/non-secure/index.js +0 -21
  55. package/dist/node_modules/sanitize-html/node_modules/nanoid/non-secure/package.json +0 -6
  56. package/dist/node_modules/sanitize-html/node_modules/nanoid/package.json +0 -88
  57. package/dist/node_modules/sanitize-html/node_modules/nanoid/url-alphabet/index.cjs +0 -3
  58. package/dist/node_modules/sanitize-html/node_modules/nanoid/url-alphabet/index.js +0 -3
  59. package/dist/node_modules/sanitize-html/node_modules/nanoid/url-alphabet/package.json +0 -6
  60. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/at-rule.d.ts +0 -115
  61. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/at-rule.js +0 -25
  62. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/comment.d.ts +0 -67
  63. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/comment.js +0 -13
  64. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/container.d.ts +0 -452
  65. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/container.js +0 -439
  66. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/css-syntax-error.d.ts +0 -248
  67. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/css-syntax-error.js +0 -100
  68. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/declaration.d.ts +0 -148
  69. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/declaration.js +0 -24
  70. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/document.d.ts +0 -68
  71. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/document.js +0 -33
  72. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/fromJSON.d.ts +0 -9
  73. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/fromJSON.js +0 -54
  74. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/input.d.ts +0 -194
  75. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/input.js +0 -248
  76. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/lazy-result.d.ts +0 -190
  77. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/lazy-result.js +0 -550
  78. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/list.d.ts +0 -57
  79. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/list.js +0 -58
  80. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/map-generator.js +0 -359
  81. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/no-work-result.d.ts +0 -46
  82. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/no-work-result.js +0 -135
  83. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/node.d.ts +0 -536
  84. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/node.js +0 -381
  85. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/parse.d.ts +0 -9
  86. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/parse.js +0 -42
  87. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/parser.js +0 -610
  88. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/postcss.d.mts +0 -72
  89. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/postcss.d.ts +0 -441
  90. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/postcss.js +0 -101
  91. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/previous-map.d.ts +0 -81
  92. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/previous-map.js +0 -142
  93. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/processor.d.ts +0 -115
  94. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/processor.js +0 -67
  95. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/result.d.ts +0 -206
  96. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/result.js +0 -42
  97. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/root.d.ts +0 -86
  98. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/root.js +0 -61
  99. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/rule.d.ts +0 -113
  100. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/rule.js +0 -27
  101. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/stringifier.d.ts +0 -46
  102. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/stringifier.js +0 -353
  103. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/stringify.d.ts +0 -9
  104. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/stringify.js +0 -11
  105. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/symbols.js +0 -5
  106. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/terminal-highlight.js +0 -70
  107. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/tokenize.js +0 -266
  108. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/warn-once.js +0 -13
  109. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/warning.d.ts +0 -147
  110. package/dist/node_modules/sanitize-html/node_modules/postcss/lib/warning.js +0 -37
  111. package/dist/node_modules/sanitize-html/node_modules/postcss/node_modules/.bin/nanoid +0 -15
  112. package/dist/node_modules/sanitize-html/node_modules/postcss/node_modules/.bin/nanoid.cmd +0 -7
  113. package/dist/node_modules/sanitize-html/node_modules/postcss/package.json +0 -88
  114. package/dist/server/actions/build.d.ts +0 -2
  115. package/dist/server/actions/getHtml.d.ts +0 -2
  116. package/dist/server/actions/getMarkdown.d.ts +0 -2
  117. package/dist/server/collections/ai-build-guide-pages.d.ts +0 -2
  118. package/dist/server/collections/ai-build-guide-spaces.d.ts +0 -2
  119. package/dist/server/index.d.ts +0 -2
  120. package/dist/server/plugin.d.ts +0 -16
  121. package/dist/server/tools/index.d.ts +0 -1
  122. package/dist/server/tools/search-guides.d.ts +0 -28
  123. /package/{dist/client/index.d.ts → src/client-v2/index.tsx} +0 -0
@@ -1,26 +0,0 @@
1
- import { getRandomBytesAsync } from 'expo-random'
2
- import { urlAlphabet } from '../url-alphabet/index.js'
3
- let random = getRandomBytesAsync
4
- let customAlphabet = (alphabet, defaultSize = 21) => {
5
- let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1
6
- let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length)
7
- let tick = (id, size = defaultSize) =>
8
- random(step).then(bytes => {
9
- let i = step
10
- while (i--) {
11
- id += alphabet[bytes[i] & mask] || ''
12
- if (id.length === size) return id
13
- }
14
- return tick(id, size)
15
- })
16
- return size => tick('', size)
17
- }
18
- let nanoid = (size = 21) =>
19
- random(size).then(bytes => {
20
- let id = ''
21
- while (size--) {
22
- id += urlAlphabet[bytes[size] & 63]
23
- }
24
- return id
25
- })
26
- export { nanoid, customAlphabet, random }
@@ -1,12 +0,0 @@
1
- {
2
- "type": "module",
3
- "main": "index.cjs",
4
- "module": "index.js",
5
- "react-native": {
6
- "./index.js": "./index.native.js"
7
- },
8
- "browser": {
9
- "./index.js": "./index.browser.js",
10
- "./index.cjs": "./index.browser.cjs"
11
- }
12
- }
@@ -1,55 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- let { nanoid, customAlphabet } = require('..')
4
-
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
- $ nanoid --s 15
26
- S9sBF77U6sDB8Yg
27
-
28
- $ nanoid --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
- }
@@ -1,34 +0,0 @@
1
- let { urlAlphabet } = require('./url-alphabet/index.cjs')
2
- let random = bytes => crypto.getRandomValues(new Uint8Array(bytes))
3
- let customRandom = (alphabet, defaultSize, getRandom) => {
4
- let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1
5
- let step = -~((1.6 * mask * defaultSize) / alphabet.length)
6
- return (size = defaultSize) => {
7
- let id = ''
8
- while (true) {
9
- let bytes = getRandom(step)
10
- let j = step
11
- while (j--) {
12
- id += alphabet[bytes[j] & mask] || ''
13
- if (id.length === size) return id
14
- }
15
- }
16
- }
17
- }
18
- let customAlphabet = (alphabet, size = 21) =>
19
- customRandom(alphabet, size, random)
20
- let nanoid = (size = 21) =>
21
- crypto.getRandomValues(new Uint8Array(size)).reduce((id, byte) => {
22
- byte &= 63
23
- if (byte < 36) {
24
- id += byte.toString(36)
25
- } else if (byte < 62) {
26
- id += (byte - 26).toString(36).toUpperCase()
27
- } else if (byte > 62) {
28
- id += '-'
29
- } else {
30
- id += '_'
31
- }
32
- return id
33
- }, '')
34
- module.exports = { nanoid, customAlphabet, customRandom, urlAlphabet, random }
@@ -1,34 +0,0 @@
1
- import { urlAlphabet } from './url-alphabet/index.js'
2
- let random = bytes => crypto.getRandomValues(new Uint8Array(bytes))
3
- let customRandom = (alphabet, defaultSize, getRandom) => {
4
- let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1
5
- let step = -~((1.6 * mask * defaultSize) / alphabet.length)
6
- return (size = defaultSize) => {
7
- let id = ''
8
- while (true) {
9
- let bytes = getRandom(step)
10
- let j = step
11
- while (j--) {
12
- id += alphabet[bytes[j] & mask] || ''
13
- if (id.length === size) return id
14
- }
15
- }
16
- }
17
- }
18
- let customAlphabet = (alphabet, size = 21) =>
19
- customRandom(alphabet, size, random)
20
- let nanoid = (size = 21) =>
21
- crypto.getRandomValues(new Uint8Array(size)).reduce((id, byte) => {
22
- byte &= 63
23
- if (byte < 36) {
24
- id += byte.toString(36)
25
- } else if (byte < 62) {
26
- id += (byte - 26).toString(36).toUpperCase()
27
- } else if (byte > 62) {
28
- id += '-'
29
- } else {
30
- id += '_'
31
- }
32
- return id
33
- }, '')
34
- export { nanoid, customAlphabet, customRandom, urlAlphabet, random }
@@ -1,45 +0,0 @@
1
- let crypto = require('crypto')
2
- let { urlAlphabet } = require('./url-alphabet/index.cjs')
3
- const POOL_SIZE_MULTIPLIER = 128
4
- let pool, poolOffset
5
- let fillPool = bytes => {
6
- if (!pool || pool.length < bytes) {
7
- pool = Buffer.allocUnsafe(bytes * POOL_SIZE_MULTIPLIER)
8
- crypto.randomFillSync(pool)
9
- poolOffset = 0
10
- } else if (poolOffset + bytes > pool.length) {
11
- crypto.randomFillSync(pool)
12
- poolOffset = 0
13
- }
14
- poolOffset += bytes
15
- }
16
- let random = bytes => {
17
- fillPool((bytes -= 0))
18
- return pool.subarray(poolOffset - bytes, poolOffset)
19
- }
20
- let customRandom = (alphabet, defaultSize, getRandom) => {
21
- let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1
22
- let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length)
23
- return (size = defaultSize) => {
24
- let id = ''
25
- while (true) {
26
- let bytes = getRandom(step)
27
- let i = step
28
- while (i--) {
29
- id += alphabet[bytes[i] & mask] || ''
30
- if (id.length === size) return id
31
- }
32
- }
33
- }
34
- }
35
- let customAlphabet = (alphabet, size = 21) =>
36
- customRandom(alphabet, size, random)
37
- let nanoid = (size = 21) => {
38
- fillPool((size -= 0))
39
- let id = ''
40
- for (let i = poolOffset - size; i < poolOffset; i++) {
41
- id += urlAlphabet[pool[i] & 63]
42
- }
43
- return id
44
- }
45
- module.exports = { nanoid, customAlphabet, customRandom, urlAlphabet, random }
@@ -1,91 +0,0 @@
1
- /**
2
- * Generate secure URL-friendly unique ID.
3
- *
4
- * By default, the ID will have 21 symbols to have a collision probability
5
- * similar to UUID v4.
6
- *
7
- * ```js
8
- * import { nanoid } from 'nanoid'
9
- * model.id = nanoid() //=> "Uakgb_J5m9g-0JDMbcJqL"
10
- * ```
11
- *
12
- * @param size Size of the ID. The default size is 21.
13
- * @returns A random string.
14
- */
15
- export function nanoid(size?: number): string
16
-
17
- /**
18
- * Generate secure unique ID with custom alphabet.
19
- *
20
- * Alphabet must contain 256 symbols or less. Otherwise, the generator
21
- * will not be secure.
22
- *
23
- * @param alphabet Alphabet used to generate the ID.
24
- * @param defaultSize Size of the ID. The default size is 21.
25
- * @returns A random string generator.
26
- *
27
- * ```js
28
- * const { customAlphabet } = require('nanoid')
29
- * const nanoid = customAlphabet('0123456789абвгдеё', 5)
30
- * nanoid() //=> "8ё56а"
31
- * ```
32
- */
33
- export function customAlphabet(
34
- alphabet: string,
35
- defaultSize?: number
36
- ): (size?: number) => string
37
-
38
- /**
39
- * Generate unique ID with custom random generator and alphabet.
40
- *
41
- * Alphabet must contain 256 symbols or less. Otherwise, the generator
42
- * will not be secure.
43
- *
44
- * ```js
45
- * import { customRandom } from 'nanoid/format'
46
- *
47
- * const nanoid = customRandom('abcdef', 5, size => {
48
- * const random = []
49
- * for (let i = 0; i < size; i++) {
50
- * random.push(randomByte())
51
- * }
52
- * return random
53
- * })
54
- *
55
- * nanoid() //=> "fbaef"
56
- * ```
57
- *
58
- * @param alphabet Alphabet used to generate a random string.
59
- * @param size Size of the random string.
60
- * @param random A random bytes generator.
61
- * @returns A random string generator.
62
- */
63
- export function customRandom(
64
- alphabet: string,
65
- size: number,
66
- random: (bytes: number) => Uint8Array
67
- ): () => string
68
-
69
- /**
70
- * URL safe symbols.
71
- *
72
- * ```js
73
- * import { urlAlphabet } from 'nanoid'
74
- * const nanoid = customAlphabet(urlAlphabet, 10)
75
- * nanoid() //=> "Uakgb_J5m9"
76
- * ```
77
- */
78
- export const urlAlphabet: string
79
-
80
- /**
81
- * Generate an array of random bytes collected from hardware noise.
82
- *
83
- * ```js
84
- * import { customRandom, random } from 'nanoid'
85
- * const nanoid = customRandom("abcdef", 5, random)
86
- * ```
87
- *
88
- * @param bytes Size of the array.
89
- * @returns An array of random bytes.
90
- */
91
- export function random(bytes: number): Uint8Array
@@ -1,91 +0,0 @@
1
- /**
2
- * Generate secure URL-friendly unique ID.
3
- *
4
- * By default, the ID will have 21 symbols to have a collision probability
5
- * similar to UUID v4.
6
- *
7
- * ```js
8
- * import { nanoid } from 'nanoid'
9
- * model.id = nanoid() //=> "Uakgb_J5m9g-0JDMbcJqL"
10
- * ```
11
- *
12
- * @param size Size of the ID. The default size is 21.
13
- * @returns A random string.
14
- */
15
- export function nanoid(size?: number): string
16
-
17
- /**
18
- * Generate secure unique ID with custom alphabet.
19
- *
20
- * Alphabet must contain 256 symbols or less. Otherwise, the generator
21
- * will not be secure.
22
- *
23
- * @param alphabet Alphabet used to generate the ID.
24
- * @param defaultSize Size of the ID. The default size is 21.
25
- * @returns A random string generator.
26
- *
27
- * ```js
28
- * const { customAlphabet } = require('nanoid')
29
- * const nanoid = customAlphabet('0123456789абвгдеё', 5)
30
- * nanoid() //=> "8ё56а"
31
- * ```
32
- */
33
- export function customAlphabet(
34
- alphabet: string,
35
- defaultSize?: number
36
- ): (size?: number) => string
37
-
38
- /**
39
- * Generate unique ID with custom random generator and alphabet.
40
- *
41
- * Alphabet must contain 256 symbols or less. Otherwise, the generator
42
- * will not be secure.
43
- *
44
- * ```js
45
- * import { customRandom } from 'nanoid/format'
46
- *
47
- * const nanoid = customRandom('abcdef', 5, size => {
48
- * const random = []
49
- * for (let i = 0; i < size; i++) {
50
- * random.push(randomByte())
51
- * }
52
- * return random
53
- * })
54
- *
55
- * nanoid() //=> "fbaef"
56
- * ```
57
- *
58
- * @param alphabet Alphabet used to generate a random string.
59
- * @param size Size of the random string.
60
- * @param random A random bytes generator.
61
- * @returns A random string generator.
62
- */
63
- export function customRandom(
64
- alphabet: string,
65
- size: number,
66
- random: (bytes: number) => Uint8Array
67
- ): () => string
68
-
69
- /**
70
- * URL safe symbols.
71
- *
72
- * ```js
73
- * import { urlAlphabet } from 'nanoid'
74
- * const nanoid = customAlphabet(urlAlphabet, 10)
75
- * nanoid() //=> "Uakgb_J5m9"
76
- * ```
77
- */
78
- export const urlAlphabet: string
79
-
80
- /**
81
- * Generate an array of random bytes collected from hardware noise.
82
- *
83
- * ```js
84
- * import { customRandom, random } from 'nanoid'
85
- * const nanoid = customRandom("abcdef", 5, random)
86
- * ```
87
- *
88
- * @param bytes Size of the array.
89
- * @returns An array of random bytes.
90
- */
91
- export function random(bytes: number): Uint8Array
@@ -1,45 +0,0 @@
1
- import crypto from 'crypto'
2
- import { urlAlphabet } from './url-alphabet/index.js'
3
- const POOL_SIZE_MULTIPLIER = 128
4
- let pool, poolOffset
5
- let fillPool = bytes => {
6
- if (!pool || pool.length < bytes) {
7
- pool = Buffer.allocUnsafe(bytes * POOL_SIZE_MULTIPLIER)
8
- crypto.randomFillSync(pool)
9
- poolOffset = 0
10
- } else if (poolOffset + bytes > pool.length) {
11
- crypto.randomFillSync(pool)
12
- poolOffset = 0
13
- }
14
- poolOffset += bytes
15
- }
16
- let random = bytes => {
17
- fillPool((bytes -= 0))
18
- return pool.subarray(poolOffset - bytes, poolOffset)
19
- }
20
- let customRandom = (alphabet, defaultSize, getRandom) => {
21
- let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1
22
- let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length)
23
- return (size = defaultSize) => {
24
- let id = ''
25
- while (true) {
26
- let bytes = getRandom(step)
27
- let i = step
28
- while (i--) {
29
- id += alphabet[bytes[i] & mask] || ''
30
- if (id.length === size) return id
31
- }
32
- }
33
- }
34
- }
35
- let customAlphabet = (alphabet, size = 21) =>
36
- customRandom(alphabet, size, random)
37
- let nanoid = (size = 21) => {
38
- fillPool((size -= 0))
39
- let id = ''
40
- for (let i = poolOffset - size; i < poolOffset; i++) {
41
- id += urlAlphabet[pool[i] & 63]
42
- }
43
- return id
44
- }
45
- export { nanoid, customAlphabet, customRandom, urlAlphabet, random }
@@ -1 +0,0 @@
1
- export let nanoid=(t=21)=>crypto.getRandomValues(new Uint8Array(t)).reduce(((t,e)=>t+=(e&=63)<36?e.toString(36):e<62?(e-26).toString(36).toUpperCase():e<63?"_":"-"),"");
@@ -1,21 +0,0 @@
1
- let urlAlphabet =
2
- 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'
3
- let customAlphabet = (alphabet, defaultSize = 21) => {
4
- return (size = defaultSize) => {
5
- let id = ''
6
- let i = size
7
- while (i--) {
8
- id += alphabet[(Math.random() * alphabet.length) | 0]
9
- }
10
- return id
11
- }
12
- }
13
- let nanoid = (size = 21) => {
14
- let id = ''
15
- let i = size
16
- while (i--) {
17
- id += urlAlphabet[(Math.random() * 64) | 0]
18
- }
19
- return id
20
- }
21
- module.exports = { nanoid, customAlphabet }
@@ -1,33 +0,0 @@
1
- /**
2
- * Generate URL-friendly unique ID. This method uses the non-secure
3
- * predictable random generator with bigger collision probability.
4
- *
5
- * ```js
6
- * import { nanoid } from 'nanoid/non-secure'
7
- * model.id = nanoid() //=> "Uakgb_J5m9g-0JDMbcJqL"
8
- * ```
9
- *
10
- * @param size Size of the ID. The default size is 21.
11
- * @returns A random string.
12
- */
13
- export function nanoid(size?: number): string
14
-
15
- /**
16
- * Generate a unique ID based on a custom alphabet.
17
- * This method uses the non-secure predictable random generator
18
- * with bigger collision probability.
19
- *
20
- * @param alphabet Alphabet used to generate the ID.
21
- * @param defaultSize Size of the ID. The default size is 21.
22
- * @returns A random string generator.
23
- *
24
- * ```js
25
- * import { customAlphabet } from 'nanoid/non-secure'
26
- * const nanoid = customAlphabet('0123456789абвгдеё', 5)
27
- * model.id = //=> "8ё56а"
28
- * ```
29
- */
30
- export function customAlphabet(
31
- alphabet: string,
32
- defaultSize?: number
33
- ): (size?: number) => string
@@ -1,21 +0,0 @@
1
- let urlAlphabet =
2
- 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'
3
- let customAlphabet = (alphabet, defaultSize = 21) => {
4
- return (size = defaultSize) => {
5
- let id = ''
6
- let i = size
7
- while (i--) {
8
- id += alphabet[(Math.random() * alphabet.length) | 0]
9
- }
10
- return id
11
- }
12
- }
13
- let nanoid = (size = 21) => {
14
- let id = ''
15
- let i = size
16
- while (i--) {
17
- id += urlAlphabet[(Math.random() * 64) | 0]
18
- }
19
- return id
20
- }
21
- export { nanoid, customAlphabet }
@@ -1,6 +0,0 @@
1
- {
2
- "type": "module",
3
- "main": "index.cjs",
4
- "module": "index.js",
5
- "react-native": "index.js"
6
- }
@@ -1,88 +0,0 @@
1
- {
2
- "name": "nanoid",
3
- "version": "3.3.7",
4
- "description": "A tiny (116 bytes), secure URL-friendly unique string ID generator",
5
- "keywords": [
6
- "uuid",
7
- "random",
8
- "id",
9
- "url"
10
- ],
11
- "engines": {
12
- "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
13
- },
14
- "funding": [
15
- {
16
- "type": "github",
17
- "url": "https://github.com/sponsors/ai"
18
- }
19
- ],
20
- "author": "Andrey Sitnik <andrey@sitnik.ru>",
21
- "license": "MIT",
22
- "repository": "ai/nanoid",
23
- "browser": {
24
- "./index.js": "./index.browser.js",
25
- "./async/index.js": "./async/index.browser.js",
26
- "./async/index.cjs": "./async/index.browser.cjs",
27
- "./index.cjs": "./index.browser.cjs"
28
- },
29
- "react-native": "index.js",
30
- "bin": "./bin/nanoid.cjs",
31
- "sideEffects": false,
32
- "types": "./index.d.ts",
33
- "type": "module",
34
- "main": "index.cjs",
35
- "module": "index.js",
36
- "exports": {
37
- ".": {
38
- "browser": "./index.browser.js",
39
- "require": {
40
- "types": "./index.d.cts",
41
- "default": "./index.cjs"
42
- },
43
- "import": {
44
- "types": "./index.d.ts",
45
- "default": "./index.js"
46
- },
47
- "default": "./index.js"
48
- },
49
- "./package.json": "./package.json",
50
- "./async/package.json": "./async/package.json",
51
- "./async": {
52
- "browser": "./async/index.browser.js",
53
- "require": {
54
- "types": "./index.d.cts",
55
- "default": "./async/index.cjs"
56
- },
57
- "import": {
58
- "types": "./index.d.ts",
59
- "default": "./async/index.js"
60
- },
61
- "default": "./async/index.js"
62
- },
63
- "./non-secure/package.json": "./non-secure/package.json",
64
- "./non-secure": {
65
- "require": {
66
- "types": "./index.d.cts",
67
- "default": "./non-secure/index.cjs"
68
- },
69
- "import": {
70
- "types": "./index.d.ts",
71
- "default": "./non-secure/index.js"
72
- },
73
- "default": "./non-secure/index.js"
74
- },
75
- "./url-alphabet/package.json": "./url-alphabet/package.json",
76
- "./url-alphabet": {
77
- "require": {
78
- "types": "./index.d.cts",
79
- "default": "./url-alphabet/index.cjs"
80
- },
81
- "import": {
82
- "types": "./index.d.ts",
83
- "default": "./url-alphabet/index.js"
84
- },
85
- "default": "./url-alphabet/index.js"
86
- }
87
- }
88
- }
@@ -1,3 +0,0 @@
1
- let urlAlphabet =
2
- 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'
3
- module.exports = { urlAlphabet }
@@ -1,3 +0,0 @@
1
- let urlAlphabet =
2
- 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'
3
- export { urlAlphabet }
@@ -1,6 +0,0 @@
1
- {
2
- "type": "module",
3
- "main": "index.cjs",
4
- "module": "index.js",
5
- "react-native": "index.js"
6
- }