@discordeno/utils 19.0.0-next.e2d86ea → 19.0.0-next.e30e5a2
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/cjs/Collection.cjs +123 -0
- package/dist/cjs/base64.cjs +276 -0
- package/dist/cjs/bucket.cjs +96 -0
- package/dist/cjs/builders/embeds.cjs +292 -0
- package/dist/cjs/builders.cjs +27 -0
- package/dist/cjs/casing.cjs +75 -0
- package/dist/cjs/colors.cjs +456 -0
- package/dist/cjs/hash.cjs +37 -0
- package/dist/cjs/images.cjs +136 -0
- package/dist/cjs/index.cjs +36 -0
- package/dist/cjs/logger.cjs +157 -0
- package/dist/cjs/oauth2.cjs +26 -0
- package/dist/cjs/permissions.cjs +35 -0
- package/dist/cjs/reactions.cjs +21 -0
- package/dist/cjs/token.cjs +39 -0
- package/dist/cjs/typeguards.cjs +45 -0
- package/dist/cjs/urlToBase64.cjs +19 -0
- package/dist/cjs/urls.cjs +26 -0
- package/dist/cjs/utils.cjs +30 -0
- package/dist/esm/Collection.js +113 -0
- package/dist/esm/base64.js +262 -0
- package/dist/esm/bucket.js +81 -0
- package/dist/esm/builders/embeds.js +295 -0
- package/dist/esm/builders.js +5 -0
- package/dist/esm/casing.js +51 -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 +21 -0
- package/dist/esm/typeguards.js +18 -0
- package/dist/esm/urlToBase64.js +9 -0
- package/dist/esm/urls.js +8 -0
- package/dist/esm/utils.js +15 -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 +146 -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/{typeguards.d.ts → types/typeguards.d.ts} +2 -1
- package/dist/types/typeguards.d.ts.map +1 -0
- package/dist/types/urlToBase64.d.ts.map +1 -0
- package/dist/types/urls.d.ts +4 -0
- package/dist/types/urls.d.ts.map +1 -0
- package/dist/types/utils.d.ts.map +1 -0
- package/package.json +27 -22
- 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.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
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/** Pause the execution for a given amount of milliseconds. */ "use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
function _export(target, all) {
|
|
6
|
+
for(var name in all)Object.defineProperty(target, name, {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: all[name]
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
_export(exports, {
|
|
12
|
+
delay: function() {
|
|
13
|
+
return delay;
|
|
14
|
+
},
|
|
15
|
+
hasProperty: function() {
|
|
16
|
+
return hasProperty;
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
async function delay(ms) {
|
|
20
|
+
// eslint-disable-next-line @typescript-eslint/return-await
|
|
21
|
+
return new Promise((resolve)=>setTimeout(()=>{
|
|
22
|
+
resolve();
|
|
23
|
+
}, ms));
|
|
24
|
+
}
|
|
25
|
+
function hasProperty(obj, prop) {
|
|
26
|
+
// eslint-disable-next-line no-prototype-builtins
|
|
27
|
+
return obj.hasOwnProperty(prop);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogUGF1c2UgdGhlIGV4ZWN1dGlvbiBmb3IgYSBnaXZlbiBhbW91bnQgb2YgbWlsbGlzZWNvbmRzLiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGRlbGF5KG1zOiBudW1iZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9yZXR1cm4tYXdhaXRcbiAgcmV0dXJuIG5ldyBQcm9taXNlKFxuICAgIChyZXNvbHZlKTogTm9kZUpTLlRpbWVvdXQgPT5cbiAgICAgIHNldFRpbWVvdXQoKCk6IHZvaWQgPT4ge1xuICAgICAgICByZXNvbHZlKClcbiAgICAgIH0sIG1zKSxcbiAgKVxufVxuXG4vLyBUeXBlc2NyaXB0IGlzIG5vdCBzbyBnb29kIGFzIHdlIGRldmVsb3BlcnMgc28gd2UgbmVlZCB0aGlzIGxpdHRsZSB1dGlsaXR5IGZ1bmN0aW9uIHRvIGhlbHAgaXQgb3V0XG4vLyBUYWtlbiBmcm9tIGh0dHBzOi8vZmV0dGJsb2cuZXUvdHlwZXNjcmlwdC1oYXNvd25wcm9wZXJ0eS9cbi8qKiBUUyBzYXZlIHdheSB0byBjaGVjayBpZiBhIHByb3BlcnR5IGV4aXN0cyBpbiBhbiBvYmplY3QgKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXR5cGVzXG5leHBvcnQgZnVuY3Rpb24gaGFzUHJvcGVydHk8VCBleHRlbmRzIHt9LCBZIGV4dGVuZHMgUHJvcGVydHlLZXkgPSBzdHJpbmc+KG9iajogVCwgcHJvcDogWSk6IG9iaiBpcyBUICYgUmVjb3JkPFksIHVua25vd24+IHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXByb3RvdHlwZS1idWlsdGluc1xuICByZXR1cm4gb2JqLmhhc093blByb3BlcnR5KHByb3ApXG59XG4iXSwibmFtZXMiOlsiZGVsYXkiLCJoYXNQcm9wZXJ0eSIsIm1zIiwiUHJvbWlzZSIsInJlc29sdmUiLCJzZXRUaW1lb3V0Iiwib2JqIiwicHJvcCIsImhhc093blByb3BlcnR5Il0sIm1hcHBpbmdzIjoiQUFBQSw0REFBNEQ7Ozs7Ozs7Ozs7O0lBQ3RDQSxLQUFLO2VBQUxBOztJQWNOQyxXQUFXO2VBQVhBOzs7QUFkVCxlQUFlRCxNQUFNRSxFQUFVO0lBQ3BDLDJEQUEyRDtJQUMzRCxPQUFPLElBQUlDLFFBQ1QsQ0FBQ0MsVUFDQ0MsV0FBVztZQUNURDtRQUNGLEdBQUdGO0FBRVQ7QUFNTyxTQUFTRCxZQUEwREssR0FBTSxFQUFFQyxJQUFPO0lBQ3ZGLGlEQUFpRDtJQUNqRCxPQUFPRCxJQUFJRSxjQUFjLENBQUNEO0FBQzVCIn0=
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-interface
|
|
2
|
+
export class Collection extends Map {
|
|
3
|
+
constructor(entries, options){
|
|
4
|
+
super(entries ?? []);
|
|
5
|
+
this.maxSize = options?.maxSize;
|
|
6
|
+
if (!options?.sweeper) return;
|
|
7
|
+
this.startSweeper(options.sweeper);
|
|
8
|
+
}
|
|
9
|
+
startSweeper(options) {
|
|
10
|
+
if (this.sweeper?.intervalId) clearInterval(this.sweeper.intervalId);
|
|
11
|
+
this.sweeper = options;
|
|
12
|
+
this.sweeper.intervalId = setInterval(()=>{
|
|
13
|
+
this.forEach((value, key)=>{
|
|
14
|
+
if (!this.sweeper?.filter(value, key, options.bot)) return;
|
|
15
|
+
this.delete(key);
|
|
16
|
+
return key;
|
|
17
|
+
});
|
|
18
|
+
}, options.interval);
|
|
19
|
+
return this.sweeper.intervalId;
|
|
20
|
+
}
|
|
21
|
+
stopSweeper() {
|
|
22
|
+
return clearInterval(this.sweeper?.intervalId);
|
|
23
|
+
}
|
|
24
|
+
changeSweeperInterval(newInterval) {
|
|
25
|
+
if (this.sweeper == null) return;
|
|
26
|
+
this.startSweeper({
|
|
27
|
+
filter: this.sweeper.filter,
|
|
28
|
+
interval: newInterval
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
changeSweeperFilter(newFilter) {
|
|
32
|
+
if (this.sweeper == null) return;
|
|
33
|
+
this.startSweeper({
|
|
34
|
+
filter: newFilter,
|
|
35
|
+
interval: this.sweeper.interval
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
/** Add an item to the collection. Makes sure not to go above the maxSize. */ set(key, value) {
|
|
39
|
+
// When this collection is maxSized make sure we can add first
|
|
40
|
+
if ((this.maxSize !== undefined || this.maxSize === 0) && this.size >= this.maxSize) {
|
|
41
|
+
return this;
|
|
42
|
+
}
|
|
43
|
+
return super.set(key, value);
|
|
44
|
+
}
|
|
45
|
+
/** Add an item to the collection, no matter what the maxSize is. */ forceSet(key, value) {
|
|
46
|
+
return super.set(key, value);
|
|
47
|
+
}
|
|
48
|
+
/** Convert the collection to an array. */ array() {
|
|
49
|
+
return [
|
|
50
|
+
...this.values()
|
|
51
|
+
];
|
|
52
|
+
}
|
|
53
|
+
/** Retrieve the value of the first element in this collection. */ first() {
|
|
54
|
+
return this.values().next().value;
|
|
55
|
+
}
|
|
56
|
+
/** Retrieve the value of the last element in this collection. */ last() {
|
|
57
|
+
return [
|
|
58
|
+
...this.values()
|
|
59
|
+
][this.size - 1];
|
|
60
|
+
}
|
|
61
|
+
/** Retrieve the value of a random element in this collection. */ random() {
|
|
62
|
+
const array = [
|
|
63
|
+
...this.values()
|
|
64
|
+
];
|
|
65
|
+
return array[Math.floor(Math.random() * array.length)];
|
|
66
|
+
}
|
|
67
|
+
/** Find a specific element in this collection. */ find(callback) {
|
|
68
|
+
for (const key of this.keys()){
|
|
69
|
+
const value = this.get(key);
|
|
70
|
+
if (callback(value, key)) return value;
|
|
71
|
+
}
|
|
72
|
+
// If nothing matched
|
|
73
|
+
}
|
|
74
|
+
/** Find all elements in this collection that match the given pattern. */ filter(callback) {
|
|
75
|
+
const relevant = new Collection();
|
|
76
|
+
this.forEach((value, key)=>{
|
|
77
|
+
if (callback(value, key)) relevant.set(key, value);
|
|
78
|
+
});
|
|
79
|
+
return relevant;
|
|
80
|
+
}
|
|
81
|
+
/** Converts the collection into an array by running a callback on all items in the collection. */ map(callback) {
|
|
82
|
+
const results = [];
|
|
83
|
+
for (const key of this.keys()){
|
|
84
|
+
const value = this.get(key);
|
|
85
|
+
results.push(callback(value, key));
|
|
86
|
+
}
|
|
87
|
+
return results;
|
|
88
|
+
}
|
|
89
|
+
/** Check if one of the items in the collection matches the pattern. */ some(callback) {
|
|
90
|
+
for (const key of this.keys()){
|
|
91
|
+
const value = this.get(key);
|
|
92
|
+
if (callback(value, key)) return true;
|
|
93
|
+
}
|
|
94
|
+
return false;
|
|
95
|
+
}
|
|
96
|
+
/** Check if all of the items in the collection matches the pattern. */ every(callback) {
|
|
97
|
+
for (const key of this.keys()){
|
|
98
|
+
const value = this.get(key);
|
|
99
|
+
if (!callback(value, key)) return false;
|
|
100
|
+
}
|
|
101
|
+
return true;
|
|
102
|
+
}
|
|
103
|
+
/** Runs a callback on all items in the collection, merging them into a single value. */ reduce(callback, initialValue) {
|
|
104
|
+
let accumulator = initialValue;
|
|
105
|
+
for (const key of this.keys()){
|
|
106
|
+
const value = this.get(key);
|
|
107
|
+
accumulator = callback(accumulator, value, key);
|
|
108
|
+
}
|
|
109
|
+
return accumulator;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Db2xsZWN0aW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktaW50ZXJmYWNlXG5leHBvcnQgaW50ZXJmYWNlIFBsYWNlSG9sZGVyQm90IHt9XG5cbmV4cG9ydCBjbGFzcyBDb2xsZWN0aW9uPEssIFY+IGV4dGVuZHMgTWFwPEssIFY+IHtcbiAgLyoqXG4gICAqIFRoZSBtYXhpbXVtIGFtb3VudCBvZiBpdGVtcyBhbGxvd2VkIGluIHRoaXMgY29sbGVjdGlvbi4gVG8gZGlzYWJsZSBjYWNoZSwgc2V0IGl0IDAsIHNldCB0byB1bmRlZmluZWQgdG8gbWFrZSBpdCBpbmZpbml0ZS5cbiAgICogQGRlZmF1bHQgdW5kZWZpbmVkXG4gICAqL1xuICBtYXhTaXplOiBudW1iZXIgfCB1bmRlZmluZWRcbiAgLyoqIEhhbmRsZXIgdG8gcmVtb3ZlIGl0ZW1zIGZyb20gdGhlIGNvbGxlY3Rpb24gZXZlcnkgc28gb2Z0ZW4uICovXG4gIHN3ZWVwZXI6IChDb2xsZWN0aW9uU3dlZXBlcjxLLCBWPiAmIHsgaW50ZXJ2YWxJZD86IE5vZGVKUy5UaW1lb3V0IH0pIHwgdW5kZWZpbmVkXG5cbiAgY29uc3RydWN0b3IoZW50cmllcz86IChSZWFkb25seUFycmF5PHJlYWRvbmx5IFtLLCBWXT4gfCBudWxsKSB8IE1hcDxLLCBWPiwgb3B0aW9ucz86IENvbGxlY3Rpb25PcHRpb25zPEssIFY+KSB7XG4gICAgc3VwZXIoZW50cmllcyA/PyBbXSlcblxuICAgIHRoaXMubWF4U2l6ZSA9IG9wdGlvbnM/Lm1heFNpemVcblxuICAgIGlmICghb3B0aW9ucz8uc3dlZXBlcikgcmV0dXJuXG5cbiAgICB0aGlzLnN0YXJ0U3dlZXBlcihvcHRpb25zLnN3ZWVwZXIpXG4gIH1cblxuICBzdGFydFN3ZWVwZXIob3B0aW9uczogQ29sbGVjdGlvblN3ZWVwZXI8SywgVj4pOiBOb2RlSlMuVGltZW91dCB7XG4gICAgaWYgKHRoaXMuc3dlZXBlcj8uaW50ZXJ2YWxJZCkgY2xlYXJJbnRlcnZhbCh0aGlzLnN3ZWVwZXIuaW50ZXJ2YWxJZClcblxuICAgIHRoaXMuc3dlZXBlciA9IG9wdGlvbnNcbiAgICB0aGlzLnN3ZWVwZXIuaW50ZXJ2YWxJZCA9IHNldEludGVydmFsKCgpID0+IHtcbiAgICAgIHRoaXMuZm9yRWFjaCgodmFsdWUsIGtleSkgPT4ge1xuICAgICAgICBpZiAoIXRoaXMuc3dlZXBlcj8uZmlsdGVyKHZhbHVlLCBrZXksIG9wdGlvbnMuYm90KSkgcmV0dXJuXG5cbiAgICAgICAgdGhpcy5kZWxldGUoa2V5KVxuICAgICAgICByZXR1cm4ga2V5XG4gICAgICB9KVxuICAgIH0sIG9wdGlvbnMuaW50ZXJ2YWwpXG5cbiAgICByZXR1cm4gdGhpcy5zd2VlcGVyLmludGVydmFsSWRcbiAgfVxuXG4gIHN0b3BTd2VlcGVyKCk6IHZvaWQge1xuICAgIHJldHVybiBjbGVhckludGVydmFsKHRoaXMuc3dlZXBlcj8uaW50ZXJ2YWxJZClcbiAgfVxuXG4gIGNoYW5nZVN3ZWVwZXJJbnRlcnZhbChuZXdJbnRlcnZhbDogbnVtYmVyKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuc3dlZXBlciA9PSBudWxsKSByZXR1cm5cblxuICAgIHRoaXMuc3RhcnRTd2VlcGVyKHsgZmlsdGVyOiB0aGlzLnN3ZWVwZXIuZmlsdGVyLCBpbnRlcnZhbDogbmV3SW50ZXJ2YWwgfSlcbiAgfVxuXG4gIGNoYW5nZVN3ZWVwZXJGaWx0ZXIobmV3RmlsdGVyOiAodmFsdWU6IFYsIGtleTogSywgYm90OiBQbGFjZUhvbGRlckJvdCkgPT4gYm9vbGVhbik6IHZvaWQge1xuICAgIGlmICh0aGlzLnN3ZWVwZXIgPT0gbnVsbCkgcmV0dXJuXG5cbiAgICB0aGlzLnN0YXJ0U3dlZXBlcih7IGZpbHRlcjogbmV3RmlsdGVyLCBpbnRlcnZhbDogdGhpcy5zd2VlcGVyLmludGVydmFsIH0pXG4gIH1cblxuICAvKiogQWRkIGFuIGl0ZW0gdG8gdGhlIGNvbGxlY3Rpb24uIE1ha2VzIHN1cmUgbm90IHRvIGdvIGFib3ZlIHRoZSBtYXhTaXplLiAqL1xuICBzZXQoa2V5OiBLLCB2YWx1ZTogVik6IHRoaXMge1xuICAgIC8vIFdoZW4gdGhpcyBjb2xsZWN0aW9uIGlzIG1heFNpemVkIG1ha2Ugc3VyZSB3ZSBjYW4gYWRkIGZpcnN0XG4gICAgaWYgKCh0aGlzLm1heFNpemUgIT09IHVuZGVmaW5lZCB8fCB0aGlzLm1heFNpemUgPT09IDApICYmIHRoaXMuc2l6ZSA+PSB0aGlzLm1heFNpemUpIHtcbiAgICAgIHJldHVybiB0aGlzXG4gICAgfVxuXG4gICAgcmV0dXJuIHN1cGVyLnNldChrZXksIHZhbHVlKVxuICB9XG5cbiAgLyoqIEFkZCBhbiBpdGVtIHRvIHRoZSBjb2xsZWN0aW9uLCBubyBtYXR0ZXIgd2hhdCB0aGUgbWF4U2l6ZSBpcy4gKi9cbiAgZm9yY2VTZXQoa2V5OiBLLCB2YWx1ZTogVik6IHRoaXMge1xuICAgIHJldHVybiBzdXBlci5zZXQoa2V5LCB2YWx1ZSlcbiAgfVxuXG4gIC8qKiBDb252ZXJ0IHRoZSBjb2xsZWN0aW9uIHRvIGFuIGFycmF5LiAqL1xuICBhcnJheSgpOiBWW10ge1xuICAgIHJldHVybiBbLi4udGhpcy52YWx1ZXMoKV1cbiAgfVxuXG4gIC8qKiBSZXRyaWV2ZSB0aGUgdmFsdWUgb2YgdGhlIGZpcnN0IGVsZW1lbnQgaW4gdGhpcyBjb2xsZWN0aW9uLiAqL1xuICBmaXJzdCgpOiBWIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gdGhpcy52YWx1ZXMoKS5uZXh0KCkudmFsdWVcbiAgfVxuXG4gIC8qKiBSZXRyaWV2ZSB0aGUgdmFsdWUgb2YgdGhlIGxhc3QgZWxlbWVudCBpbiB0aGlzIGNvbGxlY3Rpb24uICovXG4gIGxhc3QoKTogViB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIFsuLi50aGlzLnZhbHVlcygpXVt0aGlzLnNpemUgLSAxXVxuICB9XG5cbiAgLyoqIFJldHJpZXZlIHRoZSB2YWx1ZSBvZiBhIHJhbmRvbSBlbGVtZW50IGluIHRoaXMgY29sbGVjdGlvbi4gKi9cbiAgcmFuZG9tKCk6IFYgfCB1bmRlZmluZWQge1xuICAgIGNvbnN0IGFycmF5ID0gWy4uLnRoaXMudmFsdWVzKCldXG4gICAgcmV0dXJuIGFycmF5W01hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIGFycmF5Lmxlbmd0aCldXG4gIH1cblxuICAvKiogRmluZCBhIHNwZWNpZmljIGVsZW1lbnQgaW4gdGhpcyBjb2xsZWN0aW9uLiAqL1xuICBmaW5kKGNhbGxiYWNrOiAodmFsdWU6IFYsIGtleTogSykgPT4gYm9vbGVhbik6IE5vbk51bGxhYmxlPFY+IHwgdW5kZWZpbmVkIHtcbiAgICBmb3IgKGNvbnN0IGtleSBvZiB0aGlzLmtleXMoKSkge1xuICAgICAgY29uc3QgdmFsdWUgPSB0aGlzLmdldChrZXkpIVxuICAgICAgaWYgKGNhbGxiYWNrKHZhbHVlLCBrZXkpKSByZXR1cm4gdmFsdWVcbiAgICB9XG4gICAgLy8gSWYgbm90aGluZyBtYXRjaGVkXG4gIH1cblxuICAvKiogRmluZCBhbGwgZWxlbWVudHMgaW4gdGhpcyBjb2xsZWN0aW9uIHRoYXQgbWF0Y2ggdGhlIGdpdmVuIHBhdHRlcm4uICovXG4gIGZpbHRlcihjYWxsYmFjazogKHZhbHVlOiBWLCBrZXk6IEspID0+IGJvb2xlYW4pOiBDb2xsZWN0aW9uPEssIFY+IHtcbiAgICBjb25zdCByZWxldmFudCA9IG5ldyBDb2xsZWN0aW9uPEssIFY+KClcbiAgICB0aGlzLmZvckVhY2goKHZhbHVlLCBrZXkpID0+IHtcbiAgICAgIGlmIChjYWxsYmFjayh2YWx1ZSwga2V5KSkgcmVsZXZhbnQuc2V0KGtleSwgdmFsdWUpXG4gICAgfSlcblxuICAgIHJldHVybiByZWxldmFudFxuICB9XG5cbiAgLyoqIENvbnZlcnRzIHRoZSBjb2xsZWN0aW9uIGludG8gYW4gYXJyYXkgYnkgcnVubmluZyBhIGNhbGxiYWNrIG9uIGFsbCBpdGVtcyBpbiB0aGUgY29sbGVjdGlvbi4gKi9cbiAgbWFwPFQ+KGNhbGxiYWNrOiAodmFsdWU6IFYsIGtleTogSykgPT4gVCk6IFRbXSB7XG4gICAgY29uc3QgcmVzdWx0cyA9IFtdXG4gICAgZm9yIChjb25zdCBrZXkgb2YgdGhpcy5rZXlzKCkpIHtcbiAgICAgIGNvbnN0IHZhbHVlID0gdGhpcy5nZXQoa2V5KSFcbiAgICAgIHJlc3VsdHMucHVzaChjYWxsYmFjayh2YWx1ZSwga2V5KSlcbiAgICB9XG4gICAgcmV0dXJuIHJlc3VsdHNcbiAgfVxuXG4gIC8qKiBDaGVjayBpZiBvbmUgb2YgdGhlIGl0ZW1zIGluIHRoZSBjb2xsZWN0aW9uIG1hdGNoZXMgdGhlIHBhdHRlcm4uICovXG4gIHNvbWUoY2FsbGJhY2s6ICh2YWx1ZTogViwga2V5OiBLKSA9PiBib29sZWFuKTogYm9vbGVhbiB7XG4gICAgZm9yIChjb25zdCBrZXkgb2YgdGhpcy5rZXlzKCkpIHtcbiAgICAgIGNvbnN0IHZhbHVlID0gdGhpcy5nZXQoa2V5KSFcbiAgICAgIGlmIChjYWxsYmFjayh2YWx1ZSwga2V5KSkgcmV0dXJuIHRydWVcbiAgICB9XG5cbiAgICByZXR1cm4gZmFsc2VcbiAgfVxuXG4gIC8qKiBDaGVjayBpZiBhbGwgb2YgdGhlIGl0ZW1zIGluIHRoZSBjb2xsZWN0aW9uIG1hdGNoZXMgdGhlIHBhdHRlcm4uICovXG4gIGV2ZXJ5KGNhbGxiYWNrOiAodmFsdWU6IFYsIGtleTogSykgPT4gYm9vbGVhbik6IGJvb2xlYW4ge1xuICAgIGZvciAoY29uc3Qga2V5IG9mIHRoaXMua2V5cygpKSB7XG4gICAgICBjb25zdCB2YWx1ZSA9IHRoaXMuZ2V0KGtleSkhXG4gICAgICBpZiAoIWNhbGxiYWNrKHZhbHVlLCBrZXkpKSByZXR1cm4gZmFsc2VcbiAgICB9XG5cbiAgICByZXR1cm4gdHJ1ZVxuICB9XG5cbiAgLyoqIFJ1bnMgYSBjYWxsYmFjayBvbiBhbGwgaXRlbXMgaW4gdGhlIGNvbGxlY3Rpb24sIG1lcmdpbmcgdGhlbSBpbnRvIGEgc2luZ2xlIHZhbHVlLiAqL1xuICByZWR1Y2U8VD4oY2FsbGJhY2s6IChhY2N1bXVsYXRvcjogVCwgdmFsdWU6IFYsIGtleTogSykgPT4gVCwgaW5pdGlhbFZhbHVlPzogVCk6IFQge1xuICAgIGxldCBhY2N1bXVsYXRvcjogVCA9IGluaXRpYWxWYWx1ZSFcblxuICAgIGZvciAoY29uc3Qga2V5IG9mIHRoaXMua2V5cygpKSB7XG4gICAgICBjb25zdCB2YWx1ZSA9IHRoaXMuZ2V0KGtleSkhXG4gICAgICBhY2N1bXVsYXRvciA9IGNhbGxiYWNrKGFjY3VtdWxhdG9yLCB2YWx1ZSwga2V5KVxuICAgIH1cblxuICAgIHJldHVybiBhY2N1bXVsYXRvclxuICB9XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29sbGVjdGlvbk9wdGlvbnM8SywgVj4ge1xuICAvKiogSGFuZGxlciB0byBjbGVhbiBvdXQgdGhlIGl0ZW1zIGluIHRoZSBjb2xsZWN0aW9uIGV2ZXJ5IHNvIG9mdGVuLiAqL1xuICBzd2VlcGVyPzogQ29sbGVjdGlvblN3ZWVwZXI8SywgVj5cbiAgLyoqIFRoZSBtYXhpbXVtIG51bWJlciBvZiBpdGVtcyBhbGxvd2VkIGluIHRoZSBjb2xsZWN0aW9uLiAqL1xuICBtYXhTaXplPzogbnVtYmVyXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29sbGVjdGlvblN3ZWVwZXI8SywgVj4ge1xuICAvKiogVGhlIGZpbHRlciB0byBkZXRlcm1pbmUgd2hldGhlciBhbiBlbGVtZW50IHNob3VsZCBiZSBkZWxldGVkIG9yIG5vdCAqL1xuICBmaWx0ZXI6ICh2YWx1ZTogViwga2V5OiBLLCAuLi5hcmdzOiBhbnlbXSkgPT4gYm9vbGVhblxuICAvKiogVGhlIGludGVydmFsIGluIHdoaWNoIHRoZSBzd2VlcGVyIHNob3VsZCBydW4gKi9cbiAgaW50ZXJ2YWw6IG51bWJlclxuICAvKiogVGhlIGJvdCBvYmplY3QgaXRzZWxmICovXG4gIGJvdD86IFBsYWNlSG9sZGVyQm90XG59XG4iXSwibmFtZXMiOlsiQ29sbGVjdGlvbiIsIk1hcCIsImNvbnN0cnVjdG9yIiwiZW50cmllcyIsIm9wdGlvbnMiLCJtYXhTaXplIiwic3dlZXBlciIsInN0YXJ0U3dlZXBlciIsImludGVydmFsSWQiLCJjbGVhckludGVydmFsIiwic2V0SW50ZXJ2YWwiLCJmb3JFYWNoIiwidmFsdWUiLCJrZXkiLCJmaWx0ZXIiLCJib3QiLCJkZWxldGUiLCJpbnRlcnZhbCIsInN0b3BTd2VlcGVyIiwiY2hhbmdlU3dlZXBlckludGVydmFsIiwibmV3SW50ZXJ2YWwiLCJjaGFuZ2VTd2VlcGVyRmlsdGVyIiwibmV3RmlsdGVyIiwic2V0IiwidW5kZWZpbmVkIiwic2l6ZSIsImZvcmNlU2V0IiwiYXJyYXkiLCJ2YWx1ZXMiLCJmaXJzdCIsIm5leHQiLCJsYXN0IiwicmFuZG9tIiwiTWF0aCIsImZsb29yIiwibGVuZ3RoIiwiZmluZCIsImNhbGxiYWNrIiwia2V5cyIsImdldCIsInJlbGV2YW50IiwibWFwIiwicmVzdWx0cyIsInB1c2giLCJzb21lIiwiZXZlcnkiLCJyZWR1Y2UiLCJpbml0aWFsVmFsdWUiLCJhY2N1bXVsYXRvciJdLCJtYXBwaW5ncyI6IkFBQUEsaUVBQWlFO0FBR2pFLE9BQU8sTUFBTUEsbUJBQXlCQztJQVNwQ0MsWUFBWUMsT0FBNkQsRUFBRUMsT0FBaUMsQ0FBRTtRQUM1RyxLQUFLLENBQUNELFdBQVcsRUFBRTtRQUVuQixJQUFJLENBQUNFLE9BQU8sR0FBR0QsU0FBU0M7UUFFeEIsSUFBSSxDQUFDRCxTQUFTRSxTQUFTO1FBRXZCLElBQUksQ0FBQ0MsWUFBWSxDQUFDSCxRQUFRRSxPQUFPO0lBQ25DO0lBRUFDLGFBQWFILE9BQWdDLEVBQWtCO1FBQzdELElBQUksSUFBSSxDQUFDRSxPQUFPLEVBQUVFLFlBQVlDLGNBQWMsSUFBSSxDQUFDSCxPQUFPLENBQUNFLFVBQVU7UUFFbkUsSUFBSSxDQUFDRixPQUFPLEdBQUdGO1FBQ2YsSUFBSSxDQUFDRSxPQUFPLENBQUNFLFVBQVUsR0FBR0UsWUFBWTtZQUNwQyxJQUFJLENBQUNDLE9BQU8sQ0FBQyxDQUFDQyxPQUFPQztnQkFD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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/OiBQaWNrPHR5cGVvZiBsb2dnZXIsICdkZWJ1ZycgfCAnaW5mbycgfCAnd2FybicgfCAnZXJyb3InIHwgJ2ZhdGFsJz5cbn1cbiJdLCJuYW1lcyI6WyJsb2dnZXIiLCJkZWxheSIsIkxlYWt5QnVja2V0IiwiY29uc3RydWN0b3IiLCJvcHRpb25zIiwidXNlZCIsInF1ZXVlIiwicHJvY2Vzc2luZyIsIm1heCIsInJlZmlsbEFtb3VudCIsInJlZmlsbEludGVydmFsIiwicmVtYWluaW5nIiwicmVmaWxsQnVja2V0IiwiZGVidWciLCJyZWZpbGxzQXQiLCJ1bmRlZmluZWQiLCJjbGVhclRpbWVvdXQiLCJ0aW1lb3V0SWQiLCJzZXRUaW1lb3V0IiwiRGF0ZSIsIm5vdyIsInByb2Nlc3NRdWV1ZSIsImxlbmd0aCIsInNoaWZ0IiwiYWNxdWlyZSIsImhpZ2hQcmlvcml0eSIsIlByb21pc2UiLCJyZXNvbHZlIiwidW5zaGlmdCIsInB1c2giXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLFlBQVksY0FBYTtBQUNoQyxTQUFTQyxLQUFLLFFBQVEsYUFBWTtBQUVsQyxPQUFPLE1BQU1DO0lBa0JYQyxZQUFZQyxPQUE0QixDQUFFO1FBYjFDLDJEQUEyRCxRQUMzREMsT0FBZTtRQUNmLDBGQUEwRixRQUMxRkMsUUFBMEQsRUFBRTtRQUM1RCxvREFBb0QsUUFDcERDLGFBQXNCO1FBU3BCLElBQUksQ0FBQ0MsR0FBRyxHQUFHSixTQUFTSSxPQUFPO1FBQzNCLElBQUksQ0FBQ0MsWUFBWSxHQUFHTCxTQUFTSyxlQUFnQkwsUUFBUUssWUFBWSxHQUFHLElBQUksQ0FBQ0QsR0FBRyxHQUFHLElBQUksQ0FBQ0EsR0FBRyxHQUFHSixRQUFRSyxZQUFZLEdBQUk7UUFDbEgsSUFBSSxDQUFDQyxjQUFjLEdBQUdOLFNBQVNNLGtCQUFrQjtRQUNqRCxJQUFJLENBQUNWLE1BQU0sR0FBR0ksU0FBU0osVUFBVUE7SUFDbkM7SUFFQSw4Q0FBOEMsR0FDOUMsSUFBSVcsWUFBb0I7UUFDdEIsT0FBTyxJQUFJLENBQUNILEdBQUcsR0FBRyxJQUFJLENBQUNILElBQUksR0FBRyxJQUFJLElBQUksQ0FBQ0csR0FBRyxHQUFHLElBQUksQ0FBQ0gsSUFBSTtJQUN4RDtJQUVBLGtDQUFrQyxHQUNsQ08sZUFBcUI7UUFDbkIsSUFBSSxDQUFDWixNQUFNLENBQUNhLEtBQUssQ0FBQyxDQUFDLDJFQUEyRSxDQUFDO1FBQy9GLDZDQUE2QztRQUM3QyxJQUFJLENBQUNSLElBQUksR0FBRyxJQUFJLENBQUNJLFlBQVksR0FBRyxJQUFJLENBQUNKLElBQUksR0FBRyxJQUFJLElBQUksQ0FBQ0EsSUFBSSxHQUFHLElBQUksQ0FBQ0ksWUFBWTtRQUM3RSwyREFBMkQ7UUFDM0QsSUFBSSxDQUFDSyxTQUFTLEdBQUdDO1FBQ2pCLHNCQUFzQjtRQUN0QkMsYUFBYSxJQUFJLENBQUNDLFNBQVM7UUFDM0IsSUFBSSxDQUFDQSxTQUFTLEdBQUdGO1FBRWpCLElBQUksSUFBSSxDQUFDVixJQUFJLEdBQUcsR0FBRztZQUNqQixJQUFJLENBQUNZLFNBQVMsR0FBR0MsV0FBVztnQkFDMUIsSUFBSSxDQUFDTixZQUFZO1lBQ25CLEdBQUcsSUFBSSxDQUFDRixjQUFjO1lBQ3RCLElBQUksQ0FBQ0ksU0FBUyxHQUFHSyxLQUFLQyxHQUFHLEtBQUssSUFBSSxDQUFDVixjQUFjO1FBQ25EO0lBQ0Y7SUFFQSxnQ0FBZ0MsR0FDaEMsTUFBTVcsZUFBOEI7UUFDbEMsSUFBSSxDQUFDckIsTUFBTSxDQUFDYSxLQUFLLENBQUM7UUFFbEIsOENBQThDO1FBQzlDLElBQUksSUFBSSxDQUFDTixVQUFVLEVBQUUsT0FBTyxJQUFJLENBQUNQLE1BQU0sQ0FBQ2EsS0FBSyxDQUFDO1FBRTlDLElBQUksQ0FBQ04sVUFBVSxHQUFHO1FBRWxCLGlDQUFpQztRQUNqQyxNQUFPLElBQUksQ0FBQ0QsS0FBSyxDQUFDZ0IsTUFBTSxDQUFFO1lBQ3hCLElBQUksSUFBSSxDQUFDWCxTQUFTLEVBQUU7Z0JBQ2xCLElBQUksQ0FBQ1gsTUFBTSxDQUFDYSxLQUFLLENBQUMsQ0FBQywyQ0FBMkMsRUFBRSxJQUFJLENBQUNGLFNBQVMsQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDTCxLQUFLLENBQUNnQixNQUFNLENBQUMsQ0FBQztnQkFDN0csOEZBQThGO2dCQUM5RixJQUFJLENBQUNoQixLQUFLLENBQUNpQixLQUFLO2dCQUNoQix3QkFBd0I7Z0JBQ3hCLElBQUksQ0FBQ2xCLElBQUk7Z0JBRVQsd0RBQXdEO2dCQUN4RCxJQUFJLENBQUMsSUFBSSxDQUFDWSxTQUFTLEVBQUU7b0JBQ25CLElBQUksQ0FBQ2pCLE1BQU0sQ0FBQ2EsS0FBSyxDQUFDLENBQUMsNkRBQTZELENBQUM7b0JBRWpGLElBQUksQ0FBQ0ksU0FBUyxHQUFHQyxXQUFXO3dCQUMxQixJQUFJLENBQUNOLFlBQVk7b0JBQ25CLEdBQUcsSUFBSSxDQUFDRixjQUFjO29CQUN0QixnREFBZ0Q7b0JBQ2hELElBQUksQ0FBQ0ksU0FBUyxHQUFHSyxLQUFLQyxHQUFHLEtBQUssSUFBSSxDQUFDVixjQUFjO2dCQUNuRDtZQUNGLE9BR0ssSUFBSSxJQUFJLENBQUNJLFNBQVMsRUFBRTtnQkFDdkIsTUFBTU0sTUFBTUQsS0FBS0MsR0FBRztnQkFDcEIsaUVBQWlFO2dCQUNqRSxJQUFJLElBQUksQ0FBQ04sU0FBUyxHQUFHTSxLQUFLO29CQUN4QixJQUFJLENBQUNwQixNQUFNLENBQUNhLEtBQUssQ0FBQyxDQUFDLDhEQUE4RCxFQUFFLElBQUksQ0FBQ0MsU0FBUyxHQUFHTSxJQUFJLEVBQUUsQ0FBQztvQkFDM0csTUFBTW5CLE1BQU0sSUFBSSxDQUFDYSxTQUFTLEdBQUdNO29CQUM3QixJQUFJLENBQUNwQixNQUFNLENBQUNhLEtBQUssQ0FBQyxDQUFDLGdDQUFnQyxDQUFDO2dCQUN0RCxPQUdLO29CQUNILElBQUksQ0FBQ2IsTUFBTSxDQUFDYSxLQUFLLENBQUMsQ0FBQyxvRUFBb0UsQ0FBQztvQkFDeEYsTUFBTVosTUFBTTtnQkFDZDtZQUNGO1FBQ0Y7UUFFQSxnRUFBZ0U7UUFDaEUsSUFBSSxDQUFDTSxVQUFVLEdBQUc7SUFDcEI7SUFFQSxvRUFBb0UsR0FDcEUsTUFBTWlCLFFBQVFDLFlBQXNCLEVBQWlCO1FBQ25ELE9BQU8sTUFBTSxJQUFJQyxRQUFRLENBQUNDO1lBQ3hCLDZEQUE2RDtZQUM3RCxJQUFJRixjQUFjLElBQUksQ0FBQ25CLEtBQUssQ0FBQ3NCLE9BQU8sQ0FBQ0Q7aUJBRWhDLElBQUksQ0FBQ3JCLEtBQUssQ0FBQ3VCLElBQUksQ0FBQ0Y7WUFFckIseURBQXlEO1lBQ3pELEtBQUssSUFBSSxDQUFDTixZQUFZO1FBQ3hCO0lBQ0Y7QUFDRiJ9
|