@discordeno/utils 19.0.0-next.b2f65c2 → 19.0.0-next.b567c13

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 (122) hide show
  1. package/dist/cjs/Collection.cjs +121 -0
  2. package/dist/cjs/base64.cjs +272 -0
  3. package/dist/cjs/bucket.cjs +93 -0
  4. package/dist/cjs/builders/embeds.cjs +290 -0
  5. package/dist/cjs/builders.cjs +23 -0
  6. package/dist/cjs/casing.cjs +67 -0
  7. package/dist/cjs/colors.cjs +360 -0
  8. package/dist/cjs/hash.cjs +33 -0
  9. package/dist/cjs/images.cjs +47 -0
  10. package/dist/cjs/index.cjs +33 -0
  11. package/dist/cjs/logger.cjs +147 -0
  12. package/dist/cjs/oauth2.cjs +24 -0
  13. package/dist/cjs/permissions.cjs +31 -0
  14. package/dist/cjs/reactions.cjs +19 -0
  15. package/dist/cjs/token.cjs +35 -0
  16. package/dist/cjs/typeguards.cjs +35 -0
  17. package/dist/cjs/urlToBase64.cjs +17 -0
  18. package/dist/cjs/utils.cjs +26 -0
  19. package/dist/esm/Collection.js +113 -0
  20. package/dist/esm/base64.js +262 -0
  21. package/dist/esm/bucket.js +80 -0
  22. package/dist/esm/builders/embeds.js +295 -0
  23. package/dist/esm/builders.js +5 -0
  24. package/dist/esm/casing.js +51 -0
  25. package/dist/esm/colors.js +467 -0
  26. package/dist/esm/hash.js +19 -0
  27. package/dist/esm/images.js +66 -0
  28. package/dist/esm/index.js +18 -0
  29. package/dist/esm/logger.js +130 -0
  30. package/dist/esm/oauth2.js +16 -0
  31. package/dist/esm/permissions.js +17 -0
  32. package/dist/esm/reactions.js +11 -0
  33. package/dist/esm/token.js +21 -0
  34. package/dist/esm/typeguards.js +18 -0
  35. package/dist/esm/urlToBase64.js +9 -0
  36. package/dist/esm/utils.js +15 -0
  37. package/dist/types/Collection.d.ts.map +1 -0
  38. package/dist/types/base64.d.ts.map +1 -0
  39. package/dist/{bucket.d.ts → types/bucket.d.ts} +1 -1
  40. package/dist/types/bucket.d.ts.map +1 -0
  41. package/dist/types/builders/embeds.d.ts +146 -0
  42. package/dist/types/builders/embeds.d.ts.map +1 -0
  43. package/dist/types/builders.d.ts +4 -0
  44. package/dist/types/builders.d.ts.map +1 -0
  45. package/dist/types/casing.d.ts.map +1 -0
  46. package/dist/types/colors.d.ts.map +1 -0
  47. package/dist/types/hash.d.ts.map +1 -0
  48. package/dist/types/images.d.ts.map +1 -0
  49. package/dist/{index.d.ts → types/index.d.ts} +3 -1
  50. package/dist/types/index.d.ts.map +1 -0
  51. package/dist/types/logger.d.ts.map +1 -0
  52. package/dist/types/oauth2.d.ts +58 -0
  53. package/dist/types/oauth2.d.ts.map +1 -0
  54. package/dist/types/permissions.d.ts.map +1 -0
  55. package/dist/types/reactions.d.ts.map +1 -0
  56. package/dist/{token.d.ts → types/token.d.ts} +1 -1
  57. package/dist/types/token.d.ts.map +1 -0
  58. package/dist/{typeguards.d.ts → types/typeguards.d.ts} +2 -1
  59. package/dist/types/typeguards.d.ts.map +1 -0
  60. package/dist/types/urlToBase64.d.ts.map +1 -0
  61. package/dist/types/utils.d.ts.map +1 -0
  62. package/package.json +12 -6
  63. package/dist/Collection.d.ts.map +0 -1
  64. package/dist/Collection.js +0 -113
  65. package/dist/Collection.js.map +0 -1
  66. package/dist/base64.d.ts.map +0 -1
  67. package/dist/base64.js +0 -262
  68. package/dist/base64.js.map +0 -1
  69. package/dist/bucket.d.ts.map +0 -1
  70. package/dist/bucket.js +0 -76
  71. package/dist/bucket.js.map +0 -1
  72. package/dist/casing.d.ts.map +0 -1
  73. package/dist/casing.js +0 -51
  74. package/dist/casing.js.map +0 -1
  75. package/dist/colors.d.ts.map +0 -1
  76. package/dist/colors.js +0 -467
  77. package/dist/colors.js.map +0 -1
  78. package/dist/hash.d.ts.map +0 -1
  79. package/dist/hash.js +0 -19
  80. package/dist/hash.js.map +0 -1
  81. package/dist/images.d.ts.map +0 -1
  82. package/dist/images.js +0 -66
  83. package/dist/images.js.map +0 -1
  84. package/dist/index.d.ts.map +0 -1
  85. package/dist/index.js +0 -16
  86. package/dist/index.js.map +0 -1
  87. package/dist/interactions.d.ts +0 -3
  88. package/dist/interactions.d.ts.map +0 -1
  89. package/dist/interactions.js +0 -41
  90. package/dist/interactions.js.map +0 -1
  91. package/dist/logger.d.ts.map +0 -1
  92. package/dist/logger.js +0 -130
  93. package/dist/logger.js.map +0 -1
  94. package/dist/permissions.d.ts.map +0 -1
  95. package/dist/permissions.js +0 -17
  96. package/dist/permissions.js.map +0 -1
  97. package/dist/reactions.d.ts.map +0 -1
  98. package/dist/reactions.js +0 -11
  99. package/dist/reactions.js.map +0 -1
  100. package/dist/token.d.ts.map +0 -1
  101. package/dist/token.js +0 -16
  102. package/dist/token.js.map +0 -1
  103. package/dist/typeguards.d.ts.map +0 -1
  104. package/dist/typeguards.js +0 -15
  105. package/dist/typeguards.js.map +0 -1
  106. package/dist/urlToBase64.d.ts.map +0 -1
  107. package/dist/urlToBase64.js +0 -9
  108. package/dist/urlToBase64.js.map +0 -1
  109. package/dist/utils.d.ts.map +0 -1
  110. package/dist/utils.js +0 -15
  111. package/dist/utils.js.map +0 -1
  112. /package/dist/{Collection.d.ts → types/Collection.d.ts} +0 -0
  113. /package/dist/{base64.d.ts → types/base64.d.ts} +0 -0
  114. /package/dist/{casing.d.ts → types/casing.d.ts} +0 -0
  115. /package/dist/{colors.d.ts → types/colors.d.ts} +0 -0
  116. /package/dist/{hash.d.ts → types/hash.d.ts} +0 -0
  117. /package/dist/{images.d.ts → types/images.d.ts} +0 -0
  118. /package/dist/{logger.d.ts → types/logger.d.ts} +0 -0
  119. /package/dist/{permissions.d.ts → types/permissions.d.ts} +0 -0
  120. /package/dist/{reactions.d.ts → types/reactions.d.ts} +0 -0
  121. /package/dist/{urlToBase64.d.ts → types/urlToBase64.d.ts} +0 -0
  122. /package/dist/{utils.d.ts → types/utils.d.ts} +0 -0
@@ -0,0 +1,262 @@
1
+ /**
2
+ * CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727
3
+ * Encodes a given Uint8Array, ArrayBuffer or string into RFC4648 base64 representation
4
+ * @param data
5
+ */ export function encode(data) {
6
+ const uint8 = typeof data === 'string' ? new TextEncoder().encode(data) : data instanceof Uint8Array ? data : new Uint8Array(data);
7
+ let result = '';
8
+ let i;
9
+ const l = uint8.length;
10
+ for(i = 2; i < l; i += 3){
11
+ result += base64abc[uint8[i - 2] >> 2];
12
+ result += base64abc[(uint8[i - 2] & 0x03) << 4 | uint8[i - 1] >> 4];
13
+ result += base64abc[(uint8[i - 1] & 0x0f) << 2 | uint8[i] >> 6];
14
+ result += base64abc[uint8[i] & 0x3f];
15
+ }
16
+ if (i === l + 1) {
17
+ // 1 octet yet to write
18
+ result += base64abc[uint8[i - 2] >> 2];
19
+ result += base64abc[(uint8[i - 2] & 0x03) << 4];
20
+ result += '==';
21
+ }
22
+ if (i === l) {
23
+ // 2 octets yet to write
24
+ result += base64abc[uint8[i - 2] >> 2];
25
+ result += base64abc[(uint8[i - 2] & 0x03) << 4 | uint8[i - 1] >> 4];
26
+ result += base64abc[(uint8[i - 1] & 0x0f) << 2];
27
+ result += '=';
28
+ }
29
+ return result;
30
+ }
31
+ /**
32
+ * CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727
33
+ * Decodes RFC4648 base64 string into an Uint8Array
34
+ * @param data
35
+ */ export function decode(data) {
36
+ if (data.length % 4 !== 0) {
37
+ throw new Error('Unable to parse base64 string.');
38
+ }
39
+ const index = data.indexOf('=');
40
+ if (index !== -1 && index < data.length - 2) {
41
+ throw new Error('Unable to parse base64 string.');
42
+ }
43
+ const missingOctets = data.endsWith('==') ? 2 : data.endsWith('=') ? 1 : 0;
44
+ const n = data.length;
45
+ const result = new Uint8Array(3 * (n / 4));
46
+ let buffer;
47
+ for(let i = 0, j = 0; i < n; i += 4, j += 3){
48
+ buffer = getBase64Code(data.charCodeAt(i)) << 18 | getBase64Code(data.charCodeAt(i + 1)) << 12 | getBase64Code(data.charCodeAt(i + 2)) << 6 | getBase64Code(data.charCodeAt(i + 3));
49
+ result[j] = buffer >> 16;
50
+ result[j + 1] = buffer >> 8 & 0xff;
51
+ result[j + 2] = buffer & 0xff;
52
+ }
53
+ return result.subarray(0, result.length - missingOctets);
54
+ }
55
+ /**
56
+ * CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727
57
+ * @param charCode
58
+ */ function getBase64Code(charCode) {
59
+ if (charCode >= base64codes.length) {
60
+ throw new Error('Unable to parse base64 string.');
61
+ }
62
+ const code = base64codes[charCode];
63
+ if (code === 255) {
64
+ throw new Error('Unable to parse base64 string.');
65
+ }
66
+ return code;
67
+ }
68
+ // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
69
+ const base64abc = [
70
+ 'A',
71
+ 'B',
72
+ 'C',
73
+ 'D',
74
+ 'E',
75
+ 'F',
76
+ 'G',
77
+ 'H',
78
+ 'I',
79
+ 'J',
80
+ 'K',
81
+ 'L',
82
+ 'M',
83
+ 'N',
84
+ 'O',
85
+ 'P',
86
+ 'Q',
87
+ 'R',
88
+ 'S',
89
+ 'T',
90
+ 'U',
91
+ 'V',
92
+ 'W',
93
+ 'X',
94
+ 'Y',
95
+ 'Z',
96
+ 'a',
97
+ 'b',
98
+ 'c',
99
+ 'd',
100
+ 'e',
101
+ 'f',
102
+ 'g',
103
+ 'h',
104
+ 'i',
105
+ 'j',
106
+ 'k',
107
+ 'l',
108
+ 'm',
109
+ 'n',
110
+ 'o',
111
+ 'p',
112
+ 'q',
113
+ 'r',
114
+ 's',
115
+ 't',
116
+ 'u',
117
+ 'v',
118
+ 'w',
119
+ 'x',
120
+ 'y',
121
+ 'z',
122
+ '0',
123
+ '1',
124
+ '2',
125
+ '3',
126
+ '4',
127
+ '5',
128
+ '6',
129
+ '7',
130
+ '8',
131
+ '9',
132
+ '+',
133
+ '/'
134
+ ];
135
+ // CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727
136
+ const base64codes = [
137
+ 255,
138
+ 255,
139
+ 255,
140
+ 255,
141
+ 255,
142
+ 255,
143
+ 255,
144
+ 255,
145
+ 255,
146
+ 255,
147
+ 255,
148
+ 255,
149
+ 255,
150
+ 255,
151
+ 255,
152
+ 255,
153
+ 255,
154
+ 255,
155
+ 255,
156
+ 255,
157
+ 255,
158
+ 255,
159
+ 255,
160
+ 255,
161
+ 255,
162
+ 255,
163
+ 255,
164
+ 255,
165
+ 255,
166
+ 255,
167
+ 255,
168
+ 255,
169
+ 255,
170
+ 255,
171
+ 255,
172
+ 255,
173
+ 255,
174
+ 255,
175
+ 255,
176
+ 255,
177
+ 255,
178
+ 255,
179
+ 255,
180
+ 62,
181
+ 255,
182
+ 255,
183
+ 255,
184
+ 63,
185
+ 52,
186
+ 53,
187
+ 54,
188
+ 55,
189
+ 56,
190
+ 57,
191
+ 58,
192
+ 59,
193
+ 60,
194
+ 61,
195
+ 255,
196
+ 255,
197
+ 255,
198
+ 0,
199
+ 255,
200
+ 255,
201
+ 255,
202
+ 0,
203
+ 1,
204
+ 2,
205
+ 3,
206
+ 4,
207
+ 5,
208
+ 6,
209
+ 7,
210
+ 8,
211
+ 9,
212
+ 10,
213
+ 11,
214
+ 12,
215
+ 13,
216
+ 14,
217
+ 15,
218
+ 16,
219
+ 17,
220
+ 18,
221
+ 19,
222
+ 20,
223
+ 21,
224
+ 22,
225
+ 23,
226
+ 24,
227
+ 25,
228
+ 255,
229
+ 255,
230
+ 255,
231
+ 255,
232
+ 255,
233
+ 255,
234
+ 26,
235
+ 27,
236
+ 28,
237
+ 29,
238
+ 30,
239
+ 31,
240
+ 32,
241
+ 33,
242
+ 34,
243
+ 35,
244
+ 36,
245
+ 37,
246
+ 38,
247
+ 39,
248
+ 40,
249
+ 41,
250
+ 42,
251
+ 43,
252
+ 44,
253
+ 45,
254
+ 46,
255
+ 47,
256
+ 48,
257
+ 49,
258
+ 50,
259
+ 51
260
+ ];
261
+
262
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iYXNlNjQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDUkVESVQ6IGh0dHBzOi8vZ2lzdC5naXRodWIuY29tL2VuZXBvbW55YXNjaGloLzcyYzQyM2Y3MjdkMzk1ZWVhYTA5Njk3MDU4MjM4NzI3XG4gKiBFbmNvZGVzIGEgZ2l2ZW4gVWludDhBcnJheSwgQXJyYXlCdWZmZXIgb3Igc3RyaW5nIGludG8gUkZDNDY0OCBiYXNlNjQgcmVwcmVzZW50YXRpb25cbiAqIEBwYXJhbSBkYXRhXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBlbmNvZGUoZGF0YTogQXJyYXlCdWZmZXIgfCBzdHJpbmcpOiBzdHJpbmcge1xuICBjb25zdCB1aW50OCA9IHR5cGVvZiBkYXRhID09PSAnc3RyaW5nJyA/IG5ldyBUZXh0RW5jb2RlcigpLmVuY29kZShkYXRhKSA6IGRhdGEgaW5zdGFuY2VvZiBVaW50OEFycmF5ID8gZGF0YSA6IG5ldyBVaW50OEFycmF5KGRhdGEpXG4gIGxldCByZXN1bHQgPSAnJ1xuICBsZXQgaVxuICBjb25zdCBsID0gdWludDgubGVuZ3RoXG4gIGZvciAoaSA9IDI7IGkgPCBsOyBpICs9IDMpIHtcbiAgICByZXN1bHQgKz0gYmFzZTY0YWJjW3VpbnQ4W2kgLSAyXSA+PiAyXVxuICAgIHJlc3VsdCArPSBiYXNlNjRhYmNbKCh1aW50OFtpIC0gMl0gJiAweDAzKSA8PCA0KSB8ICh1aW50OFtpIC0gMV0gPj4gNCldXG4gICAgcmVzdWx0ICs9IGJhc2U2NGFiY1soKHVpbnQ4W2kgLSAxXSAmIDB4MGYpIDw8IDIpIHwgKHVpbnQ4W2ldID4+IDYpXVxuICAgIHJlc3VsdCArPSBiYXNlNjRhYmNbdWludDhbaV0gJiAweDNmXVxuICB9XG4gIGlmIChpID09PSBsICsgMSkge1xuICAgIC8vIDEgb2N0ZXQgeWV0IHRvIHdyaXRlXG4gICAgcmVzdWx0ICs9IGJhc2U2NGFiY1t1aW50OFtpIC0gMl0gPj4gMl1cbiAgICByZXN1bHQgKz0gYmFzZTY0YWJjWyh1aW50OFtpIC0gMl0gJiAweDAzKSA8PCA0XVxuICAgIHJlc3VsdCArPSAnPT0nXG4gIH1cbiAgaWYgKGkgPT09IGwpIHtcbiAgICAvLyAyIG9jdGV0cyB5ZXQgdG8gd3JpdGVcbiAgICByZXN1bHQgKz0gYmFzZTY0YWJjW3VpbnQ4W2kgLSAyXSA+PiAyXVxuICAgIHJlc3VsdCArPSBiYXNlNjRhYmNbKCh1aW50OFtpIC0gMl0gJiAweDAzKSA8PCA0KSB8ICh1aW50OFtpIC0gMV0gPj4gNCldXG4gICAgcmVzdWx0ICs9IGJhc2U2NGFiY1sodWludDhbaSAtIDFdICYgMHgwZikgPDwgMl1cbiAgICByZXN1bHQgKz0gJz0nXG4gIH1cbiAgcmV0dXJuIHJlc3VsdFxufVxuXG4vKipcbiAqIENSRURJVDogaHR0cHM6Ly9naXN0LmdpdGh1Yi5jb20vZW5lcG9tbnlhc2NoaWgvNzJjNDIzZjcyN2QzOTVlZWFhMDk2OTcwNTgyMzg3MjdcbiAqIERlY29kZXMgUkZDNDY0OCBiYXNlNjQgc3RyaW5nIGludG8gYW4gVWludDhBcnJheVxuICogQHBhcmFtIGRhdGFcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGRlY29kZShkYXRhOiBzdHJpbmcpOiBVaW50OEFycmF5IHtcbiAgaWYgKGRhdGEubGVuZ3RoICUgNCAhPT0gMCkge1xuICAgIHRocm93IG5ldyBFcnJvcignVW5hYmxlIHRvIHBhcnNlIGJhc2U2NCBzdHJpbmcuJylcbiAgfVxuICBjb25zdCBpbmRleCA9IGRhdGEuaW5kZXhPZignPScpXG4gIGlmIChpbmRleCAhPT0gLTEgJiYgaW5kZXggPCBkYXRhLmxlbmd0aCAtIDIpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1VuYWJsZSB0byBwYXJzZSBiYXNlNjQgc3RyaW5nLicpXG4gIH1cbiAgY29uc3QgbWlzc2luZ09jdGV0cyA9IGRhdGEuZW5kc1dpdGgoJz09JykgPyAyIDogZGF0YS5lbmRzV2l0aCgnPScpID8gMSA6IDBcbiAgY29uc3QgbiA9IGRhdGEubGVuZ3RoXG4gIGNvbnN0IHJlc3VsdCA9IG5ldyBVaW50OEFycmF5KDMgKiAobiAvIDQpKVxuICBsZXQgYnVmZmVyXG4gIGZvciAobGV0IGkgPSAwLCBqID0gMDsgaSA8IG47IGkgKz0gNCwgaiArPSAzKSB7XG4gICAgYnVmZmVyID1cbiAgICAgIChnZXRCYXNlNjRDb2RlKGRhdGEuY2hhckNvZGVBdChpKSkgPDwgMTgpIHxcbiAgICAgIChnZXRCYXNlNjRDb2RlKGRhdGEuY2hhckNvZGVBdChpICsgMSkpIDw8IDEyKSB8XG4gICAgICAoZ2V0QmFzZTY0Q29kZShkYXRhLmNoYXJDb2RlQXQoaSArIDIpKSA8PCA2KSB8XG4gICAgICBnZXRCYXNlNjRDb2RlKGRhdGEuY2hhckNvZGVBdChpICsgMykpXG4gICAgcmVzdWx0W2pdID0gYnVmZmVyID4+IDE2XG4gICAgcmVzdWx0W2ogKyAxXSA9IChidWZmZXIgPj4gOCkgJiAweGZmXG4gICAgcmVzdWx0W2ogKyAyXSA9IGJ1ZmZlciAmIDB4ZmZcbiAgfVxuICByZXR1cm4gcmVzdWx0LnN1YmFycmF5KDAsIHJlc3VsdC5sZW5ndGggLSBtaXNzaW5nT2N0ZXRzKVxufVxuXG4vKipcbiAqIENSRURJVDogaHR0cHM6Ly9naXN0LmdpdGh1Yi5jb20vZW5lcG9tbnlhc2NoaWgvNzJjNDIzZjcyN2QzOTVlZWFhMDk2OTcwNTgyMzg3MjdcbiAqIEBwYXJhbSBjaGFyQ29kZVxuICovXG5mdW5jdGlvbiBnZXRCYXNlNjRDb2RlKGNoYXJDb2RlOiBudW1iZXIpOiBudW1iZXIge1xuICBpZiAoY2hhckNvZGUgPj0gYmFzZTY0Y29kZXMubGVuZ3RoKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdVbmFibGUgdG8gcGFyc2UgYmFzZTY0IHN0cmluZy4nKVxuICB9XG4gIGNvbnN0IGNvZGUgPSBiYXNlNjRjb2Rlc1tjaGFyQ29kZV1cbiAgaWYgKGNvZGUgPT09IDI1NSkge1xuICAgIHRocm93IG5ldyBFcnJvcignVW5hYmxlIHRvIHBhcnNlIGJhc2U2NCBzdHJpbmcuJylcbiAgfVxuICByZXR1cm4gY29kZVxufVxuXG4vLyBDb3B5cmlnaHQgMjAxOC0yMDIxIHRoZSBEZW5vIGF1dGhvcnMuIEFsbCByaWdodHMgcmVzZXJ2ZWQuIE1JVCBsaWNlbnNlLlxuY29uc3QgYmFzZTY0YWJjID0gW1xuICAnQScsXG4gICdCJyxcbiAgJ0MnLFxuICAnRCcsXG4gICdFJyxcbiAgJ0YnLFxuICAnRycsXG4gICdIJyxcbiAgJ0knLFxuICAnSicsXG4gICdLJyxcbiAgJ0wnLFxuICAnTScsXG4gICdOJyxcbiAgJ08nLFxuICAnUCcsXG4gICdRJyxcbiAgJ1InLFxuICAnUycsXG4gICdUJyxcbiAgJ1UnLFxuICAnVicsXG4gICdXJyxcbiAgJ1gnLFxuICAnWScsXG4gICdaJyxcbiAgJ2EnLFxuICAnYicsXG4gICdjJyxcbiAgJ2QnLFxuICAnZScsXG4gICdmJyxcbiAgJ2cnLFxuICAnaCcsXG4gICdpJyxcbiAgJ2onLFxuICAnaycsXG4gICdsJyxcbiAgJ20nLFxuICAnbicsXG4gICdvJyxcbiAgJ3AnLFxuICAncScsXG4gICdyJyxcbiAgJ3MnLFxuICAndCcsXG4gICd1JyxcbiAgJ3YnLFxuICAndycsXG4gICd4JyxcbiAgJ3knLFxuICAneicsXG4gICcwJyxcbiAgJzEnLFxuICAnMicsXG4gICczJyxcbiAgJzQnLFxuICAnNScsXG4gICc2JyxcbiAgJzcnLFxuICAnOCcsXG4gICc5JyxcbiAgJysnLFxuICAnLycsXG5dXG5cbi8vIENSRURJVDogaHR0cHM6Ly9naXN0LmdpdGh1Yi5jb20vZW5lcG9tbnlhc2NoaWgvNzJjNDIzZjcyN2QzOTVlZWFhMDk2OTcwNTgyMzg3MjdcbmNvbnN0IGJhc2U2NGNvZGVzID0gW1xuICAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSxcbiAgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDYyLCAyNTUsIDI1NSwgMjU1LCA2MywgNTIsIDUzLCA1NCwgNTUsIDU2LCA1NywgNTgsIDU5LCA2MCwgNjEsIDI1NSwgMjU1LCAyNTUsXG4gIDAsIDI1NSwgMjU1LCAyNTUsIDAsIDEsIDIsIDMsIDQsIDUsIDYsIDcsIDgsIDksIDEwLCAxMSwgMTIsIDEzLCAxNCwgMTUsIDE2LCAxNywgMTgsIDE5LCAyMCwgMjEsIDIyLCAyMywgMjQsIDI1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNixcbiAgMjcsIDI4LCAyOSwgMzAsIDMxLCAzMiwgMzMsIDM0LCAzNSwgMzYsIDM3LCAzOCwgMzksIDQwLCA0MSwgNDIsIDQzLCA0NCwgNDUsIDQ2LCA0NywgNDgsIDQ5LCA1MCwgNTEsXG5dXG4iXSwibmFtZXMiOlsiZW5jb2RlIiwiZGF0YSIsInVpbnQ4IiwiVGV4dEVuY29kZXIiLCJVaW50OEFycmF5IiwicmVzdWx0IiwiaSIsImwiLCJsZW5ndGgiLCJiYXNlNjRhYmMiLCJkZWNvZGUiLCJFcnJvciIsImluZGV4IiwiaW5kZXhPZiIsIm1pc3NpbmdPY3RldHMiLCJlbmRzV2l0aCIsIm4iLCJidWZmZXIiLCJqIiwiZ2V0QmFzZTY0Q29kZSIsImNoYXJDb2RlQXQiLCJzdWJhcnJheSIsImNoYXJDb2RlIiwiYmFzZTY0Y29kZXMiLCJjb2RlIl0sIm1hcHBpbmdzIjoiQUFBQTs7OztDQUlDLEdBQ0QsT0FBTyxTQUFTQSxPQUFPQyxJQUEwQixFQUFVO0lBQ3pELE1BQU1DLFFBQVEsT0FBT0QsU0FBUyxXQUFXLElBQUlFLGNBQWNILE1BQU0sQ0FBQ0MsUUFBUUEsZ0JBQWdCRyxhQUFhSCxPQUFPLElBQUlHLFdBQVdILEtBQUs7SUFDbEksSUFBSUksU0FBUztJQUNiLElBQUlDO0lBQ0osTUFBTUMsSUFBSUwsTUFBTU0sTUFBTTtJQUN0QixJQUFLRixJQUFJLEdBQUdBLElBQUlDLEdBQUdELEtBQUssRUFBRztRQUN6QkQsVUFBVUksU0FB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V0FBVyxDQUFDRCxTQUFTO0lBQ2xDLElBQUlFLFNBQVMsS0FBSztRQUNoQixNQUFNLElBQUliLE1BQU0sa0NBQWlDO0lBQ25ELENBQUM7SUFDRCxPQUFPYTtBQUNUO0FBRUEsMEVBQTBFO0FBQzFFLE1BQU1mLFlBQVk7SUFDaEI7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7Q0FDRDtBQUVELGtGQUFrRjtBQUNsRixNQUFNYyxjQUFjO0lBQ2xCO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFDNUk7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUk7SUFBSztJQUFLO0lBQUs7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUs7SUFBSztJQUMvSTtJQUFHO0lBQUs7SUFBSztJQUFLO0lBQUc7SUFBRztJQUFHO0lBQUc7SUFBRztJQUFHO0lBQUc7SUFBRztJQUFHO0lBQUc7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUM5STtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtDQUNqRyJ9
@@ -0,0 +1,80 @@
1
+ import logger from './logger.js';
2
+ import { delay } from './utils.js';
3
+ export class LeakyBucket {
4
+ constructor(options){
5
+ /** The amount of requests that have been used up already. */ this.used = 0;
6
+ /** The queue of requests to acquire an available request. Mapped by <shardId, resolve()> */ this.queue = [];
7
+ /** Whether or not the queue is already processing. */ this.processing = false;
8
+ this.max = options?.max ?? 1;
9
+ this.refillAmount = options?.refillAmount ? options.refillAmount > this.max ? this.max : options.refillAmount : 1;
10
+ this.refillInterval = options?.refillInterval ?? 5000;
11
+ }
12
+ /** The amount of requests that still remain. */ get remaining() {
13
+ return this.max < this.used ? 0 : this.max - this.used;
14
+ }
15
+ /** Refills the bucket as needed. */ refillBucket() {
16
+ logger.debug(`[LeakyBucket] Timeout for leaky bucket requests executed. Refilling bucket.`);
17
+ // Lower the used amount by the refill amount
18
+ this.used = this.refillAmount > this.used ? 0 : this.used - this.refillAmount;
19
+ // Reset the refillsAt timestamp since it just got refilled
20
+ this.refillsAt = undefined;
21
+ // Reset the timeoutId
22
+ clearTimeout(this.timeoutId);
23
+ this.timeoutId = undefined;
24
+ if (this.used > 0) {
25
+ this.timeoutId = setTimeout(()=>{
26
+ this.refillBucket();
27
+ }, this.refillInterval);
28
+ this.refillsAt = Date.now() + this.refillInterval;
29
+ }
30
+ }
31
+ /** Begin processing the queue. */ async processQueue() {
32
+ logger.debug('[LeakyBucket] Processing queue');
33
+ // There is already a queue that is processing
34
+ if (this.processing) return logger.debug('[LeakyBucket] Queue is already processing.');
35
+ this.processing = true;
36
+ // Begin going through the queue.
37
+ while(this.queue.length){
38
+ if (this.remaining) {
39
+ logger.debug(`[LeakyBucket] Processing queue. Remaining: ${this.remaining} Length: ${this.queue.length}`);
40
+ // Resolves the promise allowing the paused execution of this request to resolve and continue.
41
+ this.queue.shift()?.();
42
+ // A request can be made
43
+ this.used++;
44
+ // Create a new timeout for this request if none exists.
45
+ if (!this.timeoutId) {
46
+ logger.debug(`[LeakyBucket] Creating new timeout for leaky bucket requests.`);
47
+ this.timeoutId = setTimeout(()=>{
48
+ this.refillBucket();
49
+ }, this.refillInterval);
50
+ // Set the time for when this refill will occur.
51
+ this.refillsAt = Date.now() + this.refillInterval;
52
+ }
53
+ } else if (this.refillsAt) {
54
+ const now = Date.now();
55
+ // If there is time left until next refill, just delay execution.
56
+ if (this.refillsAt > now) {
57
+ logger.debug(`[LeakyBucket] Delaying execution of leaky bucket requests for ${this.refillsAt - now}ms`);
58
+ await delay(this.refillsAt - now);
59
+ logger.debug(`[LeakyBucket] Resuming execution`);
60
+ } else {
61
+ logger.debug(`[LeakyBucket] Delaying execution of leaky bucket requests for 1000ms`);
62
+ await delay(1000);
63
+ }
64
+ }
65
+ }
66
+ // Loop has ended mark false so it can restart later when needed
67
+ this.processing = false;
68
+ }
69
+ /** Pauses the execution until the request is available to be made. */ async acquire(highPriority) {
70
+ return await new Promise((resolve)=>{
71
+ // High priority requests get added to the start of the queue
72
+ if (highPriority) this.queue.unshift(resolve);
73
+ else this.queue.push(resolve);
74
+ // Each request should trigger the queue to be processed.
75
+ void this.processQueue();
76
+ });
77
+ }
78
+ }
79
+
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9idWNrZXQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGxvZ2dlciBmcm9tICcuL2xvZ2dlci5qcydcbmltcG9ydCB7IGRlbGF5IH0gZnJvbSAnLi91dGlscy5qcydcblxuZXhwb3J0IGNsYXNzIExlYWt5QnVja2V0IGltcGxlbWVudHMgTGVha3lCdWNrZXRPcHRpb25zIHtcbiAgbWF4OiBudW1iZXJcbiAgcmVmaWxsSW50ZXJ2YWw6IG51bWJlclxuICByZWZpbGxBbW91bnQ6IG51bWJlclxuXG4gIC8qKiBUaGUgYW1vdW50IG9mIHJlcXVlc3RzIHRoYXQgaGF2ZSBiZWVuIHVzZWQgdXAgYWxyZWFkeS4gKi9cbiAgdXNlZDogbnVtYmVyID0gMFxuICAvKiogVGhlIHF1ZXVlIG9mIHJlcXVlc3RzIHRvIGFjcXVpcmUgYW4gYXZhaWxhYmxlIHJlcXVlc3QuIE1hcHBlZCBieSA8c2hhcmRJZCwgcmVzb2x2ZSgpPiAqL1xuICBxdWV1ZTogQXJyYXk8KHZhbHVlOiB2b2lkIHwgUHJvbWlzZUxpa2U8dm9pZD4pID0+IHZvaWQ+ID0gW11cbiAgLyoqIFdoZXRoZXIgb3Igbm90IHRoZSBxdWV1ZSBpcyBhbHJlYWR5IHByb2Nlc3NpbmcuICovXG4gIHByb2Nlc3Npbmc6IGJvb2xlYW4gPSBmYWxzZVxuICAvKiogVGhlIHRpbWVvdXQgaWQgZm9yIHRoZSB0aW1lciB0byByZWR1Y2UgdGhlIHVzZWQgYW1vdW50IGJ5IHRoZSByZWZpbGwgYW1vdW50LiAqL1xuICB0aW1lb3V0SWQ/OiBOb2RlSlMuVGltZW91dFxuICAvKiogVGhlIHRpbWVzdGFtcCBpbiBtaWxsaXNlY29uZHMgd2hlbiB0aGUgbmV4dCByZWZpbGwgaXMgc2NoZWR1bGVkLiAqL1xuICByZWZpbGxzQXQ/OiBudW1iZXJcblxuICBjb25zdHJ1Y3RvcihvcHRpb25zPzogTGVha3lCdWNrZXRPcHRpb25zKSB7XG4gICAgdGhpcy5tYXggPSBvcHRpb25zPy5tYXggPz8gMVxuICAgIHRoaXMucmVmaWxsQW1vdW50ID0gb3B0aW9ucz8ucmVmaWxsQW1vdW50ID8gKG9wdGlvbnMucmVmaWxsQW1vdW50ID4gdGhpcy5tYXggPyB0aGlzLm1heCA6IG9wdGlvbnMucmVmaWxsQW1vdW50KSA6IDFcbiAgICB0aGlzLnJlZmlsbEludGVydmFsID0gb3B0aW9ucz8ucmVmaWxsSW50ZXJ2YWwgPz8gNTAwMFxuICB9XG5cbiAgLyoqIFRoZSBhbW91bnQgb2YgcmVxdWVzdHMgdGhhdCBzdGlsbCByZW1haW4uICovXG4gIGdldCByZW1haW5pbmcoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy5tYXggPCB0aGlzLnVzZWQgPyAwIDogdGhpcy5tYXggLSB0aGlzLnVzZWRcbiAgfVxuXG4gIC8qKiBSZWZpbGxzIHRoZSBidWNrZXQgYXMgbmVlZGVkLiAqL1xuICByZWZpbGxCdWNrZXQoKTogdm9pZCB7XG4gICAgbG9nZ2VyLmRlYnVnKGBbTGVha3lCdWNrZXRdIFRpbWVvdXQgZm9yIGxlYWt5IGJ1Y2tldCByZXF1ZXN0cyBleGVjdXRlZC4gUmVmaWxsaW5nIGJ1Y2tldC5gKVxuICAgIC8vIExvd2VyIHRoZSB1c2VkIGFtb3VudCBieSB0aGUgcmVmaWxsIGFtb3VudFxuICAgIHRoaXMudXNlZCA9IHRoaXMucmVmaWxsQW1vdW50ID4gdGhpcy51c2VkID8gMCA6IHRoaXMudXNlZCAtIHRoaXMucmVmaWxsQW1vdW50XG4gICAgLy8gUmVzZXQgdGhlIHJlZmlsbHNBdCB0aW1lc3RhbXAgc2luY2UgaXQganVzdCBnb3QgcmVmaWxsZWRcbiAgICB0aGlzLnJlZmlsbHNBdCA9IHVuZGVmaW5lZFxuICAgIC8vIFJlc2V0IHRoZSB0aW1lb3V0SWRcbiAgICBjbGVhclRpbWVvdXQodGhpcy50aW1lb3V0SWQpXG4gICAgdGhpcy50aW1lb3V0SWQgPSB1bmRlZmluZWRcblxuICAgIGlmICh0aGlzLnVzZWQgPiAwKSB7XG4gICAgICB0aGlzLnRpbWVvdXRJZCA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICB0aGlzLnJlZmlsbEJ1Y2tldCgpXG4gICAgICB9LCB0aGlzLnJlZmlsbEludGVydmFsKVxuICAgICAgdGhpcy5yZWZpbGxzQXQgPSBEYXRlLm5vdygpICsgdGhpcy5yZWZpbGxJbnRlcnZhbFxuICAgIH1cbiAgfVxuXG4gIC8qKiBCZWdpbiBwcm9jZXNzaW5nIHRoZSBxdWV1ZS4gKi9cbiAgYXN5bmMgcHJvY2Vzc1F1ZXVlKCk6IFByb21pc2U8dm9pZD4ge1xuICAgIGxvZ2dlci5kZWJ1ZygnW0xlYWt5QnVja2V0XSBQcm9jZXNzaW5nIHF1ZXVlJylcblxuICAgIC8vIFRoZXJlIGlzIGFscmVhZHkgYSBxdWV1ZSB0aGF0IGlzIHByb2Nlc3NpbmdcbiAgICBpZiAodGhpcy5wcm9jZXNzaW5nKSByZXR1cm4gbG9nZ2VyLmRlYnVnKCdbTGVha3lCdWNrZXRdIFF1ZXVlIGlzIGFscmVhZHkgcHJvY2Vzc2luZy4nKVxuXG4gICAgdGhpcy5wcm9jZXNzaW5nID0gdHJ1ZVxuXG4gICAgLy8gQmVnaW4gZ29pbmcgdGhyb3VnaCB0aGUgcXVldWUuXG4gICAgd2hpbGUgKHRoaXMucXVldWUubGVuZ3RoKSB7XG4gICAgICBpZiAodGhpcy5yZW1haW5pbmcpIHtcbiAgICAgICAgbG9nZ2VyLmRlYnVnKGBbTGVha3lCdWNrZXRdIFByb2Nlc3NpbmcgcXVldWUuIFJlbWFpbmluZzogJHt0aGlzLnJlbWFpbmluZ30gTGVuZ3RoOiAke3RoaXMucXVldWUubGVuZ3RofWApXG4gICAgICAgIC8vIFJlc29sdmVzIHRoZSBwcm9taXNlIGFsbG93aW5nIHRoZSBwYXVzZWQgZXhlY3V0aW9uIG9mIHRoaXMgcmVxdWVzdCB0byByZXNvbHZlIGFuZCBjb250aW51ZS5cbiAgICAgICAgdGhpcy5xdWV1ZS5zaGlmdCgpPy4oKVxuICAgICAgICAvLyBBIHJlcXVlc3QgY2FuIGJlIG1hZGVcbiAgICAgICAgdGhpcy51c2VkKytcblxuICAgICAgICAvLyBDcmVhdGUgYSBuZXcgdGltZW91dCBmb3IgdGhpcyByZXF1ZXN0IGlmIG5vbmUgZXhpc3RzLlxuICAgICAgICBpZiAoIXRoaXMudGltZW91dElkKSB7XG4gICAgICAgICAgbG9nZ2VyLmRlYnVnKGBbTGVha3lCdWNrZXRdIENyZWF0aW5nIG5ldyB0aW1lb3V0IGZvciBsZWFreSBidWNrZXQgcmVxdWVzdHMuYClcblxuICAgICAgICAgIHRoaXMudGltZW91dElkID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgICB0aGlzLnJlZmlsbEJ1Y2tldCgpXG4gICAgICAgICAgfSwgdGhpcy5yZWZpbGxJbnRlcnZhbClcbiAgICAgICAgICAvLyBTZXQgdGhlIHRpbWUgZm9yIHdoZW4gdGhpcyByZWZpbGwgd2lsbCBvY2N1ci5cbiAgICAgICAgICB0aGlzLnJlZmlsbHNBdCA9IERhdGUubm93KCkgKyB0aGlzLnJlZmlsbEludGVydmFsXG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgLy8gQ2hlY2sgaWYgYSByZWZpbGwgaXMgc2NoZWR1bGVkLCBzaW5jZSB3ZSBoYXZlIHVzZWQgdXAgYWxsIGF2YWlsYWJsZSByZXF1ZXN0c1xuICAgICAgZWxzZSBpZiAodGhpcy5yZWZpbGxzQXQpIHtcbiAgICAgICAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKVxuICAgICAgICAvLyBJZiB0aGVyZSBpcyB0aW1lIGxlZnQgdW50aWwgbmV4dCByZWZpbGwsIGp1c3QgZGVsYXkgZXhlY3V0aW9uLlxuICAgICAgICBpZiAodGhpcy5yZWZpbGxzQXQgPiBub3cpIHtcbiAgICAgICAgICBsb2dnZXIuZGVidWcoYFtMZWFreUJ1Y2tldF0gRGVsYXlpbmcgZXhlY3V0aW9uIG9mIGxlYWt5IGJ1Y2tldCByZXF1ZXN0cyBmb3IgJHt0aGlzLnJlZmlsbHNBdCAtIG5vd31tc2ApXG4gICAgICAgICAgYXdhaXQgZGVsYXkodGhpcy5yZWZpbGxzQXQgLSBub3cpXG4gICAgICAgICAgbG9nZ2VyLmRlYnVnKGBbTGVha3lCdWNrZXRdIFJlc3VtaW5nIGV4ZWN1dGlvbmApXG4gICAgICAgIH1cblxuICAgICAgICAvLyBJZiB0aGUgcmVmaWxsc0F0IGhhcyBwYXNzZWQgYnV0IHRoZSB0aW1lb3V0IGRpZG4ndCB5ZXQgZXhlY3V0ZSBkZWxheSB0aGUgZXhlY3V0aW9uXG4gICAgICAgIGVsc2Uge1xuICAgICAgICAgIGxvZ2dlci5kZWJ1ZyhgW0xlYWt5QnVja2V0XSBEZWxheWluZyBleGVjdXRpb24gb2YgbGVha3kgYnVja2V0IHJlcXVlc3RzIGZvciAxMDAwbXNgKVxuICAgICAgICAgIGF3YWl0IGRlbGF5KDEwMDApXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICAvLyBMb29wIGhhcyBlbmRlZCBtYXJrIGZhbHNlIHNvIGl0IGNhbiByZXN0YXJ0IGxhdGVyIHdoZW4gbmVlZGVkXG4gICAgdGhpcy5wcm9jZXNzaW5nID0gZmFsc2VcbiAgfVxuXG4gIC8qKiBQYXVzZXMgdGhlIGV4ZWN1dGlvbiB1bnRpbCB0aGUgcmVxdWVzdCBpcyBhdmFpbGFibGUgdG8gYmUgbWFkZS4gKi9cbiAgYXN5bmMgYWNxdWlyZShoaWdoUHJpb3JpdHk/OiBib29sZWFuKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgcmV0dXJuIGF3YWl0IG5ldyBQcm9taXNlKChyZXNvbHZlKSA9PiB7XG4gICAgICAvLyBIaWdoIHByaW9yaXR5IHJlcXVlc3RzIGdldCBhZGRlZCB0byB0aGUgc3RhcnQgb2YgdGhlIHF1ZXVlXG4gICAgICBpZiAoaGlnaFByaW9yaXR5KSB0aGlzLnF1ZXVlLnVuc2hpZnQocmVzb2x2ZSlcbiAgICAgIC8vIEFsbCBvdGhlciByZXF1ZXN0cyBnZXQgcHVzaGVkIHRvIHRoZSBlbmQuXG4gICAgICBlbHNlIHRoaXMucXVldWUucHVzaChyZXNvbHZlKVxuXG4gICAgICAvLyBFYWNoIHJlcXVlc3Qgc2hvdWxkIHRyaWdnZXIgdGhlIHF1ZXVlIHRvIGJlIHByb2Nlc3NlZC5cbiAgICAgIHZvaWQgdGhpcy5wcm9jZXNzUXVldWUoKVxuICAgIH0pXG4gIH1cbn1cblxuZXhwb3J0IGludGVyZmFjZSBMZWFreUJ1Y2tldE9wdGlvbnMge1xuICAvKipcbiAgICogTWF4IHJlcXVlc3RzIGFsbG93ZWQgYXQgb25jZS5cbiAgICogQGRlZmF1bHQgMVxuICAgKi9cbiAgbWF4PzogbnVtYmVyXG4gIC8qKlxuICAgKiBJbnRlcnZhbCBpbiBtaWxsaXNlY29uZHMgYmV0d2VlbiByZWZpbGxzLlxuICAgKiBAZGVmYXVsdCA1MDAwXG4gICAqL1xuICByZWZpbGxJbnRlcnZhbD86IG51bWJlclxuICAvKipcbiAgICogQW1vdW50IG9mIHJlcXVlc3RzIHRvIHJlZmlsbCBhdCBlYWNoIGludGVydmFsLlxuICAgKiBAZGVmYXVsdCAxXG4gICAqL1xuICByZWZpbGxBbW91bnQ/OiBudW1iZXJcbn1cbiJdLCJuYW1lcyI6WyJsb2dnZXIiLCJkZWxheSIsIkxlYWt5QnVja2V0IiwiY29uc3RydWN0b3IiLCJvcHRpb25zIiwidXNlZCIsInF1ZXVlIiwicHJvY2Vzc2luZyIsIm1heCIsInJlZmlsbEFtb3VudCIsInJlZmlsbEludGVydmFsIiwicmVtYWluaW5nIiwicmVmaWxsQnVja2V0IiwiZGVidWciLCJyZWZpbGxzQXQiLCJ1bmRlZmluZWQiLCJjbGVhclRpbWVvdXQiLCJ0aW1lb3V0SWQiLCJzZXRUaW1lb3V0IiwiRGF0ZSIsIm5vdyIsInByb2Nlc3NRdWV1ZSIsImxlbmd0aCIsInNoaWZ0IiwiYWNxdWlyZSIsImhpZ2hQcmlvcml0eSIsIlByb21pc2UiLCJyZXNvbHZlIiwidW5zaGlmdCIsInB1c2giXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLFlBQVksY0FBYTtBQUNoQyxTQUFTQyxLQUFLLFFBQVEsYUFBWTtBQUVsQyxPQUFPLE1BQU1DO0lBZ0JYQyxZQUFZQyxPQUE0QixDQUFFO1FBWDFDLDJEQUEyRCxRQUMzREMsT0FBZTtRQUNmLDBGQUEwRixRQUMxRkMsUUFBMEQsRUFBRTtRQUM1RCxvREFBb0QsUUFDcERDLGFBQXNCLEtBQUs7UUFPekIsSUFBSSxDQUFDQyxHQUFHLEdBQUdKLFNBQVNJLE9BQU87UUFDM0IsSUFBSSxDQUFDQyxZQUFZLEdBQUdMLFNBQVNL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