@discordeno/utils 19.0.0-next.fd518cb → 19.0.0-next.fda3003

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 (124) hide show
  1. package/dist/cjs/Collection.cjs +123 -0
  2. package/dist/cjs/base64.cjs +276 -0
  3. package/dist/cjs/bucket.cjs +96 -0
  4. package/dist/cjs/builders/embeds.cjs +292 -0
  5. package/dist/cjs/builders.cjs +27 -0
  6. package/dist/cjs/casing.cjs +75 -0
  7. package/dist/cjs/colors.cjs +456 -0
  8. package/dist/cjs/hash.cjs +37 -0
  9. package/dist/cjs/images.cjs +136 -0
  10. package/dist/cjs/index.cjs +35 -0
  11. package/dist/cjs/logger.cjs +157 -0
  12. package/dist/cjs/oauth2.cjs +26 -0
  13. package/dist/cjs/permissions.cjs +35 -0
  14. package/dist/cjs/reactions.cjs +21 -0
  15. package/dist/cjs/token.cjs +39 -0
  16. package/dist/cjs/typeguards.cjs +45 -0
  17. package/dist/cjs/urlToBase64.cjs +19 -0
  18. package/dist/cjs/utils.cjs +30 -0
  19. package/dist/esm/Collection.js +113 -0
  20. package/dist/esm/base64.js +262 -0
  21. package/dist/esm/bucket.js +81 -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 +179 -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/tsconfig.tsbuildinfo +1 -0
  38. package/dist/{Collection.d.ts → types/Collection.d.ts} +2 -2
  39. package/dist/types/Collection.d.ts.map +1 -0
  40. package/dist/types/base64.d.ts.map +1 -0
  41. package/dist/{bucket.d.ts → types/bucket.d.ts} +9 -1
  42. package/dist/types/bucket.d.ts.map +1 -0
  43. package/dist/types/builders/embeds.d.ts +146 -0
  44. package/dist/types/builders/embeds.d.ts.map +1 -0
  45. package/dist/types/builders.d.ts +4 -0
  46. package/dist/types/builders.d.ts.map +1 -0
  47. package/dist/types/casing.d.ts.map +1 -0
  48. package/dist/types/colors.d.ts.map +1 -0
  49. package/dist/types/hash.d.ts.map +1 -0
  50. package/dist/types/images.d.ts +202 -0
  51. package/dist/types/images.d.ts.map +1 -0
  52. package/dist/{index.d.ts → types/index.d.ts} +3 -1
  53. package/dist/types/index.d.ts.map +1 -0
  54. package/dist/types/logger.d.ts.map +1 -0
  55. package/dist/types/oauth2.d.ts +69 -0
  56. package/dist/types/oauth2.d.ts.map +1 -0
  57. package/dist/types/permissions.d.ts.map +1 -0
  58. package/dist/types/reactions.d.ts.map +1 -0
  59. package/dist/{token.d.ts → types/token.d.ts} +1 -1
  60. package/dist/types/token.d.ts.map +1 -0
  61. package/dist/{typeguards.d.ts → types/typeguards.d.ts} +2 -1
  62. package/dist/types/typeguards.d.ts.map +1 -0
  63. package/dist/types/urlToBase64.d.ts.map +1 -0
  64. package/dist/types/utils.d.ts.map +1 -0
  65. package/package.json +26 -20
  66. package/dist/Collection.d.ts.map +0 -1
  67. package/dist/Collection.js +0 -113
  68. package/dist/Collection.js.map +0 -1
  69. package/dist/base64.d.ts.map +0 -1
  70. package/dist/base64.js +0 -262
  71. package/dist/base64.js.map +0 -1
  72. package/dist/bucket.d.ts.map +0 -1
  73. package/dist/bucket.js +0 -74
  74. package/dist/bucket.js.map +0 -1
  75. package/dist/casing.d.ts.map +0 -1
  76. package/dist/casing.js +0 -51
  77. package/dist/casing.js.map +0 -1
  78. package/dist/colors.d.ts.map +0 -1
  79. package/dist/colors.js +0 -467
  80. package/dist/colors.js.map +0 -1
  81. package/dist/hash.d.ts.map +0 -1
  82. package/dist/hash.js +0 -19
  83. package/dist/hash.js.map +0 -1
  84. package/dist/images.d.ts +0 -68
  85. package/dist/images.d.ts.map +0 -1
  86. package/dist/images.js +0 -66
  87. package/dist/images.js.map +0 -1
  88. package/dist/index.d.ts.map +0 -1
  89. package/dist/index.js +0 -16
  90. package/dist/index.js.map +0 -1
  91. package/dist/interactions.d.ts +0 -3
  92. package/dist/interactions.d.ts.map +0 -1
  93. package/dist/interactions.js +0 -41
  94. package/dist/interactions.js.map +0 -1
  95. package/dist/logger.d.ts.map +0 -1
  96. package/dist/logger.js +0 -130
  97. package/dist/logger.js.map +0 -1
  98. package/dist/permissions.d.ts.map +0 -1
  99. package/dist/permissions.js +0 -17
  100. package/dist/permissions.js.map +0 -1
  101. package/dist/reactions.d.ts.map +0 -1
  102. package/dist/reactions.js +0 -11
  103. package/dist/reactions.js.map +0 -1
  104. package/dist/token.d.ts.map +0 -1
  105. package/dist/token.js +0 -16
  106. package/dist/token.js.map +0 -1
  107. package/dist/typeguards.d.ts.map +0 -1
  108. package/dist/typeguards.js +0 -15
  109. package/dist/typeguards.js.map +0 -1
  110. package/dist/urlToBase64.d.ts.map +0 -1
  111. package/dist/urlToBase64.js +0 -9
  112. package/dist/urlToBase64.js.map +0 -1
  113. package/dist/utils.d.ts.map +0 -1
  114. package/dist/utils.js +0 -15
  115. package/dist/utils.js.map +0 -1
  116. /package/dist/{base64.d.ts → types/base64.d.ts} +0 -0
  117. /package/dist/{casing.d.ts → types/casing.d.ts} +0 -0
  118. /package/dist/{colors.d.ts → types/colors.d.ts} +0 -0
  119. /package/dist/{hash.d.ts → types/hash.d.ts} +0 -0
  120. /package/dist/{logger.d.ts → types/logger.d.ts} +0 -0
  121. /package/dist/{permissions.d.ts → types/permissions.d.ts} +0 -0
  122. /package/dist/{reactions.d.ts → types/reactions.d.ts} +0 -0
  123. /package/dist/{urlToBase64.d.ts → types/urlToBase64.d.ts} +0 -0
  124. /package/dist/{utils.d.ts → types/utils.d.ts} +0 -0
@@ -0,0 +1,123 @@
1
+ // eslint-disable-next-line @typescript-eslint/no-empty-interface
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "Collection", {
7
+ enumerable: true,
8
+ get: function() {
9
+ return Collection;
10
+ }
11
+ });
12
+ let Collection = class Collection extends Map {
13
+ constructor(entries, options){
14
+ super(entries ?? []);
15
+ this.maxSize = options?.maxSize;
16
+ if (!options?.sweeper) return;
17
+ this.startSweeper(options.sweeper);
18
+ }
19
+ startSweeper(options) {
20
+ if (this.sweeper?.intervalId) clearInterval(this.sweeper.intervalId);
21
+ this.sweeper = options;
22
+ this.sweeper.intervalId = setInterval(()=>{
23
+ this.forEach((value, key)=>{
24
+ if (!this.sweeper?.filter(value, key, options.bot)) return;
25
+ this.delete(key);
26
+ return key;
27
+ });
28
+ }, options.interval);
29
+ return this.sweeper.intervalId;
30
+ }
31
+ stopSweeper() {
32
+ return clearInterval(this.sweeper?.intervalId);
33
+ }
34
+ changeSweeperInterval(newInterval) {
35
+ if (this.sweeper == null) return;
36
+ this.startSweeper({
37
+ filter: this.sweeper.filter,
38
+ interval: newInterval
39
+ });
40
+ }
41
+ changeSweeperFilter(newFilter) {
42
+ if (this.sweeper == null) return;
43
+ this.startSweeper({
44
+ filter: newFilter,
45
+ interval: this.sweeper.interval
46
+ });
47
+ }
48
+ /** Add an item to the collection. Makes sure not to go above the maxSize. */ set(key, value) {
49
+ // When this collection is maxSized make sure we can add first
50
+ if ((this.maxSize !== undefined || this.maxSize === 0) && this.size >= this.maxSize) {
51
+ return this;
52
+ }
53
+ return super.set(key, value);
54
+ }
55
+ /** Add an item to the collection, no matter what the maxSize is. */ forceSet(key, value) {
56
+ return super.set(key, value);
57
+ }
58
+ /** Convert the collection to an array. */ array() {
59
+ return [
60
+ ...this.values()
61
+ ];
62
+ }
63
+ /** Retrieve the value of the first element in this collection. */ first() {
64
+ return this.values().next().value;
65
+ }
66
+ /** Retrieve the value of the last element in this collection. */ last() {
67
+ return [
68
+ ...this.values()
69
+ ][this.size - 1];
70
+ }
71
+ /** Retrieve the value of a random element in this collection. */ random() {
72
+ const array = [
73
+ ...this.values()
74
+ ];
75
+ return array[Math.floor(Math.random() * array.length)];
76
+ }
77
+ /** Find a specific element in this collection. */ find(callback) {
78
+ for (const key of this.keys()){
79
+ const value = this.get(key);
80
+ if (callback(value, key)) return value;
81
+ }
82
+ // If nothing matched
83
+ }
84
+ /** Find all elements in this collection that match the given pattern. */ filter(callback) {
85
+ const relevant = new Collection();
86
+ this.forEach((value, key)=>{
87
+ if (callback(value, key)) relevant.set(key, value);
88
+ });
89
+ return relevant;
90
+ }
91
+ /** Converts the collection into an array by running a callback on all items in the collection. */ map(callback) {
92
+ const results = [];
93
+ for (const key of this.keys()){
94
+ const value = this.get(key);
95
+ results.push(callback(value, key));
96
+ }
97
+ return results;
98
+ }
99
+ /** Check if one of the items in the collection matches the pattern. */ some(callback) {
100
+ for (const key of this.keys()){
101
+ const value = this.get(key);
102
+ if (callback(value, key)) return true;
103
+ }
104
+ return false;
105
+ }
106
+ /** Check if all of the items in the collection matches the pattern. */ every(callback) {
107
+ for (const key of this.keys()){
108
+ const value = this.get(key);
109
+ if (!callback(value, key)) return false;
110
+ }
111
+ return true;
112
+ }
113
+ /** Runs a callback on all items in the collection, merging them into a single value. */ reduce(callback, initialValue) {
114
+ let accumulator = initialValue;
115
+ for (const key of this.keys()){
116
+ const value = this.get(key);
117
+ accumulator = callback(accumulator, value, key);
118
+ }
119
+ return accumulator;
120
+ }
121
+ };
122
+
123
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Db2xsZWN0aW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktaW50ZXJmYWNlXG5leHBvcnQgaW50ZXJmYWNlIFBsYWNlSG9sZGVyQm90IHt9XG5cbmV4cG9ydCBjbGFzcyBDb2xsZWN0aW9uPEssIFY+IGV4dGVuZHMgTWFwPEssIFY+IHtcbiAgLyoqXG4gICAqIFRoZSBtYXhpbXVtIGFtb3VudCBvZiBpdGVtcyBhbGxvd2VkIGluIHRoaXMgY29sbGVjdGlvbi4gVG8gZGlzYWJsZSBjYWNoZSwgc2V0IGl0IDAsIHNldCB0byB1bmRlZmluZWQgdG8gbWFrZSBpdCBpbmZpbml0ZS5cbiAgICogQGRlZmF1bHQgdW5kZWZpbmVkXG4gICAqL1xuICBtYXhTaXplOiBudW1iZXIgfCB1bmRlZmluZWRcbiAgLyoqIEhhbmRsZXIgdG8gcmVtb3ZlIGl0ZW1zIGZyb20gdGhlIGNvbGxlY3Rpb24gZXZlcnkgc28gb2Z0ZW4uICovXG4gIHN3ZWVwZXI6IChDb2xsZWN0aW9uU3dlZXBlcjxLLCBWPiAmIHsgaW50ZXJ2YWxJZD86IE5vZGVKUy5UaW1lb3V0IH0pIHwgdW5kZWZpbmVkXG5cbiAgY29uc3RydWN0b3IoZW50cmllcz86IChSZWFkb25seUFycmF5PHJlYWRvbmx5IFtLLCBWXT4gfCBudWxsKSB8IE1hcDxLLCBWPiwgb3B0aW9ucz86IENvbGxlY3Rpb25PcHRpb25zPEssIFY+KSB7XG4gICAgc3VwZXIoZW50cmllcyA/PyBbXSlcblxuICAgIHRoaXMubWF4U2l6ZSA9IG9wdGlvbnM/Lm1heFNpemVcblxuICAgIGlmICghb3B0aW9ucz8uc3dlZXBlcikgcmV0dXJuXG5cbiAgICB0aGlzLnN0YXJ0U3dlZXBlcihvcHRpb25zLnN3ZWVwZXIpXG4gIH1cblxuICBzdGFydFN3ZWVwZXIob3B0aW9uczogQ29sbGVjdGlvblN3ZWVwZXI8SywgVj4pOiBOb2RlSlMuVGltZW91dCB7XG4gICAgaWYgKHRoaXMuc3dlZXBlcj8uaW50ZXJ2YWxJZCkgY2xlYXJJbnRlcnZhbCh0aGlzLnN3ZWVwZXIuaW50ZXJ2YWxJZClcblxuICAgIHRoaXMuc3dlZXBlciA9IG9wdGlvbnNcbiAgICB0aGlzLnN3ZWVwZXIuaW50ZXJ2YWxJZCA9IHNldEludGVydmFsKCgpID0+IHtcbiAgICAgIHRoaXMuZm9yRWFjaCgodmFsdWUsIGtleSkgPT4ge1xuICAgICAgICBpZiAoIXRoaXMuc3dlZXBlcj8uZmlsdGVyKHZhbHVlLCBrZXksIG9wdGlvbnMuYm90KSkgcmV0dXJuXG5cbiAgICAgICAgdGhpcy5kZWxldGUoa2V5KVxuICAgICAgICByZXR1cm4ga2V5XG4gICAgICB9KVxuICAgIH0sIG9wdGlvbnMuaW50ZXJ2YWwpXG5cbiAgICByZXR1cm4gdGhpcy5zd2VlcGVyLmludGVydmFsSWRcbiAgfVxuXG4gIHN0b3BTd2VlcGVyKCk6IHZvaWQge1xuICAgIHJldHVybiBjbGVhckludGVydmFsKHRoaXMuc3dlZXBlcj8uaW50ZXJ2YWxJZClcbiAgfVxuXG4gIGNoYW5nZVN3ZWVwZXJJbnRlcnZhbChuZXdJbnRlcnZhbDogbnVtYmVyKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuc3dlZXBlciA9PSBudWxsKSByZXR1cm5cblxuICAgIHRoaXMuc3RhcnRTd2VlcGVyKHsgZmlsdGVyOiB0aGlzLnN3ZWVwZXIuZmlsdGVyLCBpbnRlcnZhbDogbmV3SW50ZXJ2YWwgfSlcbiAgfVxuXG4gIGNoYW5nZVN3ZWVwZXJGaWx0ZXIobmV3RmlsdGVyOiAodmFsdWU6IFYsIGtleTogSywgYm90OiBQbGFjZUhvbGRlckJvdCkgPT4gYm9vbGVhbik6IHZvaWQge1xuICAgIGlmICh0aGlzLnN3ZWVwZXIgPT0gbnVsbCkgcmV0dXJuXG5cbiAgICB0aGlzLnN0YXJ0U3dlZXBlcih7IGZpbHRlcjogbmV3RmlsdGVyLCBpbnRlcnZhbDogdGhpcy5zd2VlcGVyLmludGVydmFsIH0pXG4gIH1cblxuICAvKiogQWRkIGFuIGl0ZW0gdG8gdGhlIGNvbGxlY3Rpb24uIE1ha2VzIHN1cmUgbm90IHRvIGdvIGFib3ZlIHRoZSBtYXhTaXplLiAqL1xuICBzZXQoa2V5OiBLLCB2YWx1ZTogVik6IHRoaXMge1xuICAgIC8vIFdoZW4gdGhpcyBjb2xsZWN0aW9uIGlzIG1heFNpemVkIG1ha2Ugc3VyZSB3ZSBjYW4gYWRkIGZpcnN0XG4gICAgaWYgKCh0aGlzLm1heFNpemUgIT09IHVuZGVmaW5lZCB8fCB0aGlzLm1heFNpemUgPT09IDApICYmIHRoaXMuc2l6ZSA+PSB0aGlzLm1heFNpemUpIHtcbiAgICAgIHJldHVybiB0aGlzXG4gICAgfVxuXG4gICAgcmV0dXJuIHN1cGVyLnNldChrZXksIHZhbHVlKVxuICB9XG5cbiAgLyoqIEFkZCBhbiBpdGVtIHRvIHRoZSBjb2xsZWN0aW9uLCBubyBtYXR0ZXIgd2hhdCB0aGUgbWF4U2l6ZSBpcy4gKi9cbiAgZm9yY2VTZXQoa2V5OiBLLCB2YWx1ZTogVik6IHRoaXMge1xuICAgIHJldHVybiBzdXBlci5zZXQoa2V5LCB2YWx1ZSlcbiAgfVxuXG4gIC8qKiBDb252ZXJ0IHRoZSBjb2xsZWN0aW9uIHRvIGFuIGFycmF5LiAqL1xuICBhcnJheSgpOiBWW10ge1xuICAgIHJldHVybiBbLi4udGhpcy52YWx1ZXMoKV1cbiAgfVxuXG4gIC8qKiBSZXRyaWV2ZSB0aGUgdmFsdWUgb2YgdGhlIGZpcnN0IGVsZW1lbnQgaW4gdGhpcyBjb2xsZWN0aW9uLiAqL1xuICBmaXJzdCgpOiBWIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gdGhpcy52YWx1ZXMoKS5uZXh0KCkudmFsdWVcbiAgfVxuXG4gIC8qKiBSZXRyaWV2ZSB0aGUgdmFsdWUgb2YgdGhlIGxhc3QgZWxlbWVudCBpbiB0aGlzIGNvbGxlY3Rpb24uICovXG4gIGxhc3QoKTogViB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIFsuLi50aGlzLnZhbHVlcygpXVt0aGlzLnNpemUgLSAxXVxuICB9XG5cbiAgLyoqIFJldHJpZXZlIHRoZSB2YWx1ZSBvZiBhIHJhbmRvbSBlbGVtZW50IGluIHRoaXMgY29sbGVjdGlvbi4gKi9cbiAgcmFuZG9tKCk6IFYgfCB1bmRlZmluZWQge1xuICAgIGNvbnN0IGFycmF5ID0gWy4uLnRoaXMudmFsdWVzKCldXG4gICAgcmV0dXJuIGFycmF5W01hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIGFycmF5Lmxlbmd0aCldXG4gIH1cblxuICAvKiogRmluZCBhIHNwZWNpZmljIGVsZW1lbnQgaW4gdGhpcyBjb2xsZWN0aW9uLiAqL1xuICBmaW5kKGNhbGxiYWNrOiAodmFsdWU6IFYsIGtleTogSykgPT4gYm9vbGVhbik6IE5vbk51bGxhYmxlPFY+IHwgdW5kZWZpbmVkIHtcbiAgICBmb3IgKGNvbnN0IGtleSBvZiB0aGlzLmtleXMoKSkge1xuICAgICAgY29uc3QgdmFsdWUgPSB0aGlzLmdldChrZXkpIVxuICAgICAgaWYgKGNhbGxiYWNrKHZhbHVlLCBrZXkpKSByZXR1cm4gdmFsdWVcbiAgICB9XG4gICAgLy8gSWYgbm90aGluZyBtYXRjaGVkXG4gIH1cblxuICAvKiogRmluZCBhbGwgZWxlbWVudHMgaW4gdGhpcyBjb2xsZWN0aW9uIHRoYXQgbWF0Y2ggdGhlIGdpdmVuIHBhdHRlcm4uICovXG4gIGZpbHRlcihjYWxsYmFjazogKHZhbHVlOiBWLCBrZXk6IEspID0+IGJvb2xlYW4pOiBDb2xsZWN0aW9uPEssIFY+IHtcbiAgICBjb25zdCByZWxldmFudCA9IG5ldyBDb2xsZWN0aW9uPEssIFY+KClcbiAgICB0aGlzLmZvckVhY2goKHZhbHVlLCBrZXkpID0+IHtcbiAgICAgIGlmIChjYWxsYmFjayh2YWx1ZSwga2V5KSkgcmVsZXZhbnQuc2V0KGtleSwgdmFsdWUpXG4gICAgfSlcblxuICAgIHJldHVybiByZWxldmFudFxuICB9XG5cbiAgLyoqIENvbnZlcnRzIHRoZSBjb2xsZWN0aW9uIGludG8gYW4gYXJyYXkgYnkgcnVubmluZyBhIGNhbGxiYWNrIG9uIGFsbCBpdGVtcyBpbiB0aGUgY29sbGVjdGlvbi4gKi9cbiAgbWFwPFQ+KGNhbGxiYWNrOiAodmFsdWU6IFYsIGtleTogSykgPT4gVCk6IFRbXSB7XG4gICAgY29uc3QgcmVzdWx0cyA9IFtdXG4gICAgZm9yIChjb25zdCBrZXkgb2YgdGhpcy5rZXlzKCkpIHtcbiAgICAgIGNvbnN0IHZhbHVlID0gdGhpcy5nZXQoa2V5KSFcbiAgICAgIHJlc3VsdHMucHVzaChjYWxsYmFjayh2YWx1ZSwga2V5KSlcbiAgICB9XG4gICAgcmV0dXJuIHJlc3VsdHNcbiAgfVxuXG4gIC8qKiBDaGVjayBpZiBvbmUgb2YgdGhlIGl0ZW1zIGluIHRoZSBjb2xsZWN0aW9uIG1hdGNoZXMgdGhlIHBhdHRlcm4uICovXG4gIHNvbWUoY2FsbGJhY2s6ICh2YWx1ZTogViwga2V5OiBLKSA9PiBib29sZWFuKTogYm9vbGVhbiB7XG4gICAgZm9yIChjb25zdCBrZXkgb2YgdGhpcy5rZXlzKCkpIHtcbiAgICAgIGNvbnN0IHZhbHVlID0gdGhpcy5nZXQoa2V5KSFcbiAgICAgIGlmIChjYWxsYmFjayh2YWx1ZSwga2V5KSkgcmV0dXJuIHRydWVcbiAgICB9XG5cbiAgICByZXR1cm4gZmFsc2VcbiAgfVxuXG4gIC8qKiBDaGVjayBpZiBhbGwgb2YgdGhlIGl0ZW1zIGluIHRoZSBjb2xsZWN0aW9uIG1hdGNoZXMgdGhlIHBhdHRlcm4uICovXG4gIGV2ZXJ5KGNhbGxiYWNrOiAodmFsdWU6IFYsIGtleTogSykgPT4gYm9vbGVhbik6IGJvb2xlYW4ge1xuICAgIGZvciAoY29uc3Qga2V5IG9mIHRoaXMua2V5cygpKSB7XG4gICAgICBjb25zdCB2YWx1ZSA9IHRoaXMuZ2V0KGtleSkhXG4gICAgICBpZiAoIWNhbGxiYWNrKHZhbHVlLCBrZXkpKSByZXR1cm4gZmFsc2VcbiAgICB9XG5cbiAgICByZXR1cm4gdHJ1ZVxuICB9XG5cbiAgLyoqIFJ1bnMgYSBjYWxsYmFjayBvbiBhbGwgaXRlbXMgaW4gdGhlIGNvbGxlY3Rpb24sIG1lcmdpbmcgdGhlbSBpbnRvIGEgc2luZ2xlIHZhbHVlLiAqL1xuICByZWR1Y2U8VD4oY2FsbGJhY2s6IChhY2N1bXVsYXRvcjogVCwgdmFsdWU6IFYsIGtleTogSykgPT4gVCwgaW5pdGlhbFZhbHVlPzogVCk6IFQge1xuICAgIGxldCBhY2N1bXVsYXRvcjogVCA9IGluaXRpYWxWYWx1ZSFcblxuICAgIGZvciAoY29uc3Qga2V5IG9mIHRoaXMua2V5cygpKSB7XG4gICAgICBjb25zdCB2YWx1ZSA9IHRoaXMuZ2V0KGtleSkhXG4gICAgICBhY2N1bXVsYXRvciA9IGNhbGxiYWNrKGFjY3VtdWxhdG9yLCB2YWx1ZSwga2V5KVxuICAgIH1cblxuICAgIHJldHVybiBhY2N1bXVsYXRvclxuICB9XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29sbGVjdGlvbk9wdGlvbnM8SywgVj4ge1xuICAvKiogSGFuZGxlciB0byBjbGVhbiBvdXQgdGhlIGl0ZW1zIGluIHRoZSBjb2xsZWN0aW9uIGV2ZXJ5IHNvIG9mdGVuLiAqL1xuICBzd2VlcGVyPzogQ29sbGVjdGlvblN3ZWVwZXI8SywgVj5cbiAgLyoqIFRoZSBtYXhpbXVtIG51bWJlciBvZiBpdGVtcyBhbGxvd2VkIGluIHRoZSBjb2xsZWN0aW9uLiAqL1xuICBtYXhTaXplPzogbnVtYmVyXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29sbGVjdGlvblN3ZWVwZXI8SywgVj4ge1xuICAvKiogVGhlIGZpbHRlciB0byBkZXRlcm1pbmUgd2hldGhlciBhbiBlbGVtZW50IHNob3VsZCBiZSBkZWxldGVkIG9yIG5vdCAqL1xuICBmaWx0ZXI6ICh2YWx1ZTogViwga2V5OiBLLCAuLi5hcmdzOiBhbnlbXSkgPT4gYm9vbGVhblxuICAvKiogVGhlIGludGVydmFsIGluIHdoaWNoIHRoZSBzd2VlcGVyIHNob3VsZCBydW4gKi9cbiAgaW50ZXJ2YWw6IG51bWJlclxuICAvKiogVGhlIGJvdCBvYmplY3QgaXRzZWxmICovXG4gIGJvdD86IFBsYWNlSG9sZGVyQm90XG59XG4iXSwibmFtZXMiOlsiQ29sbGVjdGlvbiIsIk1hcCIsImNvbnN0cnVjdG9yIiwiZW50cmllcyIsIm9wdGlvbnMiLCJtYXhTaXplIiwic3dlZXBlciIsInN0YXJ0U3dlZXBlciIsImludGVydmFsSWQiLCJjbGVhckludGVydmFsIiwic2V0SW50ZXJ2YWwiLCJmb3JFYWNoIiwidmFsdWUiLCJrZXkiLCJmaWx0ZXIiLCJib3QiLCJkZWxldGUiLCJpbnRlcnZhbCIsInN0b3BTd2VlcGVyIiwiY2hhbmdlU3dlZXBlckludGVydmFsIiwibmV3SW50ZXJ2YWwiLCJjaGFuZ2VTd2VlcGVyRmlsdGVyIiwibmV3RmlsdGVyIiwic2V0IiwidW5kZWZpbmVkIiwic2l6ZSIsImZvcmNlU2V0IiwiYXJyYXkiLCJ2YWx1ZXMiLCJmaXJzdCIsIm5leHQiLCJsYXN0IiwicmFuZG9tIiwiTWF0aCIsImZsb29yIiwibGVuZ3RoIiwiZmluZCIsImNhbGxiYWNrIiwia2V5cyIsImdldCIsInJlbGV2YW50IiwibWFwIiwicmVzdWx0cyIsInB1c2giLCJzb21lIiwiZXZlcnkiLCJyZWR1Y2UiLCJpbml0aWFsVmFsdWUiLCJhY2N1bXVsYXRvciJdLCJtYXBwaW5ncyI6IkFBQUEsaUVBQWlFOzs7OzsrQkFHcERBOzs7ZUFBQUE7OztBQUFOLElBQUEsQUFBTUEsYUFBTixNQUFNQSxtQkFBeUJDO0lBU3BDQyxZQUFZQyxPQUE2RCxFQUFFQyxPQUFpQyxDQUFFO1FBQzVHLEtBQUssQ0FBQ0QsV0FBVyxFQUFFO1FBRW5CLElBQUksQ0FBQ0UsT0FBTyxHQUFHRCxTQUFTQztRQUV4QixJQUFJLENBQUNELFNBQVNFLFNBQVM7UUFFdkIsSUFBSSxDQUFDQyxZQUFZLENBQUNILFFBQVFFLE9BQU87SUFDbkM7SUFFQUMsYUFBYUgsT0FBZ0MsRUFBa0I7UUFDN0QsSUFBSSxJQUFJLENBQUNFLE9BQU8sRUFBRUUsWUFBWUMsY0FBYyxJQUFJLENBQUNILE9BQU8sQ0FBQ0UsVUFBVTtRQUVuRSxJQUFJLENBQUNGLE9BQU8sR0FBR0Y7UUFDZixJQUFJLENBQUNFLE9BQU8sQ0FBQ0UsVUFBVSxHQUFHRSxZQUFZO1lBQ3BDLElBQUksQ0FBQ0MsT0FBTyxDQUFDLENBQUNDLE9BQU9DO2dCQUNuQixJQUFJLENBQUMsSUFBSSxDQUFDUCxPQUFPLEVBQUVRLE9BQU9GLE9BQU9DLEtBQUtULFFBQVFXLEdBQUcsR0FBRztnQkFFcEQsSUFBSSxDQUFDQyxNQUFNLENBQUNIO2dCQUNaLE9BQU9BO1lBQ1Q7UUFDRixHQUFHVCxRQUFRYSxRQUFRO1FBRW5CLE9BQU8sSUFBSSxDQUFDWCxPQUFPLENBQUNFLFVBQVU7SUFDaEM7SUFFQVUsY0FBb0I7UUFDbEIsT0FBT1QsY0FBYyxJQUFJLENBQUNILE9BQU8sRUFBRUU7SUFDckM7SUFFQVcsc0JBQXNCQyxXQUFtQixFQUFRO1FBQy9DLElBQUksSUFBSSxDQUFDZCxPQUFPLElBQUksTUFBTTtRQUUxQixJQUFJLENBQUNDLFlBQVksQ0FBQztZQUFFTyxRQUFRLElBQUksQ0FBQ1IsT0FBTyxDQUFDUSxNQUFNO1lBQUVHLFVBQVVHO1FBQVk7SUFDekU7SUFFQUMsb0JBQW9CQyxTQUE2RCxFQUFRO1FBQ3ZGLElBQUksSUFBSSxDQUFDaEIsT0FBTyxJQUFJLE1BQU07UUFFMUIsSUFBSSxDQUFDQyxZQUFZLENBQUM7WUFBRU8sUUFBUVE7WUFBV0wsVUFBVSxJQUFJLENBQUNYLE9BQU8sQ0FBQ1csUUFBUTtRQUFDO0lBQ3pFO0lBRUEsMkVBQTJFLEdBQzNFTSxJQUFJVixHQUFNLEVBQUVELEtBQVEsRUFBUTtRQUMxQiw4REFBOEQ7UUFDOUQsSUFBSSxBQUFDLENBQUEsSUFBSSxDQUFDUCxPQUFPLEtBQUttQixhQUFhLElBQUksQ0FBQ25CLE9BQU8sS0FBSyxDQUFBLEtBQU0sSUFBSSxDQUFDb0IsSUFBSSxJQUFJLElBQUksQ0FBQ3BCLE9BQU8sRUFBRTtZQUNuRixPQUFPLElBQUk7UUFDYjtRQUVBLE9BQU8sS0FBSyxDQUFDa0IsSUFBSVYsS0FBS0Q7SUFDeEI7SUFFQSxrRUFBa0UsR0FDbEVjLFNBQVNiLEdBQU0sRUFBRUQsS0FBUSxFQUFRO1FBQy9CLE9BQU8sS0FBSyxDQUFDVyxJQUFJVixLQUFLRDtJQUN4QjtJQUVBLHdDQUF3QyxHQUN4Q2UsUUFBYTtRQUNYLE9BQU87ZUFBSSxJQUFJLENBQUNDLE1BQU07U0FBRztJQUMzQjtJQUVBLGdFQUFnRSxHQUNoRUMsUUFBdUI7UUFDckIsT0FBTyxJQUFJLENBQUNELE1BQU0sR0FBR0UsSUFBSSxHQUFHbEIsS0FBSztJQUNuQztJQUVBLCtEQUErRCxHQUMvRG1CLE9BQXNCO1FBQ3BCLE9BQU87ZUFBSSxJQUFJLENBQUNILE1BQU07U0FBRyxDQUFDLElBQUksQ0FBQ0gsSUFBSSxHQUFHLEVBQUU7SUFDMUM7SUFFQSwrREFBK0QsR0FDL0RPLFNBQXdCO1FBQ3RCLE1BQU1MLFFBQVE7ZUFBSSxJQUFJLENBQUNDLE1BQU07U0FBRztRQUNoQyxPQUFPRCxLQUFLLENBQUNNLEtBQUtDLEtBQUssQ0FBQ0QsS0FBS0QsTUFBTSxLQUFLTCxNQUFNUSxNQUFNLEVBQUU7SUFDeEQ7SUFFQSxnREFBZ0QsR0FDaERDLEtBQUtDLFFBQXVDLEVBQThCO1FBQ3hFLEtBQUssTUFBTXhCLE9BQU8sSUFBSSxDQUFDeUIsSUFBSSxHQUFJO1lBQzdCLE1BQU0xQixRQUFRLElBQUksQ0FBQzJCLEdBQUcsQ0FBQzFCO1lBQ3ZCLElBQUl3QixTQUFTekIsT0FBT0MsTUFBTSxPQUFPRDtRQUNuQztJQUNBLHFCQUFxQjtJQUN2QjtJQUVBLHVFQUF1RSxHQUN2RUUsT0FBT3VCLFFBQXVDLEVBQW9CO1FBQ2hFLE1BQU1HLFdBQVcsSUFBSXhDO1FBQ3JCLElBQUksQ0FBQ1csT0FBTyxDQUFDLENBQUNDLE9BQU9DO1lBQ25CLElBQUl3QixTQUFTekIsT0FBT0MsTUFBTTJCLFNBQVNqQixHQUFHLENBQUNWLEtBQUtEO1FBQzlDO1FBRUEsT0FBTzRCO0lBQ1Q7SUFFQSxnR0FBZ0csR0FDaEdDLElBQU9KLFFBQWlDLEVBQU87UUFDN0MsTUFBTUssVUFBVSxFQUFFO1FBQ2xCLEtBQUssTUFBTTdCLE9BQU8sSUFBSSxDQUFDeUIsSUFBSSxHQUFJO1lBQzdCLE1BQU0xQixRQUFRLElBQUksQ0FBQzJCLEdBQUcsQ0FBQzFCO1lBQ3ZCNkIsUUFBUUMsSUFBSSxDQUFDTixTQUFTekIsT0FBT0M7UUFDL0I7UUFDQSxPQUFPNkI7SUFDVDtJQUVBLHFFQUFxRSxHQUNyRUUsS0FBS1AsUUFBdUMsRUFBVztRQUNyRCxLQUFLLE1BQU14QixPQUFPLElBQUksQ0FBQ3lCLElBQUksR0FBSTtZQUM3QixNQUFNMUIsUUFBUSxJQUFJLENBQUMyQixHQUFHLENBQUMxQjtZQUN2QixJQUFJd0IsU0FBU3pCLE9BQU9DLE1BQU0sT0FBTztRQUNuQztRQUVBLE9BQU87SUFDVDtJQUVBLHFFQUFxRSxHQUNyRWdDLE1BQU1SLFFBQXVDLEVBQVc7UUFDdEQsS0FBSyxNQUFNeEIsT0FBTyxJQUFJLENBQUN5QixJQUFJLEdBQUk7WUFDN0IsTUFBTTFCLFFBQVEsSUFBSSxDQUFDMkIsR0FBRyxDQUFDMUI7WUFDdkIsSUFBSSxDQUFDd0IsU0FBU3pCLE9BQU9DLE1BQU0sT0FBTztRQUNwQztRQUVBLE9BQU87SUFDVDtJQUVBLHNGQUFzRixHQUN0RmlDLE9BQVVULFFBQWlELEVBQUVVLFlBQWdCLEVBQUs7UUFDaEYsSUFBSUMsY0FBaUJEO1FBRXJCLEtBQUssTUFBTWxDLE9BQU8sSUFBSSxDQUFDeUIsSUFBSSxHQUFJO1lBQzdCLE1BQU0xQixRQUFRLElBQUksQ0FBQzJCLEdBQUcsQ0FBQzFCO1lBQ3ZCbUMsY0FBY1gsU0FBU1csYUFBYXBDLE9BQU9DO1FBQzdDO1FBRUEsT0FBT21DO0lBQ1Q7QUFDRiJ9
@@ -0,0 +1,276 @@
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
+ */ "use strict";
6
+ Object.defineProperty(exports, "__esModule", {
7
+ value: true
8
+ });
9
+ function _export(target, all) {
10
+ for(var name in all)Object.defineProperty(target, name, {
11
+ enumerable: true,
12
+ get: all[name]
13
+ });
14
+ }
15
+ _export(exports, {
16
+ decode: function() {
17
+ return decode;
18
+ },
19
+ encode: function() {
20
+ return encode;
21
+ }
22
+ });
23
+ function encode(data) {
24
+ const uint8 = typeof data === 'string' ? new TextEncoder().encode(data) : data instanceof Uint8Array ? data : new Uint8Array(data);
25
+ let result = '';
26
+ let i;
27
+ const l = uint8.length;
28
+ for(i = 2; i < l; i += 3){
29
+ result += base64abc[uint8[i - 2] >> 2];
30
+ result += base64abc[(uint8[i - 2] & 0x03) << 4 | uint8[i - 1] >> 4];
31
+ result += base64abc[(uint8[i - 1] & 0x0f) << 2 | uint8[i] >> 6];
32
+ result += base64abc[uint8[i] & 0x3f];
33
+ }
34
+ if (i === l + 1) {
35
+ // 1 octet yet to write
36
+ result += base64abc[uint8[i - 2] >> 2];
37
+ result += base64abc[(uint8[i - 2] & 0x03) << 4];
38
+ result += '==';
39
+ }
40
+ if (i === l) {
41
+ // 2 octets yet to write
42
+ result += base64abc[uint8[i - 2] >> 2];
43
+ result += base64abc[(uint8[i - 2] & 0x03) << 4 | uint8[i - 1] >> 4];
44
+ result += base64abc[(uint8[i - 1] & 0x0f) << 2];
45
+ result += '=';
46
+ }
47
+ return result;
48
+ }
49
+ function decode(data) {
50
+ if (data.length % 4 !== 0) {
51
+ throw new Error('Unable to parse base64 string.');
52
+ }
53
+ const index = data.indexOf('=');
54
+ if (index !== -1 && index < data.length - 2) {
55
+ throw new Error('Unable to parse base64 string.');
56
+ }
57
+ const missingOctets = data.endsWith('==') ? 2 : data.endsWith('=') ? 1 : 0;
58
+ const n = data.length;
59
+ const result = new Uint8Array(3 * (n / 4));
60
+ let buffer;
61
+ for(let i = 0, j = 0; i < n; i += 4, j += 3){
62
+ buffer = getBase64Code(data.charCodeAt(i)) << 18 | getBase64Code(data.charCodeAt(i + 1)) << 12 | getBase64Code(data.charCodeAt(i + 2)) << 6 | getBase64Code(data.charCodeAt(i + 3));
63
+ result[j] = buffer >> 16;
64
+ result[j + 1] = buffer >> 8 & 0xff;
65
+ result[j + 2] = buffer & 0xff;
66
+ }
67
+ return result.subarray(0, result.length - missingOctets);
68
+ }
69
+ /**
70
+ * CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727
71
+ * @param charCode
72
+ */ function getBase64Code(charCode) {
73
+ if (charCode >= base64codes.length) {
74
+ throw new Error('Unable to parse base64 string.');
75
+ }
76
+ const code = base64codes[charCode];
77
+ if (code === 255) {
78
+ throw new Error('Unable to parse base64 string.');
79
+ }
80
+ return code;
81
+ }
82
+ // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
83
+ const base64abc = [
84
+ 'A',
85
+ 'B',
86
+ 'C',
87
+ 'D',
88
+ 'E',
89
+ 'F',
90
+ 'G',
91
+ 'H',
92
+ 'I',
93
+ 'J',
94
+ 'K',
95
+ 'L',
96
+ 'M',
97
+ 'N',
98
+ 'O',
99
+ 'P',
100
+ 'Q',
101
+ 'R',
102
+ 'S',
103
+ 'T',
104
+ 'U',
105
+ 'V',
106
+ 'W',
107
+ 'X',
108
+ 'Y',
109
+ 'Z',
110
+ 'a',
111
+ 'b',
112
+ 'c',
113
+ 'd',
114
+ 'e',
115
+ 'f',
116
+ 'g',
117
+ 'h',
118
+ 'i',
119
+ 'j',
120
+ 'k',
121
+ 'l',
122
+ 'm',
123
+ 'n',
124
+ 'o',
125
+ 'p',
126
+ 'q',
127
+ 'r',
128
+ 's',
129
+ 't',
130
+ 'u',
131
+ 'v',
132
+ 'w',
133
+ 'x',
134
+ 'y',
135
+ 'z',
136
+ '0',
137
+ '1',
138
+ '2',
139
+ '3',
140
+ '4',
141
+ '5',
142
+ '6',
143
+ '7',
144
+ '8',
145
+ '9',
146
+ '+',
147
+ '/'
148
+ ];
149
+ // CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727
150
+ const base64codes = [
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
+ 255,
181
+ 255,
182
+ 255,
183
+ 255,
184
+ 255,
185
+ 255,
186
+ 255,
187
+ 255,
188
+ 255,
189
+ 255,
190
+ 255,
191
+ 255,
192
+ 255,
193
+ 255,
194
+ 62,
195
+ 255,
196
+ 255,
197
+ 255,
198
+ 63,
199
+ 52,
200
+ 53,
201
+ 54,
202
+ 55,
203
+ 56,
204
+ 57,
205
+ 58,
206
+ 59,
207
+ 60,
208
+ 61,
209
+ 255,
210
+ 255,
211
+ 255,
212
+ 0,
213
+ 255,
214
+ 255,
215
+ 255,
216
+ 0,
217
+ 1,
218
+ 2,
219
+ 3,
220
+ 4,
221
+ 5,
222
+ 6,
223
+ 7,
224
+ 8,
225
+ 9,
226
+ 10,
227
+ 11,
228
+ 12,
229
+ 13,
230
+ 14,
231
+ 15,
232
+ 16,
233
+ 17,
234
+ 18,
235
+ 19,
236
+ 20,
237
+ 21,
238
+ 22,
239
+ 23,
240
+ 24,
241
+ 25,
242
+ 255,
243
+ 255,
244
+ 255,
245
+ 255,
246
+ 255,
247
+ 255,
248
+ 26,
249
+ 27,
250
+ 28,
251
+ 29,
252
+ 30,
253
+ 31,
254
+ 32,
255
+ 33,
256
+ 34,
257
+ 35,
258
+ 36,
259
+ 37,
260
+ 38,
261
+ 39,
262
+ 40,
263
+ 41,
264
+ 42,
265
+ 43,
266
+ 44,
267
+ 45,
268
+ 46,
269
+ 47,
270
+ 48,
271
+ 49,
272
+ 50,
273
+ 51
274
+ ];
275
+
276
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iYXNlNjQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDUkVESVQ6IGh0dHBzOi8vZ2lzdC5naXRodWIuY29tL2VuZXBvbW55YXNjaGloLzcyYzQyM2Y3MjdkMzk1ZWVhYTA5Njk3MDU4MjM4NzI3XG4gKiBFbmNvZGVzIGEgZ2l2ZW4gVWludDhBcnJheSwgQXJyYXlCdWZmZXIgb3Igc3RyaW5nIGludG8gUkZDNDY0OCBiYXNlNjQgcmVwcmVzZW50YXRpb25cbiAqIEBwYXJhbSBkYXRhXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBlbmNvZGUoZGF0YTogQXJyYXlCdWZmZXIgfCBzdHJpbmcpOiBzdHJpbmcge1xuICBjb25zdCB1aW50OCA9IHR5cGVvZiBkYXRhID09PSAnc3RyaW5nJyA/IG5ldyBUZXh0RW5jb2RlcigpLmVuY29kZShkYXRhKSA6IGRhdGEgaW5zdGFuY2VvZiBVaW50OEFycmF5ID8gZGF0YSA6IG5ldyBVaW50OEFycmF5KGRhdGEpXG4gIGxldCByZXN1bHQgPSAnJ1xuICBsZXQgaVxuICBjb25zdCBsID0gdWludDgubGVuZ3RoXG4gIGZvciAoaSA9IDI7IGkgPCBsOyBpICs9IDMpIHtcbiAgICByZXN1bHQgKz0gYmFzZTY0YWJjW3VpbnQ4W2kgLSAyXSA+PiAyXVxuICAgIHJlc3VsdCArPSBiYXNlNjRhYmNbKCh1aW50OFtpIC0gMl0gJiAweDAzKSA8PCA0KSB8ICh1aW50OFtpIC0gMV0gPj4gNCldXG4gICAgcmVzdWx0ICs9IGJhc2U2NGFiY1soKHVpbnQ4W2kgLSAxXSAmIDB4MGYpIDw8IDIpIHwgKHVpbnQ4W2ldID4+IDYpXVxuICAgIHJlc3VsdCArPSBiYXNlNjRhYmNbdWludDhbaV0gJiAweDNmXVxuICB9XG4gIGlmIChpID09PSBsICsgMSkge1xuICAgIC8vIDEgb2N0ZXQgeWV0IHRvIHdyaXRlXG4gICAgcmVzdWx0ICs9IGJhc2U2NGFiY1t1aW50OFtpIC0gMl0gPj4gMl1cbiAgICByZXN1bHQgKz0gYmFzZTY0YWJjWyh1aW50OFtpIC0gMl0gJiAweDAzKSA8PCA0XVxuICAgIHJlc3VsdCArPSAnPT0nXG4gIH1cbiAgaWYgKGkgPT09IGwpIHtcbiAgICAvLyAyIG9jdGV0cyB5ZXQgdG8gd3JpdGVcbiAgICByZXN1bHQgKz0gYmFzZTY0YWJjW3VpbnQ4W2kgLSAyXSA+PiAyXVxuICAgIHJlc3VsdCArPSBiYXNlNjRhYmNbKCh1aW50OFtpIC0gMl0gJiAweDAzKSA8PCA0KSB8ICh1aW50OFtpIC0gMV0gPj4gNCldXG4gICAgcmVzdWx0ICs9IGJhc2U2NGFiY1sodWludDhbaSAtIDFdICYgMHgwZikgPDwgMl1cbiAgICByZXN1bHQgKz0gJz0nXG4gIH1cbiAgcmV0dXJuIHJlc3VsdFxufVxuXG4vKipcbiAqIENSRURJVDogaHR0cHM6Ly9naXN0LmdpdGh1Yi5jb20vZW5lcG9tbnlhc2NoaWgvNzJjNDIzZjcyN2QzOTVlZWFhMDk2OTcwNTgyMzg3MjdcbiAqIERlY29kZXMgUkZDNDY0OCBiYXNlNjQgc3RyaW5nIGludG8gYW4gVWludDhBcnJheVxuICogQHBhcmFtIGRhdGFcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGRlY29kZShkYXRhOiBzdHJpbmcpOiBVaW50OEFycmF5IHtcbiAgaWYgKGRhdGEubGVuZ3RoICUgNCAhPT0gMCkge1xuICAgIHRocm93IG5ldyBFcnJvcignVW5hYmxlIHRvIHBhcnNlIGJhc2U2NCBzdHJpbmcuJylcbiAgfVxuICBjb25zdCBpbmRleCA9IGRhdGEuaW5kZXhPZignPScpXG4gIGlmIChpbmRleCAhPT0gLTEgJiYgaW5kZXggPCBkYXRhLmxlbmd0aCAtIDIpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1VuYWJsZSB0byBwYXJzZSBiYXNlNjQgc3RyaW5nLicpXG4gIH1cbiAgY29uc3QgbWlzc2luZ09jdGV0cyA9IGRhdGEuZW5kc1dpdGgoJz09JykgPyAyIDogZGF0YS5lbmRzV2l0aCgnPScpID8gMSA6IDBcbiAgY29uc3QgbiA9IGRhdGEubGVuZ3RoXG4gIGNvbnN0IHJlc3VsdCA9IG5ldyBVaW50OEFycmF5KDMgKiAobiAvIDQpKVxuICBsZXQgYnVmZmVyXG4gIGZvciAobGV0IGkgPSAwLCBqID0gMDsgaSA8IG47IGkgKz0gNCwgaiArPSAzKSB7XG4gICAgYnVmZmVyID1cbiAgICAgIChnZXRCYXNlNjRDb2RlKGRhdGEuY2hhckNvZGVBdChpKSkgPDwgMTgpIHxcbiAgICAgIChnZXRCYXNlNjRDb2RlKGRhdGEuY2hhckNvZGVBdChpICsgMSkpIDw8IDEyKSB8XG4gICAgICAoZ2V0QmFzZTY0Q29kZShkYXRhLmNoYXJDb2RlQXQoaSArIDIpKSA8PCA2KSB8XG4gICAgICBnZXRCYXNlNjRDb2RlKGRhdGEuY2hhckNvZGVBdChpICsgMykpXG4gICAgcmVzdWx0W2pdID0gYnVmZmVyID4+IDE2XG4gICAgcmVzdWx0W2ogKyAxXSA9IChidWZmZXIgPj4gOCkgJiAweGZmXG4gICAgcmVzdWx0W2ogKyAyXSA9IGJ1ZmZlciAmIDB4ZmZcbiAgfVxuICByZXR1cm4gcmVzdWx0LnN1YmFycmF5KDAsIHJlc3VsdC5sZW5ndGggLSBtaXNzaW5nT2N0ZXRzKVxufVxuXG4vKipcbiAqIENSRURJVDogaHR0cHM6Ly9naXN0LmdpdGh1Yi5jb20vZW5lcG9tbnlhc2NoaWgvNzJjNDIzZjcyN2QzOTVlZWFhMDk2OTcwNTgyMzg3MjdcbiAqIEBwYXJhbSBjaGFyQ29kZVxuICovXG5mdW5jdGlvbiBnZXRCYXNlNjRDb2RlKGNoYXJDb2RlOiBudW1iZXIpOiBudW1iZXIge1xuICBpZiAoY2hhckNvZGUgPj0gYmFzZTY0Y29kZXMubGVuZ3RoKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdVbmFibGUgdG8gcGFyc2UgYmFzZTY0IHN0cmluZy4nKVxuICB9XG4gIGNvbnN0IGNvZGUgPSBiYXNlNjRjb2Rlc1tjaGFyQ29kZV1cbiAgaWYgKGNvZGUgPT09IDI1NSkge1xuICAgIHRocm93IG5ldyBFcnJvcignVW5hYmxlIHRvIHBhcnNlIGJhc2U2NCBzdHJpbmcuJylcbiAgfVxuICByZXR1cm4gY29kZVxufVxuXG4vLyBDb3B5cmlnaHQgMjAxOC0yMDIxIHRoZSBEZW5vIGF1dGhvcnMuIEFsbCByaWdodHMgcmVzZXJ2ZWQuIE1JVCBsaWNlbnNlLlxuY29uc3QgYmFzZTY0YWJjID0gW1xuICAnQScsXG4gICdCJyxcbiAgJ0MnLFxuICAnRCcsXG4gICdFJyxcbiAgJ0YnLFxuICAnRycsXG4gICdIJyxcbiAgJ0knLFxuICAnSicsXG4gICdLJyxcbiAgJ0wnLFxuICAnTScsXG4gICdOJyxcbiAgJ08nLFxuICAnUCcsXG4gICdRJyxcbiAgJ1InLFxuICAnUycsXG4gICdUJyxcbiAgJ1UnLFxuICAnVicsXG4gICdXJyxcbiAgJ1gnLFxuICAnWScsXG4gICdaJyxcbiAgJ2EnLFxuICAnYicsXG4gICdjJyxcbiAgJ2QnLFxuICAnZScsXG4gICdmJyxcbiAgJ2cnLFxuICAnaCcsXG4gICdpJyxcbiAgJ2onLFxuICAnaycsXG4gICdsJyxcbiAgJ20nLFxuICAnbicsXG4gICdvJyxcbiAgJ3AnLFxuICAncScsXG4gICdyJyxcbiAgJ3MnLFxuICAndCcsXG4gICd1JyxcbiAgJ3YnLFxuICAndycsXG4gICd4JyxcbiAgJ3knLFxuICAneicsXG4gICcwJyxcbiAgJzEnLFxuICAnMicsXG4gICczJyxcbiAgJzQnLFxuICAnNScsXG4gICc2JyxcbiAgJzcnLFxuICAnOCcsXG4gICc5JyxcbiAgJysnLFxuICAnLycsXG5dXG5cbi8vIENSRURJVDogaHR0cHM6Ly9naXN0LmdpdGh1Yi5jb20vZW5lcG9tbnlhc2NoaWgvNzJjNDIzZjcyN2QzOTVlZWFhMDk2OTcwNTgyMzg3MjdcbmNvbnN0IGJhc2U2NGNvZGVzID0gW1xuICAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSxcbiAgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDYyLCAyNTUsIDI1NSwgMjU1LCA2MywgNTIsIDUzLCA1NCwgNTUsIDU2LCA1NywgNTgsIDU5LCA2MCwgNjEsIDI1NSwgMjU1LCAyNTUsXG4gIDAsIDI1NSwgMjU1LCAyNTUsIDAsIDEsIDIsIDMsIDQsIDUsIDYsIDcsIDgsIDksIDEwLCAxMSwgMTIsIDEzLCAxNCwgMTUsIDE2LCAxNywgMTgsIDE5LCAyMCwgMjEsIDIyLCAyMywgMjQsIDI1LCAyNTUsIDI1NSwgMjU1LCAyNTUsIDI1NSwgMjU1LCAyNixcbiAgMjcsIDI4LCAyOSwgMzAsIDMxLCAzMiwgMzMsIDM0LCAzNSwgMzYsIDM3LCAzOCwgMzksIDQwLCA0MSwgNDIsIDQzLCA0NCwgNDUsIDQ2LCA0NywgNDgsIDQ5LCA1MCwgNTEsXG5dXG4iXSwibmFtZXMiOlsiZGVjb2RlIiwiZW5jb2RlIiwiZGF0YSIsInVpbnQ4IiwiVGV4dEVuY29kZXIiLCJVaW50OEFycmF5IiwicmVzdWx0IiwiaSIsImwiLCJsZW5ndGgiLCJiYXNlNjRhYmMiLCJFcnJvciIsImluZGV4IiwiaW5kZXhPZiIsIm1pc3NpbmdPY3RldHMiLCJlbmRzV2l0aCIsIm4iLCJidWZmZXIiLCJqIiwiZ2V0QmFzZTY0Q29kZSIsImNoYXJDb2RlQXQiLCJzdWJhcnJheSIsImNoYXJDb2RlIiwiYmFzZTY0Y29kZXMiLCJjb2RlIl0sIm1hcHBpbmdzIjoiQUFBQTs7OztDQUlDOzs7Ozs7Ozs7OztJQWlDZUEsTUFBTTtlQUFOQTs7SUFoQ0FDLE1BQU07ZUFBTkE7OztBQUFULFNBQVNBLE9BQU9DLElBQTBCO0lBQy9DLE1BQU1DLFFBQVEsT0FBT0QsU0FBUyxXQUFXLElBQUlFLGNBQWNILE1BQU0sQ0FBQ0MsUUFBUUEsZ0JBQWdCRyxhQUFhSCxPQUFPLElBQUlHLFdBQVdIO0lBQzdILElBQUlJLFNBQVM7SUFDYixJQUFJQztJQUNKLE1BQU1DLElBQUlMLE1BQU1NLE1BQU07SUFDdEIsSUFBS0YsSUFBSSxHQUFHQSxJQUFJ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Q2xCO0lBQ0EsT0FBT2E7QUFDVDtBQUVBLDBFQUEwRTtBQUMxRSxNQUFNZCxZQUFZO0lBQ2hCO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0NBQ0Q7QUFFRCxrRkFBa0Y7QUFDbEYsTUFBTWEsY0FBYztJQUNsQjtJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQzVJO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFJO0lBQUs7SUFBSztJQUFLO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFLO0lBQUs7SUFDL0k7SUFBRztJQUFLO0lBQUs7SUFBSztJQUFHO0lBQUc7SUFBRztJQUFHO0lBQUc7SUFBRztJQUFHO0lBQUc7SUFBRztJQUFHO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSztJQUFLO0lBQUs7SUFBSztJQUFLO0lBQUs7SUFDOUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7SUFBSTtJQUFJO0lBQUk7Q0FDakcifQ==
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "LeakyBucket", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return LeakyBucket;
9
+ }
10
+ });
11
+ const _logger = /*#__PURE__*/ _interop_require_default(require("./logger.cjs"));
12
+ const _utils = require("./utils.cjs");
13
+ function _interop_require_default(obj) {
14
+ return obj && obj.__esModule ? obj : {
15
+ default: obj
16
+ };
17
+ }
18
+ let LeakyBucket = class LeakyBucket {
19
+ constructor(options){
20
+ /** The amount of requests that have been used up already. */ this.used = 0;
21
+ /** The queue of requests to acquire an available request. Mapped by <shardId, resolve()> */ this.queue = [];
22
+ /** Whether or not the queue is already processing. */ this.processing = false;
23
+ this.max = options?.max ?? 1;
24
+ this.refillAmount = options?.refillAmount ? options.refillAmount > this.max ? this.max : options.refillAmount : 1;
25
+ this.refillInterval = options?.refillInterval ?? 5000;
26
+ this.logger = options?.logger ?? _logger.default;
27
+ }
28
+ /** The amount of requests that still remain. */ get remaining() {
29
+ return this.max < this.used ? 0 : this.max - this.used;
30
+ }
31
+ /** Refills the bucket as needed. */ refillBucket() {
32
+ this.logger.debug(`[LeakyBucket] Timeout for leaky bucket requests executed. Refilling bucket.`);
33
+ // Lower the used amount by the refill amount
34
+ this.used = this.refillAmount > this.used ? 0 : this.used - this.refillAmount;
35
+ // Reset the refillsAt timestamp since it just got refilled
36
+ this.refillsAt = undefined;
37
+ // Reset the timeoutId
38
+ clearTimeout(this.timeoutId);
39
+ this.timeoutId = undefined;
40
+ if (this.used > 0) {
41
+ this.timeoutId = setTimeout(()=>{
42
+ this.refillBucket();
43
+ }, this.refillInterval);
44
+ this.refillsAt = Date.now() + this.refillInterval;
45
+ }
46
+ }
47
+ /** Begin processing the queue. */ async processQueue() {
48
+ this.logger.debug('[LeakyBucket] Processing queue');
49
+ // There is already a queue that is processing
50
+ if (this.processing) return this.logger.debug('[LeakyBucket] Queue is already processing.');
51
+ this.processing = true;
52
+ // Begin going through the queue.
53
+ while(this.queue.length){
54
+ if (this.remaining) {
55
+ this.logger.debug(`[LeakyBucket] Processing queue. Remaining: ${this.remaining} Length: ${this.queue.length}`);
56
+ // Resolves the promise allowing the paused execution of this request to resolve and continue.
57
+ this.queue.shift()?.();
58
+ // A request can be made
59
+ this.used++;
60
+ // Create a new timeout for this request if none exists.
61
+ if (!this.timeoutId) {
62
+ this.logger.debug(`[LeakyBucket] Creating new timeout for leaky bucket requests.`);
63
+ this.timeoutId = setTimeout(()=>{
64
+ this.refillBucket();
65
+ }, this.refillInterval);
66
+ // Set the time for when this refill will occur.
67
+ this.refillsAt = Date.now() + this.refillInterval;
68
+ }
69
+ } else if (this.refillsAt) {
70
+ const now = Date.now();
71
+ // If there is time left until next refill, just delay execution.
72
+ if (this.refillsAt > now) {
73
+ this.logger.debug(`[LeakyBucket] Delaying execution of leaky bucket requests for ${this.refillsAt - now}ms`);
74
+ await (0, _utils.delay)(this.refillsAt - now);
75
+ this.logger.debug(`[LeakyBucket] Resuming execution`);
76
+ } else {
77
+ this.logger.debug(`[LeakyBucket] Delaying execution of leaky bucket requests for 1000ms`);
78
+ await (0, _utils.delay)(1000);
79
+ }
80
+ }
81
+ }
82
+ // Loop has ended mark false so it can restart later when needed
83
+ this.processing = false;
84
+ }
85
+ /** Pauses the execution until the request is available to be made. */ async acquire(highPriority) {
86
+ return await new Promise((resolve)=>{
87
+ // High priority requests get added to the start of the queue
88
+ if (highPriority) this.queue.unshift(resolve);
89
+ else this.queue.push(resolve);
90
+ // Each request should trigger the queue to be processed.
91
+ void this.processQueue();
92
+ });
93
+ }
94
+ };
95
+
96
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9idWNrZXQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGxvZ2dlciBmcm9tICcuL2xvZ2dlci5qcydcbmltcG9ydCB7IGRlbGF5IH0gZnJvbSAnLi91dGlscy5qcydcblxuZXhwb3J0IGNsYXNzIExlYWt5QnVja2V0IGltcGxlbWVudHMgTGVha3lCdWNrZXRPcHRpb25zIHtcbiAgbWF4OiBudW1iZXJcbiAgcmVmaWxsSW50ZXJ2YWw6IG51bWJlclxuICByZWZpbGxBbW91bnQ6IG51bWJlclxuXG4gIC8qKiBUaGUgYW1vdW50IG9mIHJlcXVlc3RzIHRoYXQgaGF2ZSBiZWVuIHVzZWQgdXAgYWxyZWFkeS4gKi9cbiAgdXNlZDogbnVtYmVyID0gMFxuICAvKiogVGhlIHF1ZXVlIG9mIHJlcXVlc3RzIHRvIGFjcXVpcmUgYW4gYXZhaWxhYmxlIHJlcXVlc3QuIE1hcHBlZCBieSA8c2hhcmRJZCwgcmVzb2x2ZSgpPiAqL1xuICBxdWV1ZTogQXJyYXk8KHZhbHVlOiB2b2lkIHwgUHJvbWlzZUxpa2U8dm9pZD4pID0+IHZvaWQ+ID0gW11cbiAgLyoqIFdoZXRoZXIgb3Igbm90IHRoZSBxdWV1ZSBpcyBhbHJlYWR5IHByb2Nlc3NpbmcuICovXG4gIHByb2Nlc3Npbmc6IGJvb2xlYW4gPSBmYWxzZVxuICAvKiogVGhlIHRpbWVvdXQgaWQgZm9yIHRoZSB0aW1lciB0byByZWR1Y2UgdGhlIHVzZWQgYW1vdW50IGJ5IHRoZSByZWZpbGwgYW1vdW50LiAqL1xuICB0aW1lb3V0SWQ/OiBOb2RlSlMuVGltZW91dFxuICAvKiogVGhlIHRpbWVzdGFtcCBpbiBtaWxsaXNlY29uZHMgd2hlbiB0aGUgbmV4dCByZWZpbGwgaXMgc2NoZWR1bGVkLiAqL1xuICByZWZpbGxzQXQ/OiBudW1iZXJcbiAgLyoqIExvZ2dlciB1c2VkIGluIHRoZSBsZWFreSBidWNrZXQgKi9cbiAgbG9nZ2VyOiBQaWNrPHR5cGVvZiBsb2dnZXIsICdkZWJ1ZycgfCAnaW5mbycgfCAnd2FybicgfCAnZXJyb3InIHwgJ2ZhdGFsJz5cblxuICBjb25zdHJ1Y3RvcihvcHRpb25zPzogTGVha3lCdWNrZXRPcHRpb25zKSB7XG4gICAgdGhpcy5tYXggPSBvcHRpb25zPy5tYXggPz8gMVxuICAgIHRoaXMucmVmaWxsQW1vdW50ID0gb3B0aW9ucz8ucmVmaWxsQW1vdW50ID8gKG9wdGlvbnMucmVmaWxsQW1vdW50ID4gdGhpcy5tYXggPyB0aGlzLm1heCA6IG9wdGlvbnMucmVmaWxsQW1vdW50KSA6IDFcbiAgICB0aGlzLnJlZmlsbEludGVydmFsID0gb3B0aW9ucz8ucmVmaWxsSW50ZXJ2YWwgPz8gNTAwMFxuICAgIHRoaXMubG9nZ2VyID0gb3B0aW9ucz8ubG9nZ2VyID8/IGxvZ2dlclxuICB9XG5cbiAgLyoqIFRoZSBhbW91bnQgb2YgcmVxdWVzdHMgdGhhdCBzdGlsbCByZW1haW4uICovXG4gIGdldCByZW1haW5pbmcoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy5tYXggPCB0aGlzLnVzZWQgPyAwIDogdGhpcy5tYXggLSB0aGlzLnVzZWRcbiAgfVxuXG4gIC8qKiBSZWZpbGxzIHRoZSBidWNrZXQgYXMgbmVlZGVkLiAqL1xuICByZWZpbGxCdWNrZXQoKTogdm9pZCB7XG4gICAgdGhpcy5sb2dnZXIuZGVidWcoYFtMZWFreUJ1Y2tldF0gVGltZW91dCBmb3IgbGVha3kgYnVja2V0IHJlcXVlc3RzIGV4ZWN1dGVkLiBSZWZpbGxpbmcgYnVja2V0LmApXG4gICAgLy8gTG93ZXIgdGhlIHVzZWQgYW1vdW50IGJ5IHRoZSByZWZpbGwgYW1vdW50XG4gICAgdGhpcy51c2VkID0gdGhpcy5yZWZpbGxBbW91bnQgPiB0aGlzLnVzZWQgPyAwIDogdGhpcy51c2VkIC0gdGhpcy5yZWZpbGxBbW91bnRcbiAgICAvLyBSZXNldCB0aGUgcmVmaWxsc0F0IHRpbWVzdGFtcCBzaW5jZSBpdCBqdXN0IGdvdCByZWZpbGxlZFxuICAgIHRoaXMucmVmaWxsc0F0ID0gdW5kZWZpbmVkXG4gICAgLy8gUmVzZXQgdGhlIHRpbWVvdXRJZFxuICAgIGNsZWFyVGltZW91dCh0aGlzLnRpbWVvdXRJZClcbiAgICB0aGlzLnRpbWVvdXRJZCA9IHVuZGVmaW5lZFxuXG4gICAgaWYgKHRoaXMudXNlZCA+IDApIHtcbiAgICAgIHRoaXMudGltZW91dElkID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgIHRoaXMucmVmaWxsQnVja2V0KClcbiAgICAgIH0sIHRoaXMucmVmaWxsSW50ZXJ2YWwpXG4gICAgICB0aGlzLnJlZmlsbHNBdCA9IERhdGUubm93KCkgKyB0aGlzLnJlZmlsbEludGVydmFsXG4gICAgfVxuICB9XG5cbiAgLyoqIEJlZ2luIHByb2Nlc3NpbmcgdGhlIHF1ZXVlLiAqL1xuICBhc3luYyBwcm9jZXNzUXVldWUoKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgdGhpcy5sb2dnZXIuZGVidWcoJ1tMZWFreUJ1Y2tldF0gUHJvY2Vzc2luZyBxdWV1ZScpXG5cbiAgICAvLyBUaGVyZSBpcyBhbHJlYWR5IGEgcXVldWUgdGhhdCBpcyBwcm9jZXNzaW5nXG4gICAgaWYgKHRoaXMucHJvY2Vzc2luZykgcmV0dXJuIHRoaXMubG9nZ2VyLmRlYnVnKCdbTGVha3lCdWNrZXRdIFF1ZXVlIGlzIGFscmVhZHkgcHJvY2Vzc2luZy4nKVxuXG4gICAgdGhpcy5wcm9jZXNzaW5nID0gdHJ1ZVxuXG4gICAgLy8gQmVnaW4gZ29pbmcgdGhyb3VnaCB0aGUgcXVldWUuXG4gICAgd2hpbGUgKHRoaXMucXVldWUubGVuZ3RoKSB7XG4gICAgICBpZiAodGhpcy5yZW1haW5pbmcpIHtcbiAgICAgICAgdGhpcy5sb2dnZXIuZGVidWcoYFtMZWFreUJ1Y2tldF0gUHJvY2Vzc2luZyBxdWV1ZS4gUmVtYWluaW5nOiAke3RoaXMucmVtYWluaW5nfSBMZW5ndGg6ICR7dGhpcy5xdWV1ZS5sZW5ndGh9YClcbiAgICAgICAgLy8gUmVzb2x2ZXMgdGhlIHByb21pc2UgYWxsb3dpbmcgdGhlIHBhdXNlZCBleGVjdXRpb24gb2YgdGhpcyByZXF1ZXN0IHRvIHJlc29sdmUgYW5kIGNvbnRpbnVlLlxuICAgICAgICB0aGlzLnF1ZXVlLnNoaWZ0KCk/LigpXG4gICAgICAgIC8vIEEgcmVxdWVzdCBjYW4gYmUgbWFkZVxuICAgICAgICB0aGlzLnVzZWQrK1xuXG4gICAgICAgIC8vIENyZWF0ZSBhIG5ldyB0aW1lb3V0IGZvciB0aGlzIHJlcXVlc3QgaWYgbm9uZSBleGlzdHMuXG4gICAgICAgIGlmICghdGhpcy50aW1lb3V0SWQpIHtcbiAgICAgICAgICB0aGlzLmxvZ2dlci5kZWJ1ZyhgW0xlYWt5QnVja2V0XSBDcmVhdGluZyBuZXcgdGltZW91dCBmb3IgbGVha3kgYnVja2V0IHJlcXVlc3RzLmApXG5cbiAgICAgICAgICB0aGlzLnRpbWVvdXRJZCA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICAgICAgdGhpcy5yZWZpbGxCdWNrZXQoKVxuICAgICAgICAgIH0sIHRoaXMucmVmaWxsSW50ZXJ2YWwpXG4gICAgICAgICAgLy8gU2V0IHRoZSB0aW1lIGZvciB3aGVuIHRoaXMgcmVmaWxsIHdpbGwgb2NjdXIuXG4gICAgICAgICAgdGhpcy5yZWZpbGxzQXQgPSBEYXRlLm5vdygpICsgdGhpcy5yZWZpbGxJbnRlcnZhbFxuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIC8vIENoZWNrIGlmIGEgcmVmaWxsIGlzIHNjaGVkdWxlZCwgc2luY2Ugd2UgaGF2ZSB1c2VkIHVwIGFsbCBhdmFpbGFibGUgcmVxdWVzdHNcbiAgICAgIGVsc2UgaWYgKHRoaXMucmVmaWxsc0F0KSB7XG4gICAgICAgIGNvbnN0IG5vdyA9IERhdGUubm93KClcbiAgICAgICAgLy8gSWYgdGhlcmUgaXMgdGltZSBsZWZ0IHVudGlsIG5leHQgcmVmaWxsLCBqdXN0IGRlbGF5IGV4ZWN1dGlvbi5cbiAgICAgICAgaWYgKHRoaXMucmVmaWxsc0F0ID4gbm93KSB7XG4gICAgICAgICAgdGhpcy5sb2dnZXIuZGVidWcoYFtMZWFreUJ1Y2tldF0gRGVsYXlpbmcgZXhlY3V0aW9uIG9mIGxlYWt5IGJ1Y2tldCByZXF1ZXN0cyBmb3IgJHt0aGlzLnJlZmlsbHNBdCAtIG5vd31tc2ApXG4gICAgICAgICAgYXdhaXQgZGVsYXkodGhpcy5yZWZpbGxzQXQgLSBub3cpXG4gICAgICAgICAgdGhpcy5sb2dnZXIuZGVidWcoYFtMZWFreUJ1Y2tldF0gUmVzdW1pbmcgZXhlY3V0aW9uYClcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIElmIHRoZSByZWZpbGxzQXQgaGFzIHBhc3NlZCBidXQgdGhlIHRpbWVvdXQgZGlkbid0IHlldCBleGVjdXRlIGRlbGF5IHRoZSBleGVjdXRpb25cbiAgICAgICAgZWxzZSB7XG4gICAgICAgICAgdGhpcy5sb2dnZXIuZGVidWcoYFtMZWFreUJ1Y2tldF0gRGVsYXlpbmcgZXhlY3V0aW9uIG9mIGxlYWt5IGJ1Y2tldCByZXF1ZXN0cyBmb3IgMTAwMG1zYClcbiAgICAgICAgICBhd2FpdCBkZWxheSgxMDAwKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgLy8gTG9vcCBoYXMgZW5kZWQgbWFyayBmYWxzZSBzbyBpdCBjYW4gcmVzdGFydCBsYXRlciB3aGVuIG5lZWRlZFxuICAgIHRoaXMucHJvY2Vzc2luZyA9IGZhbHNlXG4gIH1cblxuICAvKiogUGF1c2VzIHRoZSBleGVjdXRpb24gdW50aWwgdGhlIHJlcXVlc3QgaXMgYXZhaWxhYmxlIHRvIGJlIG1hZGUuICovXG4gIGFzeW5jIGFjcXVpcmUoaGlnaFByaW9yaXR5PzogYm9vbGVhbik6IFByb21pc2U8dm9pZD4ge1xuICAgIHJldHVybiBhd2FpdCBuZXcgUHJvbWlzZSgocmVzb2x2ZSkgPT4ge1xuICAgICAgLy8gSGlnaCBwcmlvcml0eSByZXF1ZXN0cyBnZXQgYWRkZWQgdG8gdGhlIHN0YXJ0IG9mIHRoZSBxdWV1ZVxuICAgICAgaWYgKGhpZ2hQcmlvcml0eSkgdGhpcy5xdWV1ZS51bnNoaWZ0KHJlc29sdmUpXG4gICAgICAvLyBBbGwgb3RoZXIgcmVxdWVzdHMgZ2V0IHB1c2hlZCB0byB0aGUgZW5kLlxuICAgICAgZWxzZSB0aGlzLnF1ZXVlLnB1c2gocmVzb2x2ZSlcblxuICAgICAgLy8gRWFjaCByZXF1ZXN0IHNob3VsZCB0cmlnZ2VyIHRoZSBxdWV1ZSB0byBiZSBwcm9jZXNzZWQuXG4gICAgICB2b2lkIHRoaXMucHJvY2Vzc1F1ZXVlKClcbiAgICB9KVxuICB9XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGVha3lCdWNrZXRPcHRpb25zIHtcbiAgLyoqXG4gICAqIE1heCByZXF1ZXN0cyBhbGxvd2VkIGF0IG9uY2UuXG4gICAqIEBkZWZhdWx0IDFcbiAgICovXG4gIG1heD86IG51bWJlclxuICAvKipcbiAgICogSW50ZXJ2YWwgaW4gbWlsbGlzZWNvbmRzIGJldHdlZW4gcmVmaWxscy5cbiAgICogQGRlZmF1bHQgNTAwMFxuICAgKi9cbiAgcmVmaWxsSW50ZXJ2YWw/OiBudW1iZXJcbiAgLyoqXG4gICAqIEFtb3VudCBvZiByZXF1ZXN0cyB0byByZWZpbGwgYXQgZWFjaCBpbnRlcnZhbC5cbiAgICogQGRlZmF1bHQgMVxuICAgKi9cbiAgcmVmaWxsQW1vdW50PzogbnVtYmVyXG4gIC8qKlxuICAgKiBUaGUgbG9nZ2VyIHRoYXQgdGhlIGxlYWt5IGJ1Y2tldCB3aWxsIHVzZVxuICAgKiBAZGVmYXVsdCBsb2dnZXIgLy8gVGhlIGxvZ2dlciBleHBvcnRlZCBieSBgQGRpc2NvcmRlbm8vdXRpbHNgXG4gICAqL1xuICBsb2dnZXI/OiBQaWNrPHR5cGVvZiBsb2dnZXIsICdkZWJ1ZycgfCAnaW5mbycgfCAnd2FybicgfCAnZXJyb3InIHwgJ2ZhdGFsJz5cbn1cbiJdLCJuYW1lcyI6WyJMZWFreUJ1Y2tldCIsImNvbnN0cnVjdG9yIiwib3B0aW9ucyIsInVzZWQiLCJxdWV1ZSIsInByb2Nlc3NpbmciLCJtYXgiLCJyZWZpbGxBbW91bnQiLCJyZWZpbGxJbnRlcnZhbCIsImxvZ2dlciIsInJlbWFpbmluZyIsInJlZmlsbEJ1Y2tldCIsImRlYnVnIiwicmVmaWxsc0F0IiwidW5kZWZpbmVkIiwiY2xlYXJUaW1lb3V0IiwidGltZW91dElkIiwic2V0VGltZW91dCIsIkRhdGUiLCJub3ciLCJwcm9jZXNzUXVldWUiLCJsZW5ndGgiLCJzaGlmdCIsImRlbGF5IiwiYWNxdWlyZSIsImhpZ2hQcmlvcml0eSIsIlByb21pc2UiLCJyZXNvbHZlIiwidW5zaGlmdCIsInB1c2giXSwibWFwcGluZ3MiOiI7Ozs7K0JBR2FBOzs7ZUFBQUE7OzsrREFITTt1QkFDRzs7Ozs7O0FBRWYsSUFBQSxBQUFNQSxjQUFOLE1BQU1BO0lBa0JYQyxZQUFZQyxPQUE0QixDQUFFO1FBYjFDLDJEQUEyRCxRQUMzREMsT0FBZTtRQUNmLDBGQUEwRixRQUMxRkMsUUFBMEQsRUFBRTtRQUM1RCxvREFBb0QsUUFDcERDLGFBQXNCO1FBU3BCLElBQUksQ0FBQ0MsR0FBRyxHQUFHSixTQUFTSSxPQUFPO1FBQzNCLElBQUksQ0FBQ0MsWUFBWSxHQUFHTCxTQUFTSyxlQUFnQkwsUUFBUUssWUFBWSxHQUFHLElBQUksQ0FBQ0QsR0FBRyxHQUFHLElBQUksQ0FBQ0EsR0FBRyxHQUFHSixRQUFRSyxZQUFZLEdBQUk7UUFDbEgsSUFBSSxDQUFDQyxjQUFjLEdBQUdOLFNBQVNNLGtCQUFrQjtRQUNqRCxJQUFJLENBQUNDLE1BQU0sR0FBR1AsU0FBU08sVUFBVUEsZUFBTTtJQUN6QztJQUVBLDhDQUE4QyxHQUM5QyxJQUFJQyxZQUFvQjtRQUN0QixPQUFPLElBQUksQ0FBQ0osR0FBRyxHQUFHLElBQUksQ0FBQ0gsSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDRyxHQUFHLEdBQUcsSUFBSSxDQUFDSCxJQUFJO0lBQ3hEO0lBRUEsa0NBQWtDLEdBQ2xDUSxlQUFxQjtRQUNuQixJQUFJLENBQUNGLE1BQU0sQ0FBQ0csS0FBSyxDQUFDLENBQUMsMkVBQTJFLENBQUM7UUFDL0YsNkNBQTZDO1FBQzdDLElBQUksQ0FBQ1QsSUFBSSxHQUFHLElBQUksQ0FBQ0ksWUFBWSxHQUFHLElBQUksQ0FBQ0osSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDQSxJQUFJLEdB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