@discordeno/utils 19.0.0-next.fe00a6f → 19.0.0
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.
- package/README.md +6 -143
- package/dist/esm/Collection.js +112 -0
- package/dist/esm/base64.js +262 -0
- package/dist/esm/bucket.js +81 -0
- package/dist/esm/builders/embeds.js +290 -0
- package/dist/esm/builders.js +5 -0
- package/dist/esm/casing.js +55 -0
- package/dist/esm/colors.js +467 -0
- package/dist/esm/hash.js +19 -0
- package/dist/esm/images.js +179 -0
- package/dist/esm/index.js +19 -0
- package/dist/esm/logger.js +130 -0
- package/dist/esm/oauth2.js +16 -0
- package/dist/esm/permissions.js +17 -0
- package/dist/esm/reactions.js +11 -0
- package/dist/esm/token.js +20 -0
- package/dist/esm/typeguards.js +22 -0
- package/dist/esm/urlToBase64.js +9 -0
- package/dist/esm/urls.js +11 -0
- package/dist/esm/utils.js +12 -0
- package/dist/{Collection.d.ts → types/Collection.d.ts} +2 -3
- package/dist/types/Collection.d.ts.map +1 -0
- package/dist/types/base64.d.ts.map +1 -0
- package/dist/{bucket.d.ts → types/bucket.d.ts} +9 -2
- package/dist/types/bucket.d.ts.map +1 -0
- package/dist/types/builders/embeds.d.ts +142 -0
- package/dist/types/builders/embeds.d.ts.map +1 -0
- package/dist/types/builders.d.ts +4 -0
- package/dist/types/builders.d.ts.map +1 -0
- package/dist/types/casing.d.ts.map +1 -0
- package/dist/types/colors.d.ts.map +1 -0
- package/dist/types/hash.d.ts.map +1 -0
- package/dist/types/images.d.ts +202 -0
- package/dist/types/images.d.ts.map +1 -0
- package/dist/{index.d.ts → types/index.d.ts} +4 -1
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/logger.d.ts.map +1 -0
- package/dist/types/oauth2.d.ts +69 -0
- package/dist/types/oauth2.d.ts.map +1 -0
- package/dist/types/permissions.d.ts.map +1 -0
- package/dist/types/reactions.d.ts.map +1 -0
- package/dist/{token.d.ts → types/token.d.ts} +1 -1
- package/dist/types/token.d.ts.map +1 -0
- package/dist/types/typeguards.d.ts +8 -0
- package/dist/types/typeguards.d.ts.map +1 -0
- package/dist/types/urlToBase64.d.ts.map +1 -0
- package/dist/types/urls.d.ts +5 -0
- package/dist/types/urls.d.ts.map +1 -0
- package/dist/types/utils.d.ts.map +1 -0
- package/package.json +30 -26
- package/dist/Collection.d.ts.map +0 -1
- package/dist/Collection.js +0 -113
- package/dist/Collection.js.map +0 -1
- package/dist/base64.d.ts.map +0 -1
- package/dist/base64.js +0 -262
- package/dist/base64.js.map +0 -1
- package/dist/bucket.d.ts.map +0 -1
- package/dist/bucket.js +0 -74
- package/dist/bucket.js.map +0 -1
- package/dist/casing.d.ts.map +0 -1
- package/dist/casing.js +0 -51
- package/dist/casing.js.map +0 -1
- package/dist/colors.d.ts.map +0 -1
- package/dist/colors.js +0 -467
- package/dist/colors.js.map +0 -1
- package/dist/hash.d.ts.map +0 -1
- package/dist/hash.js +0 -19
- package/dist/hash.js.map +0 -1
- package/dist/images.d.ts +0 -68
- package/dist/images.d.ts.map +0 -1
- package/dist/images.js +0 -66
- package/dist/images.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -16
- package/dist/index.js.map +0 -1
- package/dist/interactions.d.ts +0 -3
- package/dist/interactions.d.ts.map +0 -1
- package/dist/interactions.js +0 -41
- package/dist/interactions.js.map +0 -1
- package/dist/logger.d.ts.map +0 -1
- package/dist/logger.js +0 -130
- package/dist/logger.js.map +0 -1
- package/dist/permissions.d.ts.map +0 -1
- package/dist/permissions.js +0 -17
- package/dist/permissions.js.map +0 -1
- package/dist/reactions.d.ts.map +0 -1
- package/dist/reactions.js +0 -11
- package/dist/reactions.js.map +0 -1
- package/dist/token.d.ts.map +0 -1
- package/dist/token.js +0 -16
- package/dist/token.js.map +0 -1
- package/dist/typeguards.d.ts +0 -6
- package/dist/typeguards.d.ts.map +0 -1
- package/dist/typeguards.js +0 -15
- package/dist/typeguards.js.map +0 -1
- package/dist/urlToBase64.d.ts.map +0 -1
- package/dist/urlToBase64.js +0 -9
- package/dist/urlToBase64.js.map +0 -1
- package/dist/utils.d.ts.map +0 -1
- package/dist/utils.js +0 -15
- package/dist/utils.js.map +0 -1
- /package/dist/{base64.d.ts → types/base64.d.ts} +0 -0
- /package/dist/{casing.d.ts → types/casing.d.ts} +0 -0
- /package/dist/{colors.d.ts → types/colors.d.ts} +0 -0
- /package/dist/{hash.d.ts → types/hash.d.ts} +0 -0
- /package/dist/{logger.d.ts → types/logger.d.ts} +0 -0
- /package/dist/{permissions.d.ts → types/permissions.d.ts} +0 -0
- /package/dist/{reactions.d.ts → types/reactions.d.ts} +0 -0
- /package/dist/{urlToBase64.d.ts → types/urlToBase64.d.ts} +0 -0
- /package/dist/{utils.d.ts → types/utils.d.ts} +0 -0
package/README.md
CHANGED
|
@@ -1,151 +1,14 @@
|
|
|
1
|
-
# Discordeno
|
|
1
|
+
# Discordeno Utils
|
|
2
2
|
|
|
3
|
-
<img align="right" src="https://raw.githubusercontent.com/discordeno/discordeno/main/
|
|
3
|
+
<img align="right" src="https://raw.githubusercontent.com/discordeno/discordeno/main/website/static/img/logo.png" height="150px" />
|
|
4
4
|
|
|
5
|
-
Discord API library for [Deno](https://deno.land)
|
|
6
|
-
|
|
7
|
-
Discordeno follows [semantic versioning](https://semver.org/)
|
|
5
|
+
Discord API library for [Node.JS](https://nodejs.org), [Deno](https://deno.land) & [Bun](https://bun.sh/)
|
|
8
6
|
|
|
9
7
|
[](https://discord.com/invite/5vBgXk3UcZ)
|
|
10
|
-

|
|
134
|
-
- [Serverless Slash Commands Template (official)](https://github.com/discordeno/serverless-deno-deploy-template)
|
|
135
|
-
- [`create-discordeno-bot` (WIP, unoffical)](https://github.com/Reboot-Codes/create-discordeno-bot/)
|
|
136
|
-
- [Add Your Own!](https://github.com/discordeno/discordeno/pulls)
|
|
137
|
-
|
|
138
|
-
**Frameworks**
|
|
139
|
-
|
|
140
|
-
- [Amethyst Framework](https://github.com/AmethystFramework/framework)
|
|
141
|
-
- [Add Your Own!](https://github.com/discordeno/discordeno/pulls)
|
|
142
|
-
|
|
143
|
-
**Plugins**
|
|
8
|
+
[](https://codecov.io/gh/discordeno/discordeno)
|
|
9
|
+

|
|
144
10
|
|
|
145
|
-
|
|
146
|
-
- [Fileloader Plugin](plugins/fileloader)
|
|
147
|
-
- [Helpers Plugin](plugins/helpers)
|
|
148
|
-
- [Permissions Plugin](plugins/permissions)
|
|
11
|
+
Utilities useful when using Discordeno.
|
|
149
12
|
|
|
150
13
|
## Links
|
|
151
14
|
|
|
@@ -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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
|