@discordeno/rest 19.0.0-next.fd518cb → 19.0.0-next.fda3003
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/index.cjs +25 -0
- package/dist/cjs/invalidBucket.cjs +87 -0
- package/dist/cjs/manager.cjs +1446 -0
- package/dist/cjs/queue.cjs +166 -0
- package/dist/cjs/routes.cjs +581 -0
- package/dist/cjs/types.cjs +6 -0
- package/dist/cjs/typings/routes.cjs +6 -0
- package/dist/esm/index.js +8 -0
- package/dist/esm/invalidBucket.js +83 -0
- package/dist/esm/manager.js +1404 -0
- package/dist/esm/queue.js +156 -0
- package/dist/esm/routes.js +571 -0
- package/dist/esm/types.js +3 -0
- package/dist/esm/typings/routes.js +3 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/{invalidBucket.d.ts → types/invalidBucket.d.ts} +5 -0
- package/dist/types/invalidBucket.d.ts.map +1 -0
- package/dist/types/manager.d.ts.map +1 -0
- package/dist/{queue.d.ts → types/queue.d.ts} +12 -0
- package/dist/types/queue.d.ts.map +1 -0
- package/dist/types/routes.d.ts.map +1 -0
- package/dist/{types.d.ts → types/types.d.ts} +446 -110
- package/dist/types/types.d.ts.map +1 -0
- package/dist/{typings → types/typings}/routes.d.ts +46 -5
- package/dist/types/typings/routes.d.ts.map +1 -0
- package/package.json +29 -23
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -8
- package/dist/index.js.map +0 -1
- package/dist/invalidBucket.d.ts.map +0 -1
- package/dist/invalidBucket.js +0 -82
- package/dist/invalidBucket.js.map +0 -1
- package/dist/manager.d.ts.map +0 -1
- package/dist/manager.js +0 -1102
- package/dist/manager.js.map +0 -1
- package/dist/queue.d.ts.map +0 -1
- package/dist/queue.js +0 -153
- package/dist/queue.js.map +0 -1
- package/dist/routes.d.ts.map +0 -1
- package/dist/routes.js +0 -487
- package/dist/routes.js.map +0 -1
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js +0 -3
- package/dist/types.js.map +0 -1
- package/dist/typings/routes.d.ts.map +0 -1
- package/dist/typings/routes.js +0 -3
- package/dist/typings/routes.js.map +0 -1
- /package/dist/{index.d.ts → types/index.d.ts} +0 -0
- /package/dist/{manager.d.ts → types/manager.d.ts} +0 -0
- /package/dist/{routes.d.ts → types/routes.d.ts} +0 -0
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
_export_star(require("./typings/routes.cjs"), exports);
|
|
6
|
+
_export_star(require("./invalidBucket.cjs"), exports);
|
|
7
|
+
_export_star(require("./manager.cjs"), exports);
|
|
8
|
+
_export_star(require("./queue.cjs"), exports);
|
|
9
|
+
_export_star(require("./routes.cjs"), exports);
|
|
10
|
+
_export_star(require("./types.cjs"), exports);
|
|
11
|
+
function _export_star(from, to) {
|
|
12
|
+
Object.keys(from).forEach(function(k) {
|
|
13
|
+
if (k !== "default" && !Object.prototype.hasOwnProperty.call(to, k)) {
|
|
14
|
+
Object.defineProperty(to, k, {
|
|
15
|
+
enumerable: true,
|
|
16
|
+
get: function() {
|
|
17
|
+
return from[k];
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
return from;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3R5cGluZ3Mvcm91dGVzLmpzJ1xuZXhwb3J0ICogZnJvbSAnLi9pbnZhbGlkQnVja2V0LmpzJ1xuZXhwb3J0ICogZnJvbSAnLi9tYW5hZ2VyLmpzJ1xuZXhwb3J0ICogZnJvbSAnLi9xdWV1ZS5qcydcbmV4cG9ydCAqIGZyb20gJy4vcm91dGVzLmpzJ1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcy5qcydcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O3FCQUFjO3FCQUNBO3FCQUNBO3FCQUNBO3FCQUNBO3FCQUNBIn0=
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "createInvalidRequestBucket", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return createInvalidRequestBucket;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _utils = require("@discordeno/utils");
|
|
12
|
+
function createInvalidRequestBucket(options) {
|
|
13
|
+
const bucket = {
|
|
14
|
+
invalidRequests: options.current ?? 0,
|
|
15
|
+
max: options.max ?? 10000,
|
|
16
|
+
interval: options.interval ?? 600_000,
|
|
17
|
+
resetAt: options.resetAt,
|
|
18
|
+
safety: options.safety ?? 1,
|
|
19
|
+
errorStatuses: options.errorStatuses ?? [
|
|
20
|
+
401,
|
|
21
|
+
403,
|
|
22
|
+
429
|
|
23
|
+
],
|
|
24
|
+
activeRequests: options.requested ?? 0,
|
|
25
|
+
processing: false,
|
|
26
|
+
logger: options.logger ?? _utils.logger,
|
|
27
|
+
waiting: [],
|
|
28
|
+
requestsAllowed: function() {
|
|
29
|
+
if (bucket.resetAt !== undefined && Date.now() >= bucket.resetAt) {
|
|
30
|
+
bucket.invalidRequests = 0;
|
|
31
|
+
bucket.resetAt = Date.now() + bucket.interval;
|
|
32
|
+
}
|
|
33
|
+
return bucket.max - bucket.invalidRequests - bucket.activeRequests - bucket.safety;
|
|
34
|
+
},
|
|
35
|
+
isRequestAllowed: function() {
|
|
36
|
+
return bucket.requestsAllowed() > 0;
|
|
37
|
+
},
|
|
38
|
+
waitUntilRequestAvailable: async function() {
|
|
39
|
+
// eslint-disable-next-line no-async-promise-executor
|
|
40
|
+
return await new Promise(async (resolve)=>{
|
|
41
|
+
// If whatever amount of requests is left is more than the safety margin, allow the request
|
|
42
|
+
if (bucket.isRequestAllowed()) {
|
|
43
|
+
bucket.activeRequests += 1;
|
|
44
|
+
resolve();
|
|
45
|
+
} else {
|
|
46
|
+
bucket.waiting.push(resolve);
|
|
47
|
+
await bucket.processWaiting();
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
},
|
|
51
|
+
processWaiting: async function() {
|
|
52
|
+
// If already processing, that loop will handle all waiting requests.
|
|
53
|
+
if (bucket.processing) return;
|
|
54
|
+
// Mark as processing so other loops don't start
|
|
55
|
+
bucket.processing = true;
|
|
56
|
+
while(bucket.waiting.length > 0){
|
|
57
|
+
bucket.logger.info(`[InvalidBucket] processing waiting queue while loop ran with ${bucket.waiting.length} pending requests to be made. ${JSON.stringify(bucket)}`);
|
|
58
|
+
if (!bucket.isRequestAllowed() && bucket.resetAt !== undefined) {
|
|
59
|
+
bucket.logger.warn(`[InvalidBucket] processing waiting queue is now paused until more requests are available. ${bucket.waiting.length} pending requests. ${JSON.stringify(bucket)}`);
|
|
60
|
+
await (0, _utils.delay)(bucket.resetAt - Date.now());
|
|
61
|
+
}
|
|
62
|
+
bucket.activeRequests += 1;
|
|
63
|
+
// Resolve the next item in the queue
|
|
64
|
+
bucket.waiting.shift()?.();
|
|
65
|
+
}
|
|
66
|
+
// Mark as false so next pending request can be triggered by new loop.
|
|
67
|
+
bucket.processing = false;
|
|
68
|
+
},
|
|
69
|
+
handleCompletedRequest: function(code, sharedScope) {
|
|
70
|
+
// Since request is complete, we can remove one from requested.
|
|
71
|
+
bucket.activeRequests -= 1;
|
|
72
|
+
// Since it is as a valid request, we don't need to do anything
|
|
73
|
+
if (!bucket.errorStatuses.includes(code)) return;
|
|
74
|
+
// Shared scope is not considered invalid
|
|
75
|
+
if (code === 429 && sharedScope) return;
|
|
76
|
+
// INVALID REQUEST WAS MADE
|
|
77
|
+
if (bucket.resetAt === undefined) {
|
|
78
|
+
bucket.resetAt = Date.now() + bucket.interval;
|
|
79
|
+
}
|
|
80
|
+
bucket.invalidRequests += 1;
|
|
81
|
+
bucket.logger.warn(`[InvalidBucket] an invalid request was made. Increasing invalidRequests count to ${bucket.invalidRequests}`);
|
|
82
|
+
}
|
|
83
|
+
};
|
|
84
|
+
return bucket;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbnZhbGlkQnVja2V0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGRlbGF5LCBsb2dnZXIgfSBmcm9tICdAZGlzY29yZGVuby91dGlscydcblxuLyoqXG4gKiBBIGludmFsaWQgcmVxdWVzdCBidWNrZXQgaXMgdXNlZCBpbiBhIHNpbWlsYXIgbWFubmVyIGFzIGEgbGVha3kgYnVja2V0IGJ1dCBhIGludmFsaWQgcmVxdWVzdCBidWNrZXQgY2FuIGJlIHJlZmlsbGVkIGFzIG5lZWRlZC5cbiAqIEl0J3MgcHVycG9zZSBpcyB0byBtYWtlIHN1cmUgdGhlIGJvdCBkb2VzIG5vdCBoaXQgdGhlIGxpbWl0IHRvIGdldHRpbmcgYSAxIGhyIGJhbi5cbiAqXG4gKiBAcGFyYW0gb3B0aW9ucyBUaGUgb3B0aW9ucyB1c2VkIHRvIGNvbmZpZ3VyZSB0aGlzIGJ1Y2tldC5cbiAqIEByZXR1cm5zIFJlZmlsbGluZ0J1Y2tldFxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlSW52YWxpZFJlcXVlc3RCdWNrZXQob3B0aW9uczogSW52YWxpZFJlcXVlc3RCdWNrZXRPcHRpb25zKTogSW52YWxpZFJlcXVlc3RCdWNrZXQge1xuICBjb25zdCBidWNrZXQ6IEludmFsaWRSZXF1ZXN0QnVja2V0ID0ge1xuICAgIGludmFsaWRSZXF1ZXN0czogb3B0aW9ucy5jdXJyZW50ID8/IDAsXG4gICAgbWF4OiBvcHRpb25zLm1heCA/PyAxMDAwMCxcbiAgICBpbnRlcnZhbDogb3B0aW9ucy5pbnRlcnZhbCA/PyA2MDBfMDAwLCAvLyAxMCBtaW51dGVzXG4gICAgcmVzZXRBdDogb3B0aW9ucy5yZXNldEF0LFxuICAgIHNhZmV0eTogb3B0aW9ucy5zYWZldHkgPz8gMSxcbiAgICBlcnJvclN0YXR1c2VzOiBvcHRpb25zLmVycm9yU3RhdHVzZXMgPz8gWzQwMSwgNDAzLCA0MjldLFxuICAgIGFjdGl2ZVJlcXVlc3RzOiBvcHRpb25zLnJlcXVlc3RlZCA/PyAwLFxuICAgIHByb2Nlc3Npbmc6IGZhbHNlLFxuICAgIGxvZ2dlcjogb3B0aW9ucy5sb2dnZXIgPz8gbG9nZ2VyLFxuXG4gICAgd2FpdGluZzogW10sXG5cbiAgICByZXF1ZXN0c0FsbG93ZWQ6IGZ1bmN0aW9uICgpIHtcbiAgICAgIGlmIChidWNrZXQucmVzZXRBdCAhPT0gdW5kZWZpbmVkICYmIERhdGUubm93KCkgPj0gYnVja2V0LnJlc2V0QXQpIHtcbiAgICAgICAgYnVja2V0LmludmFsaWRSZXF1ZXN0cyA9IDBcbiAgICAgICAgYnVja2V0LnJlc2V0QXQgPSBEYXRlLm5vdygpICsgYnVja2V0LmludGVydmFsXG4gICAgICB9XG5cbiAgICAgIHJldHVybiBidWNrZXQubWF4IC0gYnVja2V0LmludmFsaWRSZXF1ZXN0cyAtIGJ1Y2tldC5hY3RpdmVSZXF1ZXN0cyAtIGJ1Y2tldC5zYWZldHlcbiAgICB9LFxuXG4gICAgaXNSZXF1ZXN0QWxsb3dlZDogZnVuY3Rpb24gKCkge1xuICAgICAgcmV0dXJuIGJ1Y2tldC5yZXF1ZXN0c0FsbG93ZWQoKSA+IDBcbiAgICB9LFxuXG4gICAgd2FpdFVudGlsUmVxdWVzdEF2YWlsYWJsZTogYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWFzeW5jLXByb21pc2UtZXhlY3V0b3JcbiAgICAgIHJldHVybiBhd2FpdCBuZXcgUHJvbWlzZShhc3luYyAocmVzb2x2ZSkgPT4ge1xuICAgICAgICAvLyBJZiB3aGF0ZXZlciBhbW91bnQgb2YgcmVxdWVzdHMgaXMgbGVmdCBpcyBtb3JlIHRoYW4gdGhlIHNhZmV0eSBtYXJnaW4sIGFsbG93IHRoZSByZXF1ZXN0XG4gICAgICAgIGlmIChidWNrZXQuaXNSZXF1ZXN0QWxsb3dlZCgpKSB7XG4gICAgICAgICAgYnVja2V0LmFjdGl2ZVJlcXVlc3RzICs9IDFcbiAgICAgICAgICByZXNvbHZlKClcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBidWNrZXQud2FpdGluZy5wdXNoKHJlc29sdmUpXG4gICAgICAgICAgYXdhaXQgYnVja2V0LnByb2Nlc3NXYWl0aW5nKClcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICB9LFxuXG4gICAgcHJvY2Vzc1dhaXRpbmc6IGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICAgIC8vIElmIGFscmVhZHkgcHJvY2Vzc2luZywgdGhhdCBsb29wIHdpbGwgaGFuZGxlIGFsbCB3YWl0aW5nIHJlcXVlc3RzLlxuICAgICAgaWYgKGJ1Y2tldC5wcm9jZXNzaW5nKSByZXR1cm5cblxuICAgICAgLy8gTWFyayBhcyBwcm9jZXNzaW5nIHNvIG90aGVyIGxvb3BzIGRvbid0IHN0YXJ0XG4gICAgICBidWNrZXQucHJvY2Vzc2luZyA9IHRydWVcblxuICAgICAgd2hpbGUgKGJ1Y2tldC53YWl0aW5nLmxlbmd0aCA+IDApIHtcbiAgICAgICAgYnVja2V0LmxvZ2dlci5pbmZvKFxuICAgICAgICAgIGBbSW52YWxpZEJ1Y2tldF0gcHJvY2Vzc2luZyB3YWl0aW5nIHF1ZXVlIHdoaWxlIGxvb3AgcmFuIHdpdGggJHtidWNrZXQud2FpdGluZy5sZW5ndGh9IHBlbmRpbmcgcmVxdWVzdHMgdG8gYmUgbWFkZS4gJHtKU09OLnN0cmluZ2lmeShcbiAgICAgICAgICAgIGJ1Y2tldCxcbiAgICAgICAgICApfWAsXG4gICAgICAgIClcblxuICAgICAgICBpZiAoIWJ1Y2tldC5pc1JlcXVlc3RBbGxvd2VkKCkgJiYgYnVja2V0LnJlc2V0QXQgIT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgIGJ1Y2tldC5sb2dnZXIud2FybihcbiAgICAgICAgICAgIGBbSW52YWxpZEJ1Y2tldF0gcHJvY2Vzc2luZyB3YWl0aW5nIHF1ZXVlIGlzIG5vdyBwYXVzZWQgdW50aWwgbW9yZSByZXF1ZXN0cyBhcmUgYXZhaWxhYmxlLiAke1xuICAgICAgICAgICAgICBidWNrZXQud2FpdGluZy5sZW5ndGhcbiAgICAgICAgICAgIH0gcGVuZGluZyByZXF1ZXN0cy4gJHtKU09OLnN0cmluZ2lmeShidWNrZXQpfWAsXG4gICAgICAgICAgKVxuICAgICAgICAgIGF3YWl0IGRlbGF5KGJ1Y2tldC5yZXNldEF0IC0gRGF0ZS5ub3coKSlcbiAgICAgICAgfVxuXG4gICAgICAgIGJ1Y2tldC5hY3RpdmVSZXF1ZXN0cyArPSAxXG4gICAgICAgIC8vIFJlc29sdmUgdGhlIG5leHQgaXRlbSBpbiB0aGUgcXVldWVcbiAgICAgICAgYnVja2V0LndhaXRpbmcuc2hpZnQoKT8uKClcbiAgICAgIH1cblxuICAgICAgLy8gTWFyayBhcyBmYWxzZSBzbyBuZXh0IHBlbmRpbmcgcmVxdWVzdCBjYW4gYmUgdHJpZ2dlcmVkIGJ5IG5ldyBsb29wLlxuICAgICAgYnVja2V0LnByb2Nlc3NpbmcgPSBmYWxzZVxuICAgIH0sXG5cbiAgICBoYW5kbGVDb21wbGV0ZWRSZXF1ZXN0OiBmdW5jdGlvbiAoY29kZSwgc2hhcmVkU2NvcGUpIHtcbiAgICAgIC8vIFNpbmNlIHJlcXVlc3QgaXMgY29tcGxldGUsIHdlIGNhbiByZW1vdmUgb25lIGZyb20gcmVxdWVzdGVkLlxuICAgICAgYnVja2V0LmFjdGl2ZVJlcXVlc3RzIC09IDFcbiAgICAgIC8vIFNpbmNlIGl0IGlzIGFzIGEgdmFsaWQgcmVxdWVzdCwgd2UgZG9uJ3QgbmVlZCB0byBkbyBhbnl0aGluZ1xuICAgICAgaWYgKCFidWNrZXQuZXJyb3JTdGF0dXNlcy5pbmNsdWRlcyhjb2RlKSkgcmV0dXJuXG4gICAgICAvLyBTaGFyZWQgc2NvcGUgaXMgbm90IGNvbnNpZGVyZWQgaW52YWxpZFxuICAgICAgaWYgKGNvZGUgPT09IDQyOSAmJiBzaGFyZWRTY29wZSkgcmV0dXJuXG5cbiAgICAgIC8vIElOVkFMSUQgUkVRVUVTVCBXQVMgTUFERVxuICAgICAgaWYgKGJ1Y2tldC5yZXNldEF0ID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgYnVja2V0LnJlc2V0QXQgPSBEYXRlLm5vdygpICsgYnVja2V0LmludGVydmFsXG4gICAgICB9XG5cbiAgICAgIGJ1Y2tldC5pbnZhbGlkUmVxdWVzdHMgKz0gMVxuICAgICAgYnVja2V0LmxvZ2dlci53YXJuKGBbSW52YWxpZEJ1Y2tldF0gYW4gaW52YWxpZCByZXF1ZXN0IHdhcyBtYWRlLiBJbmNyZWFzaW5nIGludmFsaWRSZXF1ZXN0cyBjb3VudCB0byAke2J1Y2tldC5pbnZhbGlkUmVxdWVzdHN9YClcbiAgICB9LFxuICB9XG5cbiAgcmV0dXJuIGJ1Y2tldFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEludmFsaWRSZXF1ZXN0QnVja2V0T3B0aW9ucyB7XG4gIC8qKiBjdXJyZW50IGludmFsaWQgYW1vdW50ICovXG4gIGN1cnJlbnQ/OiBudW1iZXJcbiAgLyoqIG1heCBpbnZhbGlkIHJlcXVlc3RzIGFsbG93ZWQgdW50aWwgYmFuLiBEZWZhdWx0cyB0byAxMCwwMDAgKi9cbiAgbWF4PzogbnVtYmVyXG4gIC8qKiBUaGUgdGltZSB0aGF0IGRpc2NvcmQgYWxsb3dzIHRvIG1ha2UgdGhlIG1heCBudW1iZXIgb2YgaW52YWxpZCByZXF1ZXN0cy4gRGVmYXVsdHMgdG8gMTAgbWludXRlcyAqL1xuICBpbnRlcnZhbD86IG51bWJlclxuICAvKiogV2hlbiB0aGUgdGltZW91dCBmb3IgdGhlIGJ1Y2tldCBoYXMgc3RhcnRlZCBhdC4gKi9cbiAgcmVzZXRBdD86IG51bWJlclxuICAvKiogaG93IHNhZmUgdG8gYmUgZnJvbSBtYXguIERlZmF1bHRzIHRvIDEgKi9cbiAgc2FmZXR5PzogbnVtYmVyXG4gIC8qKiBUaGUgcmVxdWVzdCBzdGF0dXNlcyB0aGF0IGNvdW50IGFzIGFuIGludmFsaWQgcmVxdWVzdC4gKi9cbiAgZXJyb3JTdGF0dXNlcz86IG51bWJlcltdXG4gIC8qKiBUaGUgYW1vdW50IG9mIHJlcXVlc3RzIHRoYXQgd2VyZSByZXF1ZXN0ZWQgZnJvbSB0aGlzIGJ1Y2tldC4gKi9cbiAgcmVxdWVzdGVkPzogbnVtYmVyXG4gIC8qKiBUaGUgbG9nZ2VyIHRoYXQgd2lsbCBiZSB1c2VkIGZvciB0aGUgYnVja2V0ICovXG4gIGxvZ2dlcj86IFBpY2s8dHlwZW9mIGxvZ2dlciwgJ2RlYnVnJyB8ICdpbmZvJyB8ICd3YXJuJyB8ICdlcnJvcicgfCAnZmF0YWwnPlxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEludmFsaWRSZXF1ZXN0QnVja2V0IHtcbiAgLyoqIGN1cnJlbnQgaW52YWxpZCBhbW91bnQgKi9cbiAgaW52YWxpZFJlcXVlc3RzOiBudW1iZXJcbiAgLyoqIG1heCBpbnZhbGlkIHJlcXVlc3RzIGFsbG93ZWQgdW50aWwgYmFuLiBEZWZhdWx0cyB0byAxMCwwMDAgKi9cbiAgbWF4OiBudW1iZXJcbiAgLyoqIFRoZSB0aW1lIHRoYXQgZGlzY29yZCBhbGxvd3MgdG8gbWFrZSB0aGUgbWF4IG51bWJlciBvZiBpbnZhbGlkIHJlcXVlc3RzLiBEZWZhdWx0cyB0byAxMCBtaW51dGVzICovXG4gIGludGVydmFsOiBudW1iZXJcbiAgLyoqIFdoZW4gdGhlIHRpbWVvdXQgZm9yIHRoaXMgYnVja2V0IGhhcyBzdGFydGVkIGF0LiAqL1xuICByZXNldEF0OiBudW1iZXIgfCB1bmRlZmluZWRcbiAgLyoqIGhvdyBzYWZlIHRvIGJlIGZyb20gbWF4LiBEZWZhdWx0cyB0byAxICovXG4gIHNhZmV0eTogbnVtYmVyXG4gIC8qKiBUaGUgcmVxdWVzdCBzdGF0dXNlcyB0aGF0IGNvdW50IGFzIGFuIGludmFsaWQgcmVxdWVzdC4gKi9cbiAgZXJyb3JTdGF0dXNlczogbnVtYmVyW11cbiAgLyoqIFRoZSBhbW91bnQgb2YgcmVxdWVzdHMgdGhhdCB3ZXJlIHJlcXVlc3RlZCBmcm9tIHRoaXMgYnVja2V0LiAqL1xuICBhY3RpdmVSZXF1ZXN0czogbnVtYmVyXG4gIC8qKiBUaGUgcmVxdWVzdHMgdGhhdCBhcmUgY3VycmVudGx5IHBlbmRpbmcuICovXG4gIHdhaXRpbmc6IEFycmF5PCh2YWx1ZTogdm9pZCB8IFByb21pc2VMaWtlPHZvaWQ+KSA9PiB2b2lkPlxuICAvKiogV2hldGhlciBvciBub3QgdGhlIHdhaXRpbmcgcXVldWUgaXMgYWxyZWFkeSBwcm9jZXNzaW5nLiAqL1xuICBwcm9jZXNzaW5nOiBib29sZWFuXG4gIC8qKiBUaGUgbG9nZ2VyIHRoYXQgd2lsbCBiZSB1c2VkIGZvciB0aGUgYnVja2V0ICovXG4gIGxvZ2dlcjogUGljazx0eXBlb2YgbG9nZ2VyLCAnZGVidWcnIHwgJ2luZm8nIHwgJ3dhcm4nIHwgJ2Vycm9yJyB8ICdmYXRhbCc+XG5cbiAgLyoqIEdpdmVzIHRoZSBudW1iZXIgb2YgcmVxdWVzdHMgdGhhdCBhcmUgY3VycmVudGx5IGFsbG93ZWQuICovXG4gIHJlcXVlc3RzQWxsb3dlZDogKCkgPT4gbnVtYmVyXG4gIC8qKiBDaGVja3MgaWYgYSByZXF1ZXN0IGlzIGFsbG93ZWQgYXQgdGhpcyB0aW1lLiAqL1xuICBpc1JlcXVlc3RBbGxvd2VkOiAoKSA9PiBib29sZWFuXG4gIC8qKiBXYWl0cyB1bnRpbCBhIHJlcXVlc3QgaXMgYXZhaWxhYmxlICovXG4gIHdhaXRVbnRpbFJlcXVlc3RBdmFpbGFibGU6ICgpID0+IFByb21pc2U8dm9pZD5cbiAgLyoqIEJlZ2lucyBwcm9jZXNzaW5nIHRoZSB3YWl0aW5nIHF1ZXVlIG9mIHJlcXVlc3RzLiAqL1xuICBwcm9jZXNzV2FpdGluZzogKCkgPT4gUHJvbWlzZTx2b2lkPlxuICAvKiogSGFuZGxlciBmb3Igd2hlbmV2ZXIgYSByZXF1ZXN0IGlzIHZhbGlkYXRlZC4gVGhpcyBzaG91bGQgdXBkYXRlIHRoZSByZXF1ZXN0ZWQgdmFsdWVzIG9yIHRyaWdnZXIgYW55IG90aGVyIG5lY2Vzc2FyeSBzdHVmZi4gKi9cbiAgaGFuZGxlQ29tcGxldGVkUmVxdWVzdDogKGNvZGU6IG51bWJlciwgc2hhcmVkU2NvcGU6IGJvb2xlYW4pID0+IHZvaWRcbn1cbiJdLCJuYW1lcyI6WyJjcmVhdGVJbnZhbGlkUmVxdWVzdEJ1Y2tldCIsIm9wdGlvbnMiLCJidWNrZXQiLCJpbnZhbGlkUmVxdWVzdHMiLCJjdXJyZW50IiwibWF4IiwiaW50ZXJ2YWwiLCJyZXNldEF0Iiwic2FmZXR5IiwiZXJyb3JTdGF0dXNlcyIsImFjdGl2ZVJlcXVlc3RzIiwicmVxdWVzdGVkIiwicHJvY2Vzc2luZyIsImxvZ2dlciIsIndhaXRpbmciLCJyZXF1ZXN0c0FsbG93ZWQiLCJ1bmRlZmluZWQiLCJEYXRlIiwibm93IiwiaXNSZXF1ZXN0QWxsb3dlZCIsIndhaXRVbnRpbFJlcXVlc3RBdmFpbGFibGUiLCJQcm9taXNlIiwicmVzb2x2ZSIsInB1c2giLCJwcm9jZXNzV2FpdGluZyIsImxlbmd0aCIsImluZm8iLCJKU09OIiwic3RyaW5naWZ5Iiwid2FybiIsImRlbGF5Iiwic2hpZnQiLCJoYW5kbGVDb21wbGV0ZWRSZXF1ZXN0IiwiY29kZSIsInNoYXJlZFNjb3BlIiwiaW5jbHVkZXMiXSwibWFwcGluZ3MiOiI7Ozs7K0JBU2dCQTs7O2VBQUFBOzs7dUJBVGM7QUFTdkIsU0FBU0EsMkJBQTJCQyxPQUFvQztJQUM3RSxNQUFNQyxTQUErQjtRQUNuQ0MsaUJBQWlCRixRQUFRRyxPQUFPLElBQUk7UUFDcENDLEtBQUtKLFFBQVFJLEdBQUcsSUFBSTtRQUNwQkMsVUFBVUwsUUFBUUssUUFBUSxJQUFJO1FBQzlCQyxTQUFTTixRQUFRTSxPQUFPO1FBQ3hCQyxRQUFRUCxRQUFRTyxNQUFNLElBQUk7UUFDMUJDLGVBQWVSLFFBQVFRLGFBQWEsSUFBSTtZQUFDO1lBQUs7WUFBSztTQUFJO1FBQ3ZEQyxnQkFBZ0JULFFBQVFVLFNBQVMsSUFBSTtRQUNyQ0MsWUFBWTtRQUNaQyxRQUFRWixRQUFRWSxNQUFNLElBQUlBLGFBQU07UUFFaENDLFNBQVMsRUFBRTtRQUVYQyxpQkFBaUI7WUFDZixJQUFJYixPQUFPSyxPQUFPLEtBQUtTLGFBQWFDLEtBQUtDLEdBQUcsTUFBTWhCLE9BQU9LLE9BQU8sRUFBRTtnQkFDaEVMLE9BQU9DLGVBQWUsR0FBRztnQkFDekJELE9BQU9LLE9BQU8sR0FBR1UsS0FBS0MsR0FBRyxLQUFLaEIsT0FBT0ksUUFBUTtZQUMvQztZQUVBLE9BQU9KLE9BQU9HLEdBQUcsR0FBR0gsT0FBT0MsZUFBZSxHQUFHRCxPQUFPUSxjQUFjLEdBQUdSLE9BQU9NLE1BQU07UUFDcEY7UUFFQVcsa0JBQWtCO1lBQ2hCLE9BQU9qQixPQUFPYSxlQUFlLEtBQUs7UUFDcEM7UUFFQUssMkJBQTJCO1lBQ3pCLHFEQUFxRDtZQUNyRCxPQUFPLE1BQU0sSUFBSUMsUUFBUSxPQUFPQztnQkFDOUIsMkZBQTJGO2dCQUMzRixJQUFJcEIsT0FBT2lCLGdCQUFnQixJQUFJO29CQUM3QmpCLE9BQU9RLGNBQWMsSUFBSTtvQkFDekJZO2dCQUNGLE9BQU87b0JBQ0xwQixPQUFPWSxPQUFPLENBQUNTLElBQUksQ0FBQ0Q7b0JBQ3BCLE1BQU1wQixPQUFPc0IsY0FBYztnQkFDN0I7WUFDRjtRQUNGO1FBRUFBLGdCQUFnQjtZQUNkLHFFQUFxRTtZQUNyRSxJQUFJdEIsT0FBT1UsVUFBVSxFQUFFO1lBRXZCLGdEQUFnRDtZQUNoRFYsT0FBT1UsVUFBVSxHQUFHO1lBRXBCLE1BQU9WLE9BQU9ZLE9BQU8sQ0FBQ1csTUFBTSxHQUFHLEVBQUc7Z0JBQ2hDdkIsT0FBT1csTUFBTSxDQUFDYSxJQUFJLENBQ2hCLENBQUMsNkRBQTZELEVBQUV4QixPQUFPWSxPQUFPLENBQUNXLE1BQU0sQ0FBQyw4QkFBOEIsRUFBRUUsS0FBS0MsU0FBUyxDQUNsSTFCLFFBQ0EsQ0FBQztnQkFHTCxJQUFJLENBQUNBLE9BQU9pQixnQkFBZ0IsTUFBTWpCLE9BQU9LLE9BQU8sS0FBS1MsV0FBVztvQkFDOURkLE9BQU9XLE1BQU0sQ0FBQ2dCLElBQUksQ0FDaEIsQ0FBQywwRkFBMEYsRUFDekYzQixPQUFPWSxPQUFPLENBQUNXLE1BQU0sQ0FDdEIsbUJBQW1CLEVBQUVFLEtBQUtDLFNBQVMsQ0FBQzFCLFFBQVEsQ0FBQztvQkFFaEQsTUFBTTRCLElBQUFBLFlBQUssRUFBQzVCLE9BQU9LLE9BQU8sR0FBR1UsS0FBS0MsR0FBRztnQkFDdkM7Z0JBRUFoQixPQUFPUSxjQUFjLElBQUk7Z0JBQ3pCLHFDQUFxQztnQkFDckNSLE9BQU9ZLE9BQU8sQ0FBQ2lCLEtBQUs7WUFDdEI7WUFFQSxzRUFBc0U7WUFDdEU3QixPQUFPVSxVQUFVLEdBQUc7UUFDdEI7UUFFQW9CLHdCQUF3QixTQUFVQyxJQUFJLEVBQUVDLFdBQVc7WUFDakQsK0RBQStEO1lBQy9EaEMsT0FBT1EsY0FBYyxJQUFJO1lBQ3pCLCtEQUErRDtZQUMvRCxJQUFJLENBQUNSLE9BQU9PLGFBQWEsQ0FBQzBCLFFBQVEsQ0FBQ0YsT0FBTztZQUMxQyx5Q0FBeUM7WUFDekMsSUFBSUEsU0FBUyxPQUFPQyxhQUFhO1lBRWpDLDJCQUEyQjtZQUMzQixJQUFJaEMsT0FBT0ssT0FBTyxLQUFLUyxXQUFXO2dCQUNoQ2QsT0FBT0ssT0FBTyxHQUFHVSxLQUFLQyxHQUFHLEtBQUtoQixPQUFPSSxRQUFRO1lBQy9DO1lBRUFKLE9BQU9DLGVBQWUsSUFBSTtZQUMxQkQsT0FBT1csTUFBTSxDQUFDZ0IsSUFBSSxDQUFDLENBQUMsaUZBQWlGLEVBQUUzQixPQUFPQyxlQUFlLENBQUMsQ0FBQztRQUNqSTtJQUNGO0lBRUEsT0FBT0Q7QUFDVCJ9
|