@discordeno/utils 19.0.0-next.fe00a6f → 19.0.0-next.ffdef6c

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 (129) hide show
  1. package/README.md +6 -143
  2. package/dist/cjs/Collection.cjs +122 -0
  3. package/dist/cjs/base64.cjs +276 -0
  4. package/dist/cjs/bucket.cjs +96 -0
  5. package/dist/cjs/builders/embeds.cjs +291 -0
  6. package/dist/cjs/builders.cjs +27 -0
  7. package/dist/cjs/casing.cjs +79 -0
  8. package/dist/cjs/colors.cjs +456 -0
  9. package/dist/cjs/hash.cjs +37 -0
  10. package/dist/cjs/images.cjs +136 -0
  11. package/dist/cjs/index.cjs +36 -0
  12. package/dist/cjs/logger.cjs +157 -0
  13. package/dist/cjs/oauth2.cjs +26 -0
  14. package/dist/cjs/permissions.cjs +35 -0
  15. package/dist/cjs/reactions.cjs +21 -0
  16. package/dist/cjs/token.cjs +38 -0
  17. package/dist/cjs/typeguards.cjs +52 -0
  18. package/dist/cjs/urlToBase64.cjs +19 -0
  19. package/dist/cjs/urls.cjs +32 -0
  20. package/dist/cjs/utils.cjs +28 -0
  21. package/dist/esm/Collection.js +112 -0
  22. package/dist/esm/base64.js +262 -0
  23. package/dist/esm/bucket.js +81 -0
  24. package/dist/esm/builders/embeds.js +290 -0
  25. package/dist/esm/builders.js +5 -0
  26. package/dist/esm/casing.js +55 -0
  27. package/dist/esm/colors.js +467 -0
  28. package/dist/esm/hash.js +19 -0
  29. package/dist/esm/images.js +179 -0
  30. package/dist/esm/index.js +19 -0
  31. package/dist/esm/logger.js +130 -0
  32. package/dist/esm/oauth2.js +16 -0
  33. package/dist/esm/permissions.js +17 -0
  34. package/dist/esm/reactions.js +11 -0
  35. package/dist/esm/token.js +20 -0
  36. package/dist/esm/typeguards.js +22 -0
  37. package/dist/esm/urlToBase64.js +9 -0
  38. package/dist/esm/urls.js +11 -0
  39. package/dist/esm/utils.js +12 -0
  40. package/dist/{Collection.d.ts → types/Collection.d.ts} +2 -3
  41. package/dist/types/Collection.d.ts.map +1 -0
  42. package/dist/types/base64.d.ts.map +1 -0
  43. package/dist/{bucket.d.ts → types/bucket.d.ts} +9 -2
  44. package/dist/types/bucket.d.ts.map +1 -0
  45. package/dist/types/builders/embeds.d.ts +142 -0
  46. package/dist/types/builders/embeds.d.ts.map +1 -0
  47. package/dist/types/builders.d.ts +4 -0
  48. package/dist/types/builders.d.ts.map +1 -0
  49. package/dist/types/casing.d.ts.map +1 -0
  50. package/dist/types/colors.d.ts.map +1 -0
  51. package/dist/types/hash.d.ts.map +1 -0
  52. package/dist/types/images.d.ts +202 -0
  53. package/dist/types/images.d.ts.map +1 -0
  54. package/dist/{index.d.ts → types/index.d.ts} +4 -1
  55. package/dist/types/index.d.ts.map +1 -0
  56. package/dist/types/logger.d.ts.map +1 -0
  57. package/dist/types/oauth2.d.ts +69 -0
  58. package/dist/types/oauth2.d.ts.map +1 -0
  59. package/dist/types/permissions.d.ts.map +1 -0
  60. package/dist/types/reactions.d.ts.map +1 -0
  61. package/dist/{token.d.ts → types/token.d.ts} +1 -1
  62. package/dist/types/token.d.ts.map +1 -0
  63. package/dist/types/typeguards.d.ts +8 -0
  64. package/dist/types/typeguards.d.ts.map +1 -0
  65. package/dist/types/urlToBase64.d.ts.map +1 -0
  66. package/dist/types/urls.d.ts +5 -0
  67. package/dist/types/urls.d.ts.map +1 -0
  68. package/dist/types/utils.d.ts.map +1 -0
  69. package/package.json +29 -25
  70. package/dist/Collection.d.ts.map +0 -1
  71. package/dist/Collection.js +0 -113
  72. package/dist/Collection.js.map +0 -1
  73. package/dist/base64.d.ts.map +0 -1
  74. package/dist/base64.js +0 -262
  75. package/dist/base64.js.map +0 -1
  76. package/dist/bucket.d.ts.map +0 -1
  77. package/dist/bucket.js +0 -74
  78. package/dist/bucket.js.map +0 -1
  79. package/dist/casing.d.ts.map +0 -1
  80. package/dist/casing.js +0 -51
  81. package/dist/casing.js.map +0 -1
  82. package/dist/colors.d.ts.map +0 -1
  83. package/dist/colors.js +0 -467
  84. package/dist/colors.js.map +0 -1
  85. package/dist/hash.d.ts.map +0 -1
  86. package/dist/hash.js +0 -19
  87. package/dist/hash.js.map +0 -1
  88. package/dist/images.d.ts +0 -68
  89. package/dist/images.d.ts.map +0 -1
  90. package/dist/images.js +0 -66
  91. package/dist/images.js.map +0 -1
  92. package/dist/index.d.ts.map +0 -1
  93. package/dist/index.js +0 -16
  94. package/dist/index.js.map +0 -1
  95. package/dist/interactions.d.ts +0 -3
  96. package/dist/interactions.d.ts.map +0 -1
  97. package/dist/interactions.js +0 -41
  98. package/dist/interactions.js.map +0 -1
  99. package/dist/logger.d.ts.map +0 -1
  100. package/dist/logger.js +0 -130
  101. package/dist/logger.js.map +0 -1
  102. package/dist/permissions.d.ts.map +0 -1
  103. package/dist/permissions.js +0 -17
  104. package/dist/permissions.js.map +0 -1
  105. package/dist/reactions.d.ts.map +0 -1
  106. package/dist/reactions.js +0 -11
  107. package/dist/reactions.js.map +0 -1
  108. package/dist/token.d.ts.map +0 -1
  109. package/dist/token.js +0 -16
  110. package/dist/token.js.map +0 -1
  111. package/dist/typeguards.d.ts +0 -6
  112. package/dist/typeguards.d.ts.map +0 -1
  113. package/dist/typeguards.js +0 -15
  114. package/dist/typeguards.js.map +0 -1
  115. package/dist/urlToBase64.d.ts.map +0 -1
  116. package/dist/urlToBase64.js +0 -9
  117. package/dist/urlToBase64.js.map +0 -1
  118. package/dist/utils.d.ts.map +0 -1
  119. package/dist/utils.js +0 -15
  120. package/dist/utils.js.map +0 -1
  121. /package/dist/{base64.d.ts → types/base64.d.ts} +0 -0
  122. /package/dist/{casing.d.ts → types/casing.d.ts} +0 -0
  123. /package/dist/{colors.d.ts → types/colors.d.ts} +0 -0
  124. /package/dist/{hash.d.ts → types/hash.d.ts} +0 -0
  125. /package/dist/{logger.d.ts → types/logger.d.ts} +0 -0
  126. /package/dist/{permissions.d.ts → types/permissions.d.ts} +0 -0
  127. /package/dist/{reactions.d.ts → types/reactions.d.ts} +0 -0
  128. /package/dist/{urlToBase64.d.ts → types/urlToBase64.d.ts} +0 -0
  129. /package/dist/{utils.d.ts → types/utils.d.ts} +0 -0
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: all[name]
9
+ });
10
+ }
11
+ _export(exports, {
12
+ skuLink: function() {
13
+ return skuLink;
14
+ },
15
+ soundLink: function() {
16
+ return soundLink;
17
+ },
18
+ storeLink: function() {
19
+ return storeLink;
20
+ }
21
+ });
22
+ function skuLink(appId, skuId) {
23
+ return `https://discord.com/application-directory/${appId}/store/${skuId}`;
24
+ }
25
+ function storeLink(appId) {
26
+ return `https://discord.com/application-directory/${appId}/store`;
27
+ }
28
+ function soundLink(soundId) {
29
+ return `https://cdn.discordapp.com/soundboard-sounds/${soundId}`;
30
+ }
31
+
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91cmxzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQmlnU3RyaW5nIH0gZnJvbSAnQGRpc2NvcmRlbm8vdHlwZXMnXG5cbmV4cG9ydCBmdW5jdGlvbiBza3VMaW5rKGFwcElkOiBCaWdTdHJpbmcsIHNrdUlkOiBCaWdTdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4gYGh0dHBzOi8vZGlzY29yZC5jb20vYXBwbGljYXRpb24tZGlyZWN0b3J5LyR7YXBwSWR9L3N0b3JlLyR7c2t1SWR9YFxufVxuXG5leHBvcnQgZnVuY3Rpb24gc3RvcmVMaW5rKGFwcElkOiBCaWdTdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4gYGh0dHBzOi8vZGlzY29yZC5jb20vYXBwbGljYXRpb24tZGlyZWN0b3J5LyR7YXBwSWR9L3N0b3JlYFxufVxuXG5leHBvcnQgZnVuY3Rpb24gc291bmRMaW5rKHNvdW5kSWQ6IEJpZ1N0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBgaHR0cHM6Ly9jZG4uZGlzY29yZGFwcC5jb20vc291bmRib2FyZC1zb3VuZHMvJHtzb3VuZElkfWBcbn1cbiJdLCJuYW1lcyI6WyJza3VMaW5rIiwic291bmRMaW5rIiwic3RvcmVMaW5rIiwiYXBwSWQiLCJza3VJZCIsInNvdW5kSWQiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0lBRWdCQSxPQUFPO2VBQVBBOztJQVFBQyxTQUFTO2VBQVRBOztJQUpBQyxTQUFTO2VBQVRBOzs7QUFKVCxTQUFTRixRQUFRRyxLQUFnQixFQUFFQyxLQUFnQjtJQUN4RCxPQUFPLENBQUMsMENBQTBDLEVBQUVELE1BQU0sT0FBTyxFQUFFQyxPQUFPO0FBQzVFO0FBRU8sU0FBU0YsVUFBVUMsS0FBZ0I7SUFDeEMsT0FBTyxDQUFDLDBDQUEwQyxFQUFFQSxNQUFNLE1BQU0sQ0FBQztBQUNuRTtBQUVPLFNBQVNGLFVBQVVJLE9BQWtCO0lBQzFDLE9BQU8sQ0FBQyw2Q0FBNkMsRUFBRUEsU0FBUztBQUNsRSJ9
@@ -0,0 +1,28 @@
1
+ /** Pause the execution for a given amount of milliseconds. */ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: all[name]
9
+ });
10
+ }
11
+ _export(exports, {
12
+ delay: function() {
13
+ return delay;
14
+ },
15
+ hasProperty: function() {
16
+ return hasProperty;
17
+ }
18
+ });
19
+ async function delay(ms) {
20
+ return new Promise((resolve)=>setTimeout(()=>{
21
+ resolve();
22
+ }, ms));
23
+ }
24
+ function hasProperty(obj, prop) {
25
+ return obj.hasOwnProperty(prop);
26
+ }
27
+
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogUGF1c2UgdGhlIGV4ZWN1dGlvbiBmb3IgYSBnaXZlbiBhbW91bnQgb2YgbWlsbGlzZWNvbmRzLiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGRlbGF5KG1zOiBudW1iZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlKFxuICAgIChyZXNvbHZlKTogTm9kZUpTLlRpbWVvdXQgPT5cbiAgICAgIHNldFRpbWVvdXQoKCk6IHZvaWQgPT4ge1xuICAgICAgICByZXNvbHZlKClcbiAgICAgIH0sIG1zKSxcbiAgKVxufVxuXG4vLyBUeXBlc2NyaXB0IGlzIG5vdCBzbyBnb29kIGFzIHdlIGRldmVsb3BlcnMgc28gd2UgbmVlZCB0aGlzIGxpdHRsZSB1dGlsaXR5IGZ1bmN0aW9uIHRvIGhlbHAgaXQgb3V0XG4vLyBUYWtlbiBmcm9tIGh0dHBzOi8vZmV0dGJsb2cuZXUvdHlwZXNjcmlwdC1oYXNvd25wcm9wZXJ0eS9cbi8qKiBUUyBzYXZlIHdheSB0byBjaGVjayBpZiBhIHByb3BlcnR5IGV4aXN0cyBpbiBhbiBvYmplY3QgKi9cbmV4cG9ydCBmdW5jdGlvbiBoYXNQcm9wZXJ0eTxUIGV4dGVuZHMge30sIFkgZXh0ZW5kcyBQcm9wZXJ0eUtleSA9IHN0cmluZz4ob2JqOiBULCBwcm9wOiBZKTogb2JqIGlzIFQgJiBSZWNvcmQ8WSwgdW5rbm93bj4ge1xuICByZXR1cm4gb2JqLmhhc093blByb3BlcnR5KHByb3ApXG59XG4iXSwibmFtZXMiOlsiZGVsYXkiLCJoYXNQcm9wZXJ0eSIsIm1zIiwiUHJvbWlzZSIsInJlc29sdmUiLCJzZXRUaW1lb3V0Iiwib2JqIiwicHJvcCIsImhhc093blByb3BlcnR5Il0sIm1hcHBpbmdzIjoiQUFBQSw0REFBNEQ7Ozs7Ozs7Ozs7O0lBQ3RDQSxLQUFLO2VBQUxBOztJQVlOQyxXQUFXO2VBQVhBOzs7QUFaVCxlQUFlRCxNQUFNRSxFQUFVO0lBQ3BDLE9BQU8sSUFBSUMsUUFDVCxDQUFDQyxVQUNDQyxXQUFXO1lBQ1REO1FBQ0YsR0FBR0Y7QUFFVDtBQUtPLFNBQVNELFlBQTBESyxHQUFNLEVBQUVDLElBQU87SUFDdkYsT0FBT0QsSUFBSUUsY0FBYyxDQUFDRDtBQUM1QiJ9
@@ -0,0 +1,112 @@
1
+ export class Collection extends Map {
2
+ constructor(entries, options){
3
+ super(entries ?? []);
4
+ this.maxSize = options?.maxSize;
5
+ if (!options?.sweeper) return;
6
+ this.startSweeper(options.sweeper);
7
+ }
8
+ startSweeper(options) {
9
+ if (this.sweeper?.intervalId) clearInterval(this.sweeper.intervalId);
10
+ this.sweeper = options;
11
+ this.sweeper.intervalId = setInterval(()=>{
12
+ this.forEach((value, key)=>{
13
+ if (!this.sweeper?.filter(value, key, options.bot)) return;
14
+ this.delete(key);
15
+ return key;
16
+ });
17
+ }, options.interval);
18
+ return this.sweeper.intervalId;
19
+ }
20
+ stopSweeper() {
21
+ return clearInterval(this.sweeper?.intervalId);
22
+ }
23
+ changeSweeperInterval(newInterval) {
24
+ if (this.sweeper == null) return;
25
+ this.startSweeper({
26
+ filter: this.sweeper.filter,
27
+ interval: newInterval
28
+ });
29
+ }
30
+ changeSweeperFilter(newFilter) {
31
+ if (this.sweeper == null) return;
32
+ this.startSweeper({
33
+ filter: newFilter,
34
+ interval: this.sweeper.interval
35
+ });
36
+ }
37
+ /** Add an item to the collection. Makes sure not to go above the maxSize. */ set(key, value) {
38
+ // When this collection is maxSized make sure we can add first
39
+ if ((this.maxSize !== undefined || this.maxSize === 0) && this.size >= this.maxSize) {
40
+ return this;
41
+ }
42
+ return super.set(key, value);
43
+ }
44
+ /** Add an item to the collection, no matter what the maxSize is. */ forceSet(key, value) {
45
+ return super.set(key, value);
46
+ }
47
+ /** Convert the collection to an array. */ array() {
48
+ return [
49
+ ...this.values()
50
+ ];
51
+ }
52
+ /** Retrieve the value of the first element in this collection. */ first() {
53
+ return this.values().next().value;
54
+ }
55
+ /** Retrieve the value of the last element in this collection. */ last() {
56
+ return [
57
+ ...this.values()
58
+ ][this.size - 1];
59
+ }
60
+ /** Retrieve the value of a random element in this collection. */ random() {
61
+ const array = [
62
+ ...this.values()
63
+ ];
64
+ return array[Math.floor(Math.random() * array.length)];
65
+ }
66
+ /** Find a specific element in this collection. */ find(callback) {
67
+ for (const key of this.keys()){
68
+ const value = this.get(key);
69
+ if (callback(value, key)) return value;
70
+ }
71
+ // If nothing matched
72
+ }
73
+ /** Find all elements in this collection that match the given pattern. */ filter(callback) {
74
+ const relevant = new Collection();
75
+ this.forEach((value, key)=>{
76
+ if (callback(value, key)) relevant.set(key, value);
77
+ });
78
+ return relevant;
79
+ }
80
+ /** Converts the collection into an array by running a callback on all items in the collection. */ map(callback) {
81
+ const results = [];
82
+ for (const key of this.keys()){
83
+ const value = this.get(key);
84
+ results.push(callback(value, key));
85
+ }
86
+ return results;
87
+ }
88
+ /** Check if one of the items in the collection matches the pattern. */ some(callback) {
89
+ for (const key of this.keys()){
90
+ const value = this.get(key);
91
+ if (callback(value, key)) return true;
92
+ }
93
+ return false;
94
+ }
95
+ /** Check if all of the items in the collection matches the pattern. */ every(callback) {
96
+ for (const key of this.keys()){
97
+ const value = this.get(key);
98
+ if (!callback(value, key)) return false;
99
+ }
100
+ return true;
101
+ }
102
+ /** Runs a callback on all items in the collection, merging them into a single value. */ reduce(callback, initialValue) {
103
+ let accumulator = initialValue;
104
+ for (const key of this.keys()){
105
+ const value = this.get(key);
106
+ accumulator = callback(accumulator, value, key);
107
+ }
108
+ return accumulator;
109
+ }
110
+ }
111
+
112
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Db2xsZWN0aW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUGxhY2VIb2xkZXJCb3Qge31cblxuZXhwb3J0IGNsYXNzIENvbGxlY3Rpb248SywgVj4gZXh0ZW5kcyBNYXA8SywgVj4ge1xuICAvKipcbiAgICogVGhlIG1heGltdW0gYW1vdW50IG9mIGl0ZW1zIGFsbG93ZWQgaW4gdGhpcyBjb2xsZWN0aW9uLiBUbyBkaXNhYmxlIGNhY2hlLCBzZXQgaXQgMCwgc2V0IHRvIHVuZGVmaW5lZCB0byBtYWtlIGl0IGluZmluaXRlLlxuICAgKiBAZGVmYXVsdCB1bmRlZmluZWRcbiAgICovXG4gIG1heFNpemU6IG51bWJlciB8IHVuZGVmaW5lZFxuICAvKiogSGFuZGxlciB0byByZW1vdmUgaXRlbXMgZnJvbSB0aGUgY29sbGVjdGlvbiBldmVyeSBzbyBvZnRlbi4gKi9cbiAgc3dlZXBlcjogKENvbGxlY3Rpb25Td2VlcGVyPEssIFY+ICYgeyBpbnRlcnZhbElkPzogTm9kZUpTLlRpbWVvdXQgfSkgfCB1bmRlZmluZWRcblxuICBjb25zdHJ1Y3RvcihlbnRyaWVzPzogKFJlYWRvbmx5QXJyYXk8cmVhZG9ubHkgW0ssIFZdPiB8IG51bGwpIHwgTWFwPEssIFY+LCBvcHRpb25zPzogQ29sbGVjdGlvbk9wdGlvbnM8SywgVj4pIHtcbiAgICBzdXBlcihlbnRyaWVzID8/IFtdKVxuXG4gICAgdGhpcy5tYXhTaXplID0gb3B0aW9ucz8ubWF4U2l6ZVxuXG4gICAgaWYgKCFvcHRpb25zPy5zd2VlcGVyKSByZXR1cm5cblxuICAgIHRoaXMuc3RhcnRTd2VlcGVyKG9wdGlvbnMuc3dlZXBlcilcbiAgfVxuXG4gIHN0YXJ0U3dlZXBlcihvcHRpb25zOiBDb2xsZWN0aW9uU3dlZXBlcjxLLCBWPik6IE5vZGVKUy5UaW1lb3V0IHtcbiAgICBpZiAodGhpcy5zd2VlcGVyPy5pbnRlcnZhbElkKSBjbGVhckludGVydmFsKHRoaXMuc3dlZXBlci5pbnRlcnZhbElkKVxuXG4gICAgdGhpcy5zd2VlcGVyID0gb3B0aW9uc1xuICAgIHRoaXMuc3dlZXBlci5pbnRlcnZhbElkID0gc2V0SW50ZXJ2YWwoKCkgPT4ge1xuICAgICAgdGhpcy5mb3JFYWNoKCh2YWx1ZSwga2V5KSA9PiB7XG4gICAgICAgIGlmICghdGhpcy5zd2VlcGVyPy5maWx0ZXIodmFsdWUsIGtleSwgb3B0aW9ucy5ib3QpKSByZXR1cm5cblxuICAgICAgICB0aGlzLmRlbGV0ZShrZXkpXG4gICAgICAgIHJldHVybiBrZXlcbiAgICAgIH0pXG4gICAgfSwgb3B0aW9ucy5pbnRlcnZhbClcblxuICAgIHJldHVybiB0aGlzLnN3ZWVwZXIuaW50ZXJ2YWxJZFxuICB9XG5cbiAgc3RvcFN3ZWVwZXIoKTogdm9pZCB7XG4gICAgcmV0dXJuIGNsZWFySW50ZXJ2YWwodGhpcy5zd2VlcGVyPy5pbnRlcnZhbElkKVxuICB9XG5cbiAgY2hhbmdlU3dlZXBlckludGVydmFsKG5ld0ludGVydmFsOiBudW1iZXIpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5zd2VlcGVyID09IG51bGwpIHJldHVyblxuXG4gICAgdGhpcy5zdGFydFN3ZWVwZXIoeyBmaWx0ZXI6IHRoaXMuc3dlZXBlci5maWx0ZXIsIGludGVydmFsOiBuZXdJbnRlcnZhbCB9KVxuICB9XG5cbiAgY2hhbmdlU3dlZXBlckZpbHRlcihuZXdGaWx0ZXI6ICh2YWx1ZTogViwga2V5OiBLLCBib3Q6IFBsYWNlSG9sZGVyQm90KSA9PiBib29sZWFuKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuc3dlZXBlciA9PSBudWxsKSByZXR1cm5cblxuICAgIHRoaXMuc3RhcnRTd2VlcGVyKHsgZmlsdGVyOiBuZXdGaWx0ZXIsIGludGVydmFsOiB0aGlzLnN3ZWVwZXIuaW50ZXJ2YWwgfSlcbiAgfVxuXG4gIC8qKiBBZGQgYW4gaXRlbSB0byB0aGUgY29sbGVjdGlvbi4gTWFrZXMgc3VyZSBub3QgdG8gZ28gYWJvdmUgdGhlIG1heFNpemUuICovXG4gIHNldChrZXk6IEssIHZhbHVlOiBWKTogdGhpcyB7XG4gICAgLy8gV2hlbiB0aGlzIGNvbGxlY3Rpb24gaXMgbWF4U2l6ZWQgbWFrZSBzdXJlIHdlIGNhbiBhZGQgZmlyc3RcbiAgICBpZiAoKHRoaXMubWF4U2l6ZSAhPT0gdW5kZWZpbmVkIHx8IHRoaXMubWF4U2l6ZSA9PT0gMCkgJiYgdGhpcy5zaXplID49IHRoaXMubWF4U2l6ZSkge1xuICAgICAgcmV0dXJuIHRoaXNcbiAgICB9XG5cbiAgICByZXR1cm4gc3VwZXIuc2V0KGtleSwgdmFsdWUpXG4gIH1cblxuICAvKiogQWRkIGFuIGl0ZW0gdG8gdGhlIGNvbGxlY3Rpb24sIG5vIG1hdHRlciB3aGF0IHRoZSBtYXhTaXplIGlzLiAqL1xuICBmb3JjZVNldChrZXk6IEssIHZhbHVlOiBWKTogdGhpcyB7XG4gICAgcmV0dXJuIHN1cGVyLnNldChrZXksIHZhbHVlKVxuICB9XG5cbiAgLyoqIENvbnZlcnQgdGhlIGNvbGxlY3Rpb24gdG8gYW4gYXJyYXkuICovXG4gIGFycmF5KCk6IFZbXSB7XG4gICAgcmV0dXJuIFsuLi50aGlzLnZhbHVlcygpXVxuICB9XG5cbiAgLyoqIFJldHJpZXZlIHRoZSB2YWx1ZSBvZiB0aGUgZmlyc3QgZWxlbWVudCBpbiB0aGlzIGNvbGxlY3Rpb24uICovXG4gIGZpcnN0KCk6IFYgfCB1bmRlZmluZWQge1xuICAgIHJldHVybiB0aGlzLnZhbHVlcygpLm5leHQoKS52YWx1ZVxuICB9XG5cbiAgLyoqIFJldHJpZXZlIHRoZSB2YWx1ZSBvZiB0aGUgbGFzdCBlbGVtZW50IGluIHRoaXMgY29sbGVjdGlvbi4gKi9cbiAgbGFzdCgpOiBWIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gWy4uLnRoaXMudmFsdWVzKCldW3RoaXMuc2l6ZSAtIDFdXG4gIH1cblxuICAvKiogUmV0cmlldmUgdGhlIHZhbHVlIG9mIGEgcmFuZG9tIGVsZW1lbnQgaW4gdGhpcyBjb2xsZWN0aW9uLiAqL1xuICByYW5kb20oKTogViB8IHVuZGVmaW5lZCB7XG4gICAgY29uc3QgYXJyYXkgPSBbLi4udGhpcy52YWx1ZXMoKV1cbiAgICByZXR1cm4gYXJyYXlbTWF0aC5mbG9vcihNYXRoLnJhbmRvbSgpICogYXJyYXkubGVuZ3RoKV1cbiAgfVxuXG4gIC8qKiBGaW5kIGEgc3BlY2lmaWMgZWxlbWVudCBpbiB0aGlzIGNvbGxlY3Rpb24uICovXG4gIGZpbmQoY2FsbGJhY2s6ICh2YWx1ZTogViwga2V5OiBLKSA9PiBib29sZWFuKTogTm9uTnVsbGFibGU8Vj4gfCB1bmRlZmluZWQge1xuICAgIGZvciAoY29uc3Qga2V5IG9mIHRoaXMua2V5cygpKSB7XG4gICAgICBjb25zdCB2YWx1ZSA9IHRoaXMuZ2V0KGtleSkhXG4gICAgICBpZiAoY2FsbGJhY2sodmFsdWUsIGtleSkpIHJldHVybiB2YWx1ZVxuICAgIH1cbiAgICAvLyBJZiBub3RoaW5nIG1hdGNoZWRcbiAgfVxuXG4gIC8qKiBGaW5kIGFsbCBlbGVtZW50cyBpbiB0aGlzIGNvbGxlY3Rpb24gdGhhdCBtYXRjaCB0aGUgZ2l2ZW4gcGF0dGVybi4gKi9cbiAgZmlsdGVyKGNhbGxiYWNrOiAodmFsdWU6IFYsIGtleTogSykgPT4gYm9vbGVhbik6IENvbGxlY3Rpb248SywgVj4ge1xuICAgIGNvbnN0IHJlbGV2YW50ID0gbmV3IENvbGxlY3Rpb248SywgVj4oKVxuICAgIHRoaXMuZm9yRWFjaCgodmFsdWUsIGtleSkgPT4ge1xuICAgICAgaWYgKGNhbGxiYWNrKHZhbHVlLCBrZXkpKSByZWxldmFudC5zZXQoa2V5LCB2YWx1ZSlcbiAgICB9KVxuXG4gICAgcmV0dXJuIHJlbGV2YW50XG4gIH1cblxuICAvKiogQ29udmVydHMgdGhlIGNvbGxlY3Rpb24gaW50byBhbiBhcnJheSBieSBydW5uaW5nIGEgY2FsbGJhY2sgb24gYWxsIGl0ZW1zIGluIHRoZSBjb2xsZWN0aW9uLiAqL1xuICBtYXA8VD4oY2FsbGJhY2s6ICh2YWx1ZTogViwga2V5OiBLKSA9PiBUKTogVFtdIHtcbiAgICBjb25zdCByZXN1bHRzID0gW11cbiAgICBmb3IgKGNvbnN0IGtleSBvZiB0aGlzLmtleXMoKSkge1xuICAgICAgY29uc3QgdmFsdWUgPSB0aGlzLmdldChrZXkpIVxuICAgICAgcmVzdWx0cy5wdXNoKGNhbGxiYWNrKHZhbHVlLCBrZXkpKVxuICAgIH1cbiAgICByZXR1cm4gcmVzdWx0c1xuICB9XG5cbiAgLyoqIENoZWNrIGlmIG9uZSBvZiB0aGUgaXRlbXMgaW4gdGhlIGNvbGxlY3Rpb24gbWF0Y2hlcyB0aGUgcGF0dGVybi4gKi9cbiAgc29tZShjYWxsYmFjazogKHZhbHVlOiBWLCBrZXk6IEspID0+IGJvb2xlYW4pOiBib29sZWFuIHtcbiAgICBmb3IgKGNvbnN0IGtleSBvZiB0aGlzLmtleXMoKSkge1xuICAgICAgY29uc3QgdmFsdWUgPSB0aGlzLmdldChrZXkpIVxuICAgICAgaWYgKGNhbGxiYWNrKHZhbHVlLCBrZXkpKSByZXR1cm4gdHJ1ZVxuICAgIH1cblxuICAgIHJldHVybiBmYWxzZVxuICB9XG5cbiAgLyoqIENoZWNrIGlmIGFsbCBvZiB0aGUgaXRlbXMgaW4gdGhlIGNvbGxlY3Rpb24gbWF0Y2hlcyB0aGUgcGF0dGVybi4gKi9cbiAgZXZlcnkoY2FsbGJhY2s6ICh2YWx1ZTogViwga2V5OiBLKSA9PiBib29sZWFuKTogYm9vbGVhbiB7XG4gICAgZm9yIChjb25zdCBrZXkgb2YgdGhpcy5rZXlzKCkpIHtcbiAgICAgIGNvbnN0IHZhbHVlID0gdGhpcy5nZXQoa2V5KSFcbiAgICAgIGlmICghY2FsbGJhY2sodmFsdWUsIGtleSkpIHJldHVybiBmYWxzZVxuICAgIH1cblxuICAgIHJldHVybiB0cnVlXG4gIH1cblxuICAvKiogUnVucyBhIGNhbGxiYWNrIG9uIGFsbCBpdGVtcyBpbiB0aGUgY29sbGVjdGlvbiwgbWVyZ2luZyB0aGVtIGludG8gYSBzaW5nbGUgdmFsdWUuICovXG4gIHJlZHVjZTxUPihjYWxsYmFjazogKGFjY3VtdWxhdG9yOiBULCB2YWx1ZTogViwga2V5OiBLKSA9PiBULCBpbml0aWFsVmFsdWU/OiBUKTogVCB7XG4gICAgbGV0IGFjY3VtdWxhdG9yOiBUID0gaW5pdGlhbFZhbHVlIVxuXG4gICAgZm9yIChjb25zdCBrZXkgb2YgdGhpcy5rZXlzKCkpIHtcbiAgICAgIGNvbnN0IHZhbHVlID0gdGhpcy5nZXQoa2V5KSFcbiAgICAgIGFjY3VtdWxhdG9yID0gY2FsbGJhY2soYWNjdW11bGF0b3IsIHZhbHVlLCBrZXkpXG4gICAgfVxuXG4gICAgcmV0dXJuIGFjY3VtdWxhdG9yXG4gIH1cbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb2xsZWN0aW9uT3B0aW9uczxLLCBWPiB7XG4gIC8qKiBIYW5kbGVyIHRvIGNsZWFuIG91dCB0aGUgaXRlbXMgaW4gdGhlIGNvbGxlY3Rpb24gZXZlcnkgc28gb2Z0ZW4uICovXG4gIHN3ZWVwZXI/OiBDb2xsZWN0aW9uU3dlZXBlcjxLLCBWPlxuICAvKiogVGhlIG1heGltdW0gbnVtYmVyIG9mIGl0ZW1zIGFsbG93ZWQgaW4gdGhlIGNvbGxlY3Rpb24uICovXG4gIG1heFNpemU/OiBudW1iZXJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb2xsZWN0aW9uU3dlZXBlcjxLLCBWPiB7XG4gIC8qKiBUaGUgZmlsdGVyIHRvIGRldGVybWluZSB3aGV0aGVyIGFuIGVsZW1lbnQgc2hvdWxkIGJlIGRlbGV0ZWQgb3Igbm90ICovXG4gIGZpbHRlcjogKHZhbHVlOiBWLCBrZXk6IEssIC4uLmFyZ3M6IGFueVtdKSA9PiBib29sZWFuXG4gIC8qKiBUaGUgaW50ZXJ2YWwgaW4gd2hpY2ggdGhlIHN3ZWVwZXIgc2hvdWxkIHJ1biAqL1xuICBpbnRlcnZhbDogbnVtYmVyXG4gIC8qKiBUaGUgYm90IG9iamVjdCBpdHNlbGYgKi9cbiAgYm90PzogUGxhY2VIb2xkZXJCb3Rcbn1cbiJdLCJuYW1lcyI6WyJDb2xsZWN0aW9uIiwiTWFwIiwiY29uc3RydWN0b3IiLCJlbnRyaWVzIiwib3B0aW9ucyIsIm1heFNpemUiLCJzd2VlcGVyIiwic3RhcnRTd2VlcGVyIiwiaW50ZXJ2YWxJZCIsImNsZWFySW50ZXJ2YWwiLCJzZXRJbnRlcnZhbCIsImZvckVhY2giLCJ2YWx1ZSIsImtleSIsImZpbHRlciIsImJvdCIsImRlbGV0ZSIsImludGVydmFsIiwic3RvcFN3ZWVwZXIiLCJjaGFuZ2VTd2VlcGVySW50ZXJ2YWwiLCJuZXdJbnRlcnZhbCIsImNoYW5nZVN3ZWVwZXJGaWx0ZXIiLCJuZXdGaWx0ZXIiLCJzZXQiLCJ1bmRlZmluZWQiLCJzaXplIiwiZm9yY2VTZXQiLCJhcnJheSIsInZhbHVlcyIsImZpcnN0IiwibmV4dCIsImxhc3QiLCJyYW5kb20iLCJNYXRoIiwiZmxvb3IiLCJsZW5ndGgiLCJmaW5kIiwiY2FsbGJhY2siLCJrZXlzIiwiZ2V0IiwicmVsZXZhbnQiLCJtYXAiLCJyZXN1bHRzIiwicHVzaCIsInNvbWUiLCJldmVyeSIsInJlZHVjZSIsImluaXRpYWxWYWx1ZSIsImFjY3VtdWxhdG9yIl0sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLE1BQU1BLG1CQUF5QkM7SUFTcENDLFlBQVlDLE9BQTZELEVBQUVDLE9BQWlDLENBQUU7UUFDNUcsS0FBSyxDQUFDRCxXQUFXLEVBQUU7UUFFbkIsSUFBSSxDQUFDRSxPQUFPLEdBQUdELFNBQVNDO1FBRXhCLElBQUksQ0FBQ0QsU0FBU0UsU0FBUztRQUV2QixJQUFJLENBQUNDLFlBQVksQ0FBQ0gsUUFBUUUsT0FBTztJQUNuQztJQUVBQyxhQUFhSCxPQUFnQyxFQUFrQjtRQUM3RCxJQUFJLElBQUksQ0FBQ0UsT0FBTyxFQUFFRSxZQUFZQyxjQUFjLElBQUksQ0FBQ0gsT0FBTyxDQUFDRSxVQUFVO1FBRW5FLElBQUksQ0FBQ0YsT0FBTyxHQUFHRjtRQUNmLElBQUksQ0FBQ0UsT0FBTyxDQUFDRSxVQUFVLEdBQUdFLFlBQVk7WUFDcEMsSUFBSSxDQUFDQyxPQUFPLENBQUMsQ0FBQ0MsT0FBT0M7Z0JBQ25CLElBQUksQ0FBQyxJQUFJLENBQUNQLE9BQU8sRUFBRVEsT0FBT0YsT0FBT0MsS0FBS1QsUUFBUVcsR0FBRyxHQUFHO2dCQUVwRCxJQUFJ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
@@ -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+IDE2XG4gICAgcmVzdWx0W2ogKyAxXSA9IChidWZmZXIgPj4gOCkgJiAweGZmXG4gICAgcmVzdWx0W2ogKyAyXSA9IGJ1ZmZlciAmIDB4ZmZcbiAgfVxuICByZXR1cm4gcmVzdWx0LnN1YmFycmF5KDAsIHJlc3VsdC5sZW5ndGggLSBtaXNzaW5nT2N0ZXRzKVxufVxuXG4vKipcbiAqIENSRURJVDogaHR0cHM6Ly9naXN0LmdpdGh1Yi5jb20vZW5lcG9tbnlhc2NoaWgvNzJjNDIzZjcyN2QzOTVlZWFhMDk2OTcwNTgyMzg3MjdcbiAqIEBwYXJhbSBjaGFyQ29kZVxuICovXG5mdW5jdGlvbiBnZXRCYXNlNjRDb2RlKGNoYXJDb2RlOiBudW1iZXIpOiBudW1iZXIge1xuICBpZiAoY2hhckNvZGUgPj0gYmFzZTY0Y29kZXMubGVuZ3RoKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdVbmFibGUgdG8gcGFyc2UgYmFzZTY0IHN0cmluZy4nKVxuICB9XG4gIGNvbnN0IGNvZGUgPSBiYXNlNjRjb2Rlc1tjaGFyQ29kZV1cbiAgaWYgKGNvZGUgPT09IDI1NSkge1xuICAgIHRocm93IG5ldyBFcnJvcignVW5hYmxlIHRvIHBhcnNlIGJhc2U2NCBzdHJpbmcuJylcbiAgfVxuICByZXR1cm4gY29kZVxufVxuXG4vLyBDb3B5cmlnaHQgMjAxOC0yMDIxIHRoZSBEZW5vIGF1dGhvcnMuIEFsbCByaWdodHMgcmVzZXJ2ZWQuIE1JVCBsaWNlbnNlLlxuY29uc3QgYmFzZTY0YWJjID0gW1xuICAnQScsXG4gICdCJyxcbiAgJ0MnLFxuICAnRCcsXG4gICdFJyxcbiAgJ0YnLFxuICAnRycsXG4gICdIJyxcbiAgJ0knLFxuICAnSicsXG4gICdLJyxcbiAgJ0wnLFxuICAnTScsXG4gICdOJyxcbiAgJ08nLFxuICAnUCcsXG4gICdRJyxcbiAgJ1InLFxuICAnUycsXG4gICdUJyxcbiAgJ1UnLFxuICAnVicsXG4gICdXJyxcbiAgJ1gnLFxuICAnWScsXG4gICdaJyxcbiAgJ2EnLFxuICAnYicsXG4gICdjJyxcbiAgJ2QnLFxuICAnZScsXG4gICdmJyxcbiAgJ2cnLFxuICAnaCcsXG4gICdpJyxcbiAgJ2onLFxuICAnaycsXG4gICdsJyxcbiAgJ20nLFxuICAnbicsXG4gICdvJyxcbiAgJ3AnLFxuICAncScsXG4gICdyJyxcbiAgJ3MnLFxuICAndCcsXG4gICd1JyxcbiAgJ3YnLFxuICAndycsXG4gICd4JyxcbiAgJ3knLFxuICAneicsXG4gICcwJyxcbiAgJzEnLFxuICAnMicsXG4gICczJyxcbiAgJzQnLFxuICAnNScsXG4gICc2JyxcbiAgJzcnLFxuICAnOCcsXG4gICc5JyxcbiAgJysnLFxuICAnLycsXG5dXG5cbi8vIENSRURJVDogaHR0cHM6Ly9naXN0LmdpdGh1Yi5jb20vZW5lcG9tbnlhc2NoaWgvNzJjNDIzZjcyN2QzOTVlZWFhMDk2OTcwNTgyMzg3MjdcbmNvbnN0IGJhc2U2NGNvZGVzID0gW1xuICAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSxcbiAgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDYyLCAyNTUsIDI1NSwgMjU1LCA2MywgNTIsIDUzLCA1NCwgNTUsIDU2LCA1NywgNTgsIDU5LCA2MCwgNjEsIDI1NSwgMjU1LCAyNTUsXG4gIDAsIDI1NSwgMjU1LCAyNTUsIDAsIDEsIDIsIDMsIDQsIDUsIDYsIDcsIDgsIDksIDEwLCAxMSwgMTIsIDEzLCAxNCwgMTUsIDE2LCAxNywgMTgsIDE5LCAyMCwgMjEsIDIyLCAyMywgMjQsIDI1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNixcbiAgMjcsIDI4LCAyOSwgMzAsIDMxLCAzMiwgMzMsIDM0LCAzNSwgMzYsIDM3LCAzOCwgMzksIDQwLCA0MSwgNDIsIDQzLCA0NCwgNDUsIDQ2LCA0NywgNDgsIDQ5LCA1MCwgNTEsXG5dXG4iXSwibmFtZXMiOlsiZW5jb2RlIiwiZGF0YSIsInVpbnQ4IiwiVGV4dEVuY29kZXIiLCJVaW50OEFycmF5IiwicmVzdWx0IiwiaSIsImwiLCJsZW5ndGgiLCJiYXNlNjRhYmMiLCJkZWNvZGUiLCJFcnJvciIsImluZGV4IiwiaW5kZXhPZiIsIm1pc3NpbmdPY3RldHMiLCJlbmRzV2l0aCIsIm4iLCJidWZmZXIiLCJqIiwiZ2V0QmFzZTY0Q29kZSIsImNoYXJDb2RlQXQiLCJzdWJhcnJheSIsImNoYXJDb2RlIiwiYmFzZTY0Y29kZXMiLCJjb2RlIl0sIm1hcHBpbmdzIjoiQUFBQTs7OztDQUlDLEdBQ0QsT0FBTyxTQUFTQSxPQUFPQyxJQUEwQjtJQUMvQyxNQUFNQyxRQUFRLE9BQU9ELFNBQVMsV0FBVyxJQUFJRSxjQUFjSCxNQUFNLENBQUNDLFFBQVFBLGdCQUFnQkcsYUFBYUgsT0FBTyxJQUFJRyxXQUFXSDtJQUM3SCxJQUFJSSxTQUFTO0lBQ2IsSUFBSUM7SUFDSixNQUFNQyxJQUFJTCxNQUFNTSxNQUFNO0lBQ3RCLElBQUtGLElBQUksR0FBR0EsSUFBSUMsR0FBR0QsS0FBSyxFQUFHO1FBQ3pCRCxVQUFVSSxTQUFTLENBQUNQLEtB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LDBFQUEwRTtBQUMxRSxNQUFNZixZQUFZO0lBQ2hCO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0NBQ0Q7QUFFRCxrRkFBa0Y7QUFDbEYsTUFBTWMsY0FBYztJQUNsQjtJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQzVJO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFJO0lBQUs7SUFBSztJQUFLO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFLO0lBQUs7SUFDL0k7SUFBRztJQUFLO0lBQUs7SUFBSztJQUFHO0lBQUc7SUFBRztJQUFHO0lBQUc7SUFBRztJQUFHO0lBQUc7SUFBRztJQUFHO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFDOUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7Q0FDakcifQ==
@@ -0,0 +1,81 @@
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
+ this.logger = options?.logger ?? logger;
12
+ }
13
+ /** The amount of requests that still remain. */ get remaining() {
14
+ return this.max < this.used ? 0 : this.max - this.used;
15
+ }
16
+ /** Refills the bucket as needed. */ refillBucket() {
17
+ this.logger.debug(`[LeakyBucket] Timeout for leaky bucket requests executed. Refilling bucket.`);
18
+ // Lower the used amount by the refill amount
19
+ this.used = this.refillAmount > this.used ? 0 : this.used - this.refillAmount;
20
+ // Reset the refillsAt timestamp since it just got refilled
21
+ this.refillsAt = undefined;
22
+ // Reset the timeoutId
23
+ clearTimeout(this.timeoutId);
24
+ this.timeoutId = undefined;
25
+ if (this.used > 0) {
26
+ this.timeoutId = setTimeout(()=>{
27
+ this.refillBucket();
28
+ }, this.refillInterval);
29
+ this.refillsAt = Date.now() + this.refillInterval;
30
+ }
31
+ }
32
+ /** Begin processing the queue. */ async processQueue() {
33
+ this.logger.debug('[LeakyBucket] Processing queue');
34
+ // There is already a queue that is processing
35
+ if (this.processing) return this.logger.debug('[LeakyBucket] Queue is already processing.');
36
+ this.processing = true;
37
+ // Begin going through the queue.
38
+ while(this.queue.length){
39
+ if (this.remaining) {
40
+ this.logger.debug(`[LeakyBucket] Processing queue. Remaining: ${this.remaining} Length: ${this.queue.length}`);
41
+ // Resolves the promise allowing the paused execution of this request to resolve and continue.
42
+ this.queue.shift()?.();
43
+ // A request can be made
44
+ this.used++;
45
+ // Create a new timeout for this request if none exists.
46
+ if (!this.timeoutId) {
47
+ this.logger.debug(`[LeakyBucket] Creating new timeout for leaky bucket requests.`);
48
+ this.timeoutId = setTimeout(()=>{
49
+ this.refillBucket();
50
+ }, this.refillInterval);
51
+ // Set the time for when this refill will occur.
52
+ this.refillsAt = Date.now() + this.refillInterval;
53
+ }
54
+ } else if (this.refillsAt) {
55
+ const now = Date.now();
56
+ // If there is time left until next refill, just delay execution.
57
+ if (this.refillsAt > now) {
58
+ this.logger.debug(`[LeakyBucket] Delaying execution of leaky bucket requests for ${this.refillsAt - now}ms`);
59
+ await delay(this.refillsAt - now);
60
+ this.logger.debug(`[LeakyBucket] Resuming execution`);
61
+ } else {
62
+ this.logger.debug(`[LeakyBucket] Delaying execution of leaky bucket requests for 1000ms`);
63
+ await delay(1000);
64
+ }
65
+ }
66
+ }
67
+ // Loop has ended mark false so it can restart later when needed
68
+ this.processing = false;
69
+ }
70
+ /** Pauses the execution until the request is available to be made. */ async acquire(highPriority) {
71
+ return await new Promise((resolve)=>{
72
+ // High priority requests get added to the start of the queue
73
+ if (highPriority) this.queue.unshift(resolve);
74
+ else this.queue.push(resolve);
75
+ // Each request should trigger the queue to be processed.
76
+ void this.processQueue();
77
+ });
78
+ }
79
+ }
80
+
81
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9idWNrZXQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGxvZ2dlciBmcm9tICcuL2xvZ2dlci5qcydcbmltcG9ydCB7IGRlbGF5IH0gZnJvbSAnLi91dGlscy5qcydcblxuZXhwb3J0IGNsYXNzIExlYWt5QnVja2V0IGltcGxlbWVudHMgTGVha3lCdWNrZXRPcHRpb25zIHtcbiAgbWF4OiBudW1iZXJcbiAgcmVmaWxsSW50ZXJ2YWw6IG51bWJlclxuICByZWZpbGxBbW91bnQ6IG51bWJlclxuXG4gIC8qKiBUaGUgYW1vdW50IG9mIHJlcXVlc3RzIHRoYXQgaGF2ZSBiZWVuIHVzZWQgdXAgYWxyZWFkeS4gKi9cbiAgdXNlZDogbnVtYmVyID0gMFxuICAvKiogVGhlIHF1ZXVlIG9mIHJlcXVlc3RzIHRvIGFjcXVpcmUgYW4gYXZhaWxhYmxlIHJlcXVlc3QuIE1hcHBlZCBieSA8c2hhcmRJZCwgcmVzb2x2ZSgpPiAqL1xuICBxdWV1ZTogQXJyYXk8KHZhbHVlOiB2b2lkIHwgUHJvbWlzZUxpa2U8dm9pZD4pID0+IHZvaWQ+ID0gW11cbiAgLyoqIFdoZXRoZXIgb3Igbm90IHRoZSBxdWV1ZSBpcyBhbHJlYWR5IHByb2Nlc3NpbmcuICovXG4gIHByb2Nlc3Npbmc6IGJvb2xlYW4gPSBmYWxzZVxuICAvKiogVGhlIHRpbWVvdXQgaWQgZm9yIHRoZSB0aW1lciB0byByZWR1Y2UgdGhlIHVzZWQgYW1vdW50IGJ5IHRoZSByZWZpbGwgYW1vdW50LiAqL1xuICB0aW1lb3V0SWQ/OiBOb2RlSlMuVGltZW91dFxuICAvKiogVGhlIHRpbWVzdGFtcCBpbiBtaWxsaXNlY29uZHMgd2hlbiB0aGUgbmV4dCByZWZpbGwgaXMgc2NoZWR1bGVkLiAqL1xuICByZWZpbGxzQXQ/OiBudW1iZXJcbiAgLyoqIExvZ2dlciB1c2VkIGluIHRoZSBsZWFreSBidWNrZXQgKi9cbiAgbG9nZ2VyOiBQaWNrPHR5cGVvZiBsb2dnZXIsICdkZWJ1ZycgfCAnaW5mbycgfCAnd2FybicgfCAnZXJyb3InIHwgJ2ZhdGFsJz5cblxuICBjb25zdHJ1Y3RvcihvcHRpb25zPzogTGVha3lCdWNrZXRPcHRpb25zKSB7XG4gICAgdGhpcy5tYXggPSBvcHRpb25zPy5tYXggPz8gMVxuICAgIHRoaXMucmVmaWxsQW1vdW50ID0gb3B0aW9ucz8ucmVmaWxsQW1vdW50ID8gKG9wdGlvbnMucmVmaWxsQW1vdW50ID4gdGhpcy5tYXggPyB0aGlzLm1heCA6IG9wdGlvbnMucmVmaWxsQW1vdW50KSA6IDFcbiAgICB0aGlzLnJlZmlsbEludGVydmFsID0gb3B0aW9ucz8ucmVmaWxsSW50ZXJ2YWwgPz8gNTAwMFxuICAgIHRoaXMubG9nZ2VyID0gb3B0aW9ucz8ubG9nZ2VyID8/IGxvZ2dlclxuICB9XG5cbiAgLyoqIFRoZSBhbW91bnQgb2YgcmVxdWVzdHMgdGhhdCBzdGlsbCByZW1haW4uICovXG4gIGdldCByZW1haW5pbmcoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy5tYXggPCB0aGlzLnVzZWQgPyAwIDogdGhpcy5tYXggLSB0aGlzLnVzZWRcbiAgfVxuXG4gIC8qKiBSZWZpbGxzIHRoZSBidWNrZXQgYXMgbmVlZGVkLiAqL1xuICByZWZpbGxCdWNrZXQoKTogdm9pZCB7XG4gICAgdGhpcy5sb2dnZXIuZGVidWcoYFtMZWFreUJ1Y2tldF0gVGltZW91dCBmb3IgbGVha3kgYnVja2V0IHJlcXVlc3RzIGV4ZWN1dGVkLiBSZWZpbGxpbmcgYnVja2V0LmApXG4gICAgLy8gTG93ZXIgdGhlIHVzZWQgYW1vdW50IGJ5IHRoZSByZWZpbGwgYW1vdW50XG4gICAgdGhpcy51c2VkID0gdGhpcy5yZWZpbGxBbW91bnQgPiB0aGlzLnVzZWQgPyAwIDogdGhpcy51c2VkIC0gdGhpcy5yZWZpbGxBbW91bnRcbiAgICAvLyBSZXNldCB0aGUgcmVmaWxsc0F0IHRpbWVzdGFtcCBzaW5jZSBpdCBqdXN0IGdvdCByZWZpbGxlZFxuICAgIHRoaXMucmVmaWxsc0F0ID0gdW5kZWZpbmVkXG4gICAgLy8gUmVzZXQgdGhlIHRpbWVvdXRJZFxuICAgIGNsZWFyVGltZW91dCh0aGlzLnRpbWVvdXRJZClcbiAgICB0aGlzLnRpbWVvdXRJZCA9IHVuZGVmaW5lZFxuXG4gICAgaWYgKHRoaXMudXNlZCA+IDApIHtcbiAgICAgIHRoaXMudGltZW91dElkID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgIHRoaXMucmVmaWxsQnVja2V0KClcbiAgICAgIH0sIHRoaXMucmVmaWxsSW50ZXJ2YWwpXG4gICAgICB0aGlzLnJlZmlsbHNBdCA9IERhdGUubm93KCkgKyB0aGlzLnJlZmlsbEludGVydmFsXG4gICAgfVxuICB9XG5cbiAgLyoqIEJlZ2luIHByb2Nlc3NpbmcgdGhlIHF1ZXVlLiAqL1xuICBhc3luYyBwcm9jZXNzUXVldWUoKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgdGhpcy5sb2dnZXIuZGVidWcoJ1tMZWFreUJ1Y2tldF0gUHJvY2Vzc2luZyBxdWV1ZScpXG5cbiAgICAvLyBUaGVyZSBpcyBhbHJlYWR5IGEgcXVldWUgdGhhdCBpcyBwcm9jZXNzaW5nXG4gICAgaWYgKHRoaXMucHJvY2Vzc2luZykgcmV0dXJuIHRoaXMubG9nZ2VyLmRlYnVnKCdbTGVha3lCdWNrZXRdIFF1ZXVlIGlzIGFscmVhZHkgcHJvY2Vzc2luZy4nKVxuXG4gICAgdGhpcy5wcm9jZXNzaW5nID0gdHJ1ZVxuXG4gICAgLy8gQmVnaW4gZ29pbmcgdGhyb3VnaCB0aGUgcXVldWUuXG4gICAgd2hpbGUgKHRoaXMucXVldWUubGVuZ3RoKSB7XG4gICAgICBpZiAodGhpcy5yZW1haW5pbmcpIHtcbiAgICAgICAgdGhpcy5sb2dnZXIuZGVidWcoYFtMZWFreUJ1Y2tldF0gUHJvY2Vzc2luZyBxdWV1ZS4gUmVtYWluaW5nOiAke3RoaXMucmVtYWluaW5nfSBMZW5ndGg6ICR7dGhpcy5xdWV1ZS5sZW5ndGh9YClcbiAgICAgICAgLy8gUmVzb2x2ZXMgdGhlIHByb21pc2UgYWxsb3dpbmcgdGhlIHBhdXNlZCBleGVjdXRpb24gb2YgdGhpcyByZXF1ZXN0IHRvIHJlc29sdmUgYW5kIGNvbnRpbnVlLlxuICAgICAgICB0aGlzLnF1ZXVlLnNoaWZ0KCk/LigpXG4gICAgICAgIC8vIEEgcmVxdWVzdCBjYW4gYmUgbWFkZVxuICAgICAgICB0aGlzLnVzZWQrK1xuXG4gICAgICAgIC8vIENyZWF0ZSBhIG5ldyB0aW1lb3V0IGZvciB0aGlzIHJlcXVlc3QgaWYgbm9uZSBleGlzdHMuXG4gICAgICAgIGlmICghdGhpcy50aW1lb3V0SWQpIHtcbiAgICAgICAgICB0aGlzLmxvZ2dlci5kZWJ1ZyhgW0xlYWt5QnVja2V0XSBDcmVhdGluZyBuZXcgdGltZW91dCBmb3IgbGVha3kgYnVja2V0IHJlcXVlc3RzLmApXG5cbiAgICAgICAgICB0aGlzLnRpbWVvdXRJZCA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICAgICAgdGhpcy5yZWZpbGxCdWNrZXQoKVxuICAgICAgICAgIH0sIHRoaXMucmVmaWxsSW50ZXJ2YWwpXG4gICAgICAgICAgLy8gU2V0IHRoZSB0aW1lIGZvciB3aGVuIHRoaXMgcmVmaWxsIHdpbGwgb2NjdXIuXG4gICAgICAgICAgdGhpcy5yZWZpbGxzQXQgPSBEYXRlLm5vdygpICsgdGhpcy5yZWZpbGxJbnRlcnZhbFxuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIC8vIENoZWNrIGlmIGEgcmVmaWxsIGlzIHNjaGVkdWxlZCwgc2luY2Ugd2UgaGF2ZSB1c2VkIHVwIGFsbCBhdmFpbGFibGUgcmVxdWVzdHNcbiAgICAgIGVsc2UgaWYgKHRoaXMucmVmaWxsc0F0KSB7XG4gICAgICAgIGNvbnN0IG5vdyA9IERhdGUubm93KClcbiAgICAgICAgLy8gSWYgdGhlcmUgaXMgdGltZSBsZWZ0IHVudGlsIG5leHQgcmVmaWxsLCBqdXN0IGRlbGF5IGV4ZWN1dGlvbi5cbiAgICAgICAgaWYgKHRoaXMucmVmaWxsc0F0ID4gbm93KSB7XG4gICAgICAgICAgdGhpcy5sb2dnZXIuZGVidWcoYFtMZWFreUJ1Y2tldF0gRGVsYXlpbmcgZXhlY3V0aW9uIG9mIGxlYWt5IGJ1Y2tldCByZXF1ZXN0cyBmb3IgJHt0aGlzLnJlZmlsbHNBdCAtIG5vd31tc2ApXG4gICAgICAgICAgYXdhaXQgZGVsYXkodGhpcy5yZWZpbGxzQXQgLSBub3cpXG4gICAgICAgICAgdGhpcy5sb2dnZXIuZGVidWcoYFtMZWFreUJ1Y2tldF0gUmVzdW1pbmcgZXhlY3V0aW9uYClcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIElmIHRoZSByZWZpbGxzQXQgaGFzIHBhc3NlZCBidXQgdGhlIHRpbWVvdXQgZGlkbid0IHlldCBleGVjdXRlIGRlbGF5IHRoZSBleGVjdXRpb25cbiAgICAgICAgZWxzZSB7XG4gICAgICAgICAgdGhpcy5sb2dnZXIuZGVidWcoYFtMZWFreUJ1Y2tldF0gRGVsYXlpbmcgZXhlY3V0aW9uIG9mIGxlYWt5IGJ1Y2tldCByZXF1ZXN0cyBmb3IgMTAwMG1zYClcbiAgICAgICAgICBhd2FpdCBkZWxheSgxMDAwKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgLy8gTG9vcCBoYXMgZW5kZWQgbWFyayBmYWxzZSBzbyBpdCBjYW4gcmVzdGFydCBsYXRlciB3aGVuIG5lZWRlZFxuICAgIHRoaXMucHJvY2Vzc2luZyA9IGZhbHNlXG4gIH1cblxuICAvKiogUGF1c2VzIHRoZSBleGVjdXRpb24gdW50aWwgdGhlIHJlcXVlc3QgaXMgYXZhaWxhYmxlIHRvIGJlIG1hZGUuICovXG4gIGFzeW5jIGFjcXVpcmUoaGlnaFByaW9yaXR5PzogYm9vbGVhbik6IFByb21pc2U8dm9pZD4ge1xuICAgIHJldHVybiBhd2FpdCBuZXcgUHJvbWlzZSgocmVzb2x2ZSkgPT4ge1xuICAgICAgLy8gSGlnaCBwcmlvcml0eSByZXF1ZXN0cyBnZXQgYWRkZWQgdG8gdGhlIHN0YXJ0IG9mIHRoZSBxdWV1ZVxuICAgICAgaWYgKGhpZ2hQcmlvcml0eSkgdGhpcy5xdWV1ZS51bnNoaWZ0KHJlc29sdmUpXG4gICAgICAvLyBBbGwgb3RoZXIgcmVxdWVzdHMgZ2V0IHB1c2hlZCB0byB0aGUgZW5kLlxuICAgICAgZWxzZSB0aGlzLnF1ZXVlLnB1c2gocmVzb2x2ZSlcblxuICAgICAgLy8gRWFjaCByZXF1ZXN0IHNob3VsZCB0cmlnZ2VyIHRoZSBxdWV1ZSB0byBiZSBwcm9jZXNzZWQuXG4gICAgICB2b2lkIHRoaXMucHJvY2Vzc1F1ZXVlKClcbiAgICB9KVxuICB9XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGVha3lCdWNrZXRPcHRpb25zIHtcbiAgLyoqXG4gICAqIE1heCByZXF1ZXN0cyBhbGxvd2VkIGF0IG9uY2UuXG4gICAqIEBkZWZhdWx0IDFcbiAgICovXG4gIG1heD86IG51bWJlclxuICAvKipcbiAgICogSW50ZXJ2YWwgaW4gbWlsbGlzZWNvbmRzIGJldHdlZW4gcmVmaWxscy5cbiAgICogQGRlZmF1bHQgNTAwMFxuICAgKi9cbiAgcmVmaWxsSW50ZXJ2YWw/OiBudW1iZXJcbiAgLyoqXG4gICAqIEFtb3VudCBvZiByZXF1ZXN0cyB0byByZWZpbGwgYXQgZWFjaCBpbnRlcnZhbC5cbiAgICogQGRlZmF1bHQgMVxuICAgKi9cbiAgcmVmaWxsQW1vdW50PzogbnVtYmVyXG4gIC8qKlxuICAgKiBUaGUgbG9nZ2VyIHRoYXQgdGhlIGxlYWt5IGJ1Y2tldCB3aWxsIHVzZVxuICAgKiBAZGVmYXVsdCBsb2dnZXIgLy8gVGhlIGxvZ2dlciBleHBvcnRlZCBieSBgQGRpc2NvcmRlbm8vdXRpbHNgXG4gICAqL1xuICBsb2dnZXI/OiBQaWNrPHR5cGVvZiBsb2dnZXIsICdkZWJ1ZycgfCAnaW5mbycgfCAnd2FybicgfCAnZXJyb3InIHwgJ2ZhdGFsJz5cbn1cbiJdLCJuYW1lcyI6WyJsb2dnZXIiLCJkZWxheSIsIkxlYWt5QnVja2V0IiwiY29uc3RydWN0b3IiLCJvcHRpb25zIiwidXNlZCIsInF1ZXVlIiwicHJvY2Vzc2luZyIsIm1heCIsInJlZmlsbEFtb3VudCIsInJlZmlsbEludGVydmFsIiwicmVtYWluaW5nIiwicmVmaWxsQnVja2V0IiwiZGVidWciLCJyZWZpbGxzQXQiLCJ1bmRlZmluZWQiLCJjbGVhclRpbWVvdXQiLCJ0aW1lb3V0SWQiLCJzZXRUaW1lb3V0IiwiRGF0ZSIsIm5vdyIsInByb2Nlc3NRdWV1ZSIsImxlbmd0aCIsInNoaWZ0IiwiYWNxdWlyZSIsImhpZ2hQcmlvcml0eSIsIlByb21pc2UiLCJyZXNvbHZlIiwidW5zaGlmdCIsInB1c2giXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLFlBQVksY0FBYTtBQUNoQyxTQUFTQyxLQUFLLFFBQVEsYUFBWTtBQUVsQyxPQUFPLE1BQU1DO0lBa0JYQyxZQUFZQyxPQUE0QixDQUFFO1FBYjFDLDJEQUEyRCxRQUMzREMsT0FBZTtRQUNmLDBGQUEwRixRQUMxRkMsUUFBMEQsRUFBRTtRQUM1RCxvREFBb0QsUUFDcERDLGFBQXNCO1FBU3BCLElBQUksQ0FBQ0MsR0FBRyxHQUFHSixTQUFTSSxPQUFPO1FBQzNCLElBQUksQ0FBQ0MsWUFBWSxHQUFHTCxTQUFTSyxlQUFnQkwsUUFBUUssWUFBWSxHQUFHLElBQUksQ0FBQ0QsR0FBRyxHQUFHLElBQUksQ0FBQ0EsR0FBRyxHQUFHSixRQUFRSyxZQUFZLEdBQUk7UUFDbEgsSUFBSSxDQUFDQyxjQUFjLEdBQUdOLFNBQVNNLGtCQUFrQjtRQUNqRCxJQUFJLENBQUNWLE1BQU0sR0FBR0ksU0FBU0osVUFBVUE7SUFDbkM7SUFFQSw4Q0FBOEMsR0FDOUMsSUFBSVcsWUFBb0I7UUFDdEIsT0FBTyxJQUFJLENBQUNILEdBQUcsR0FBRyxJQUFJLENBQUNILElBQUksR0FBRyxJQUFJLElBQUksQ0FBQ0csR0FBRyxHQUFHLElBQUksQ0FBQ0gsSUFBSTtJQUN4RDtJQUVBLGtDQUFrQyxHQUNsQ08sZUFBcUI7UUFDbkIsSUFBSSxDQUFDWixNQUFNLENBQUNhLEtBQUssQ0FBQyxDQUFDLDJFQUEyRSxDQUFDO1FBQy9GLDZDQUE2QztRQUM3QyxJQUFJLENBQUNSLElBQUksR0FBRyxJQUFJLENBQUNJLFlBQVksR0FBRyxJQUFJLENBQUNKLElBQUksR0FBRyxJQUFJLElBQUksQ0FBQ0EsSUFBSSxHQUFHLElB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