@discordeno/rest 19.0.0-next.c485f89 → 19.0.0-next.c56bb06

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (48) hide show
  1. package/dist/cjs/index.cjs +25 -0
  2. package/dist/cjs/invalidBucket.cjs +86 -0
  3. package/dist/cjs/manager.cjs +1345 -0
  4. package/dist/cjs/queue.cjs +167 -0
  5. package/dist/cjs/routes.cjs +535 -0
  6. package/dist/cjs/types.cjs +6 -0
  7. package/dist/cjs/typings/routes.cjs +6 -0
  8. package/dist/esm/index.js +8 -0
  9. package/dist/esm/invalidBucket.js +82 -0
  10. package/dist/esm/manager.js +1303 -0
  11. package/dist/esm/queue.js +157 -0
  12. package/dist/esm/routes.js +525 -0
  13. package/dist/esm/types.js +3 -0
  14. package/dist/esm/typings/routes.js +3 -0
  15. package/dist/{index.d.ts → types/index.d.ts} +1 -0
  16. package/dist/types/index.d.ts.map +1 -0
  17. package/dist/{invalidBucket.d.ts → types/invalidBucket.d.ts} +6 -7
  18. package/dist/types/invalidBucket.d.ts.map +1 -0
  19. package/dist/types/manager.d.ts +12 -0
  20. package/dist/types/manager.d.ts.map +1 -0
  21. package/dist/{queue.d.ts → types/queue.d.ts} +5 -0
  22. package/dist/types/queue.d.ts.map +1 -0
  23. package/dist/types/routes.d.ts +3 -0
  24. package/dist/types/routes.d.ts.map +1 -0
  25. package/dist/{types.d.ts → types/types.d.ts} +483 -217
  26. package/dist/types/types.d.ts.map +1 -0
  27. package/dist/{typings → types/typings}/routes.d.ts +24 -6
  28. package/dist/types/typings/routes.d.ts.map +1 -0
  29. package/package.json +28 -23
  30. package/dist/index.d.ts.map +0 -1
  31. package/dist/index.js +0 -7
  32. package/dist/index.js.map +0 -1
  33. package/dist/invalidBucket.d.ts.map +0 -1
  34. package/dist/invalidBucket.js +0 -84
  35. package/dist/invalidBucket.js.map +0 -1
  36. package/dist/manager.d.ts +0 -3
  37. package/dist/manager.d.ts.map +0 -1
  38. package/dist/manager.js +0 -1417
  39. package/dist/manager.js.map +0 -1
  40. package/dist/queue.d.ts.map +0 -1
  41. package/dist/queue.js +0 -153
  42. package/dist/queue.js.map +0 -1
  43. package/dist/types.d.ts.map +0 -1
  44. package/dist/types.js +0 -3
  45. package/dist/types.js.map +0 -1
  46. package/dist/typings/routes.d.ts.map +0 -1
  47. package/dist/typings/routes.js +0 -3
  48. package/dist/typings/routes.js.map +0 -1
@@ -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,86 @@
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
+ waiting: [],
27
+ requestsAllowed: function() {
28
+ if (bucket.resetAt !== undefined && Date.now() >= bucket.resetAt) {
29
+ bucket.invalidRequests = 0;
30
+ bucket.resetAt = Date.now() + bucket.interval;
31
+ }
32
+ return bucket.max - bucket.invalidRequests - bucket.activeRequests - bucket.safety;
33
+ },
34
+ isRequestAllowed: function() {
35
+ return bucket.requestsAllowed() > 0;
36
+ },
37
+ waitUntilRequestAvailable: async function() {
38
+ // eslint-disable-next-line no-async-promise-executor
39
+ return await new Promise(async (resolve)=>{
40
+ // If whatever amount of requests is left is more than the safety margin, allow the request
41
+ if (bucket.isRequestAllowed()) {
42
+ bucket.activeRequests += 1;
43
+ resolve();
44
+ } else {
45
+ bucket.waiting.push(resolve);
46
+ await bucket.processWaiting();
47
+ }
48
+ });
49
+ },
50
+ processWaiting: async function() {
51
+ // If already processing, that loop will handle all waiting requests.
52
+ if (bucket.processing) return;
53
+ // Mark as processing so other loops don't start
54
+ bucket.processing = true;
55
+ while(bucket.waiting.length > 0){
56
+ _utils.logger.info(`[InvalidBucket] processing waiting queue while loop ran with ${bucket.waiting.length} pending requests to be made. ${JSON.stringify(bucket)}`);
57
+ if (!bucket.isRequestAllowed() && bucket.resetAt !== undefined) {
58
+ _utils.logger.warn(`[InvalidBucket] processing waiting queue is now paused until more requests are available. ${bucket.waiting.length} pending requests. ${JSON.stringify(bucket)}`);
59
+ await (0, _utils.delay)(bucket.resetAt - Date.now());
60
+ }
61
+ bucket.activeRequests += 1;
62
+ // Resolve the next item in the queue
63
+ bucket.waiting.shift()?.();
64
+ }
65
+ // Mark as false so next pending request can be triggered by new loop.
66
+ bucket.processing = false;
67
+ },
68
+ handleCompletedRequest: function(code, sharedScope) {
69
+ // Since request is complete, we can remove one from requested.
70
+ bucket.activeRequests -= 1;
71
+ // Since it is as a valid request, we don't need to do anything
72
+ if (!bucket.errorStatuses.includes(code)) return;
73
+ // Shared scope is not considered invalid
74
+ if (code === 429 && sharedScope) return;
75
+ // INVALID REQUEST WAS MADE
76
+ if (bucket.resetAt === undefined) {
77
+ bucket.resetAt = Date.now() + bucket.interval;
78
+ }
79
+ bucket.invalidRequests += 1;
80
+ _utils.logger.warn(`[InvalidBucket] an invalid request was made. Increasing invalidRequests count to ${bucket.invalidRequests}`);
81
+ }
82
+ };
83
+ return bucket;
84
+ }
85
+
86
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbnZhbGlkQnVja2V0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGRlbGF5LCBsb2dnZXIgfSBmcm9tICdAZGlzY29yZGVuby91dGlscydcblxuLyoqXG4gKiBBIGludmFsaWQgcmVxdWVzdCBidWNrZXQgaXMgdXNlZCBpbiBhIHNpbWlsYXIgbWFubmVyIGFzIGEgbGVha3kgYnVja2V0IGJ1dCBhIGludmFsaWQgcmVxdWVzdCBidWNrZXQgY2FuIGJlIHJlZmlsbGVkIGFzIG5lZWRlZC5cbiAqIEl0J3MgcHVycG9zZSBpcyB0byBtYWtlIHN1cmUgdGhlIGJvdCBkb2VzIG5vdCBoaXQgdGhlIGxpbWl0IHRvIGdldHRpbmcgYSAxIGhyIGJhbi5cbiAqXG4gKiBAcGFyYW0gb3B0aW9ucyBUaGUgb3B0aW9ucyB1c2VkIHRvIGNvbmZpZ3VyZSB0aGlzIGJ1Y2tldC5cbiAqIEByZXR1cm5zIFJlZmlsbGluZ0J1Y2tldFxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlSW52YWxpZFJlcXVlc3RCdWNrZXQob3B0aW9uczogSW52YWxpZFJlcXVlc3RCdWNrZXRPcHRpb25zKTogSW52YWxpZFJlcXVlc3RCdWNrZXQge1xuICBjb25zdCBidWNrZXQ6IEludmFsaWRSZXF1ZXN0QnVja2V0ID0ge1xuICAgIGludmFsaWRSZXF1ZXN0czogb3B0aW9ucy5jdXJyZW50ID8/IDAsXG4gICAgbWF4OiBvcHRpb25zLm1heCA/PyAxMDAwMCxcbiAgICBpbnRlcnZhbDogb3B0aW9ucy5pbnRlcnZhbCA/PyA2MDBfMDAwLCAvLyAxMCBtaW51dGVzXG4gICAgcmVzZXRBdDogb3B0aW9ucy5yZXNldEF0LFxuICAgIHNhZmV0eTogb3B0aW9ucy5zYWZldHkgPz8gMSxcbiAgICBlcnJvclN0YXR1c2VzOiBvcHRpb25zLmVycm9yU3RhdHVzZXMgPz8gWzQwMSwgNDAzLCA0MjldLFxuICAgIGFjdGl2ZVJlcXVlc3RzOiBvcHRpb25zLnJlcXVlc3RlZCA/PyAwLFxuICAgIHByb2Nlc3Npbmc6IGZhbHNlLFxuXG4gICAgd2FpdGluZzogW10sXG5cbiAgICByZXF1ZXN0c0FsbG93ZWQ6IGZ1bmN0aW9uICgpIHtcbiAgICAgIGlmIChidWNrZXQucmVzZXRBdCAhPT0gdW5kZWZpbmVkICYmIERhdGUubm93KCkgPj0gYnVja2V0LnJlc2V0QXQpIHtcbiAgICAgICAgYnVja2V0LmludmFsaWRSZXF1ZXN0cyA9IDBcbiAgICAgICAgYnVja2V0LnJlc2V0QXQgPSBEYXRlLm5vdygpICsgYnVja2V0LmludGVydmFsXG4gICAgICB9XG5cbiAgICAgIHJldHVybiBidWNrZXQubWF4IC0gYnVja2V0LmludmFsaWRSZXF1ZXN0cyAtIGJ1Y2tldC5hY3RpdmVSZXF1ZXN0cyAtIGJ1Y2tldC5zYWZldHlcbiAgICB9LFxuXG4gICAgaXNSZXF1ZXN0QWxsb3dlZDogZnVuY3Rpb24gKCkge1xuICAgICAgcmV0dXJuIGJ1Y2tldC5yZXF1ZXN0c0FsbG93ZWQoKSA+IDBcbiAgICB9LFxuXG4gICAgd2FpdFVudGlsUmVxdWVzdEF2YWlsYWJsZTogYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWFzeW5jLXByb21pc2UtZXhlY3V0b3JcbiAgICAgIHJldHVybiBhd2FpdCBuZXcgUHJvbWlzZShhc3luYyAocmVzb2x2ZSkgPT4ge1xuICAgICAgICAvLyBJZiB3aGF0ZXZlciBhbW91bnQgb2YgcmVxdWVzdHMgaXMgbGVmdCBpcyBtb3JlIHRoYW4gdGhlIHNhZmV0eSBtYXJnaW4sIGFsbG93IHRoZSByZXF1ZXN0XG4gICAgICAgIGlmIChidWNrZXQuaXNSZXF1ZXN0QWxsb3dlZCgpKSB7XG4gICAgICAgICAgYnVja2V0LmFjdGl2ZVJlcXVlc3RzICs9IDFcbiAgICAgICAgICByZXNvbHZlKClcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBidWNrZXQud2FpdGluZy5wdXNoKHJlc29sdmUpXG4gICAgICAgICAgYXdhaXQgYnVja2V0LnByb2Nlc3NXYWl0aW5nKClcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICB9LFxuXG4gICAgcHJvY2Vzc1dhaXRpbmc6IGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICAgIC8vIElmIGFscmVhZHkgcHJvY2Vzc2luZywgdGhhdCBsb29wIHdpbGwgaGFuZGxlIGFsbCB3YWl0aW5nIHJlcXVlc3RzLlxuICAgICAgaWYgKGJ1Y2tldC5wcm9jZXNzaW5nKSByZXR1cm5cblxuICAgICAgLy8gTWFyayBhcyBwcm9jZXNzaW5nIHNvIG90aGVyIGxvb3BzIGRvbid0IHN0YXJ0XG4gICAgICBidWNrZXQucHJvY2Vzc2luZyA9IHRydWVcblxuICAgICAgd2hpbGUgKGJ1Y2tldC53YWl0aW5nLmxlbmd0aCA+IDApIHtcbiAgICAgICAgbG9nZ2VyLmluZm8oXG4gICAgICAgICAgYFtJbnZhbGlkQnVja2V0XSBwcm9jZXNzaW5nIHdhaXRpbmcgcXVldWUgd2hpbGUgbG9vcCByYW4gd2l0aCAke2J1Y2tldC53YWl0aW5nLmxlbmd0aH0gcGVuZGluZyByZXF1ZXN0cyB0byBiZSBtYWRlLiAke0pTT04uc3RyaW5naWZ5KFxuICAgICAgICAgICAgYnVja2V0LFxuICAgICAgICAgICl9YCxcbiAgICAgICAgKVxuXG4gICAgICAgIGlmICghYnVja2V0LmlzUmVxdWVzdEFsbG93ZWQoKSAmJiBidWNrZXQucmVzZXRBdCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgbG9nZ2VyLndhcm4oXG4gICAgICAgICAgICBgW0ludmFsaWRCdWNrZXRdIHByb2Nlc3Npbmcgd2FpdGluZyBxdWV1ZSBpcyBub3cgcGF1c2VkIHVudGlsIG1vcmUgcmVxdWVzdHMgYXJlIGF2YWlsYWJsZS4gJHtcbiAgICAgICAgICAgICAgYnVja2V0LndhaXRpbmcubGVuZ3RoXG4gICAgICAgICAgICB9IHBlbmRpbmcgcmVxdWVzdHMuICR7SlNPTi5zdHJpbmdpZnkoYnVja2V0KX1gLFxuICAgICAgICAgIClcbiAgICAgICAgICBhd2FpdCBkZWxheShidWNrZXQucmVzZXRBdCAtIERhdGUubm93KCkpXG4gICAgICAgIH1cblxuICAgICAgICBidWNrZXQuYWN0aXZlUmVxdWVzdHMgKz0gMVxuICAgICAgICAvLyBSZXNvbHZlIHRoZSBuZXh0IGl0ZW0gaW4gdGhlIHF1ZXVlXG4gICAgICAgIGJ1Y2tldC53YWl0aW5nLnNoaWZ0KCk/LigpXG4gICAgICB9XG5cbiAgICAgIC8vIE1hcmsgYXMgZmFsc2Ugc28gbmV4dCBwZW5kaW5nIHJlcXVlc3QgY2FuIGJlIHRyaWdnZXJlZCBieSBuZXcgbG9vcC5cbiAgICAgIGJ1Y2tldC5wcm9jZXNzaW5nID0gZmFsc2VcbiAgICB9LFxuXG4gICAgaGFuZGxlQ29tcGxldGVkUmVxdWVzdDogZnVuY3Rpb24gKGNvZGUsIHNoYXJlZFNjb3BlKSB7XG4gICAgICAvLyBTaW5jZSByZXF1ZXN0IGlzIGNvbXBsZXRlLCB3ZSBjYW4gcmVtb3ZlIG9uZSBmcm9tIHJlcXVlc3RlZC5cbiAgICAgIGJ1Y2tldC5hY3RpdmVSZXF1ZXN0cyAtPSAxXG4gICAgICAvLyBTaW5jZSBpdCBpcyBhcyBhIHZhbGlkIHJlcXVlc3QsIHdlIGRvbid0IG5lZWQgdG8gZG8gYW55dGhpbmdcbiAgICAgIGlmICghYnVja2V0LmVycm9yU3RhdHVzZXMuaW5jbHVkZXMoY29kZSkpIHJldHVyblxuICAgICAgLy8gU2hhcmVkIHNjb3BlIGlzIG5vdCBjb25zaWRlcmVkIGludmFsaWRcbiAgICAgIGlmIChjb2RlID09PSA0MjkgJiYgc2hhcmVkU2NvcGUpIHJldHVyblxuXG4gICAgICAvLyBJTlZBTElEIFJFUVVFU1QgV0FTIE1BREVcbiAgICAgIGlmIChidWNrZXQucmVzZXRBdCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIGJ1Y2tldC5yZXNldEF0ID0gRGF0ZS5ub3coKSArIGJ1Y2tldC5pbnRlcnZhbFxuICAgICAgfVxuXG4gICAgICBidWNrZXQuaW52YWxpZFJlcXVlc3RzICs9IDFcbiAgICAgIGxvZ2dlci53YXJuKGBbSW52YWxpZEJ1Y2tldF0gYW4gaW52YWxpZCByZXF1ZXN0IHdhcyBtYWRlLiBJbmNyZWFzaW5nIGludmFsaWRSZXF1ZXN0cyBjb3VudCB0byAke2J1Y2tldC5pbnZhbGlkUmVxdWVzdHN9YClcbiAgICB9LFxuICB9XG5cbiAgcmV0dXJuIGJ1Y2tldFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEludmFsaWRSZXF1ZXN0QnVja2V0T3B0aW9ucyB7XG4gIC8qKiBjdXJyZW50IGludmFsaWQgYW1vdW50ICovXG4gIGN1cnJlbnQ/OiBudW1iZXJcbiAgLyoqIG1heCBpbnZhbGlkIHJlcXVlc3RzIGFsbG93ZWQgdW50aWwgYmFuLiBEZWZhdWx0cyB0byAxMCwwMDAgKi9cbiAgbWF4PzogbnVtYmVyXG4gIC8qKiBUaGUgdGltZSB0aGF0IGRpc2NvcmQgYWxsb3dzIHRvIG1ha2UgdGhlIG1heCBudW1iZXIgb2YgaW52YWxpZCByZXF1ZXN0cy4gRGVmYXVsdHMgdG8gMTAgbWludXRlcyAqL1xuICBpbnRlcnZhbD86IG51bWJlclxuICAvKiogV2hlbiB0aGUgdGltZW91dCBmb3IgdGhlIGJ1Y2tldCBoYXMgc3RhcnRlZCBhdC4gKi9cbiAgcmVzZXRBdD86IG51bWJlclxuICAvKiogaG93IHNhZmUgdG8gYmUgZnJvbSBtYXguIERlZmF1bHRzIHRvIDEgKi9cbiAgc2FmZXR5PzogbnVtYmVyXG4gIC8qKiBUaGUgcmVxdWVzdCBzdGF0dXNlcyB0aGF0IGNvdW50IGFzIGFuIGludmFsaWQgcmVxdWVzdC4gKi9cbiAgZXJyb3JTdGF0dXNlcz86IG51bWJlcltdXG4gIC8qKiBUaGUgYW1vdW50IG9mIHJlcXVlc3RzIHRoYXQgd2VyZSByZXF1ZXN0ZWQgZnJvbSB0aGlzIGJ1Y2tldC4gKi9cbiAgcmVxdWVzdGVkPzogbnVtYmVyXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW52YWxpZFJlcXVlc3RCdWNrZXQge1xuICAvKiogY3VycmVudCBpbnZhbGlkIGFtb3VudCAqL1xuICBpbnZhbGlkUmVxdWVzdHM6IG51bWJlclxuICAvKiogbWF4IGludmFsaWQgcmVxdWVzdHMgYWxsb3dlZCB1bnRpbCBiYW4uIERlZmF1bHRzIHRvIDEwLDAwMCAqL1xuICBtYXg6IG51bWJlclxuICAvKiogVGhlIHRpbWUgdGhhdCBkaXNjb3JkIGFsbG93cyB0byBtYWtlIHRoZSBtYXggbnVtYmVyIG9mIGludmFsaWQgcmVxdWVzdHMuIERlZmF1bHRzIHRvIDEwIG1pbnV0ZXMgKi9cbiAgaW50ZXJ2YWw6IG51bWJlclxuICAvKiogV2hlbiB0aGUgdGltZW91dCBmb3IgdGhpcyBidWNrZXQgaGFzIHN0YXJ0ZWQgYXQuICovXG4gIHJlc2V0QXQ6IG51bWJlciB8IHVuZGVmaW5lZFxuICAvKiogaG93IHNhZmUgdG8gYmUgZnJvbSBtYXguIERlZmF1bHRzIHRvIDEgKi9cbiAgc2FmZXR5OiBudW1iZXJcbiAgLyoqIFRoZSByZXF1ZXN0IHN0YXR1c2VzIHRoYXQgY291bnQgYXMgYW4gaW52YWxpZCByZXF1ZXN0LiAqL1xuICBlcnJvclN0YXR1c2VzOiBudW1iZXJbXVxuICAvKiogVGhlIGFtb3VudCBvZiByZXF1ZXN0cyB0aGF0IHdlcmUgcmVxdWVzdGVkIGZyb20gdGhpcyBidWNrZXQuICovXG4gIGFjdGl2ZVJlcXVlc3RzOiBudW1iZXJcbiAgLyoqIFRoZSByZXF1ZXN0cyB0aGF0IGFyZSBjdXJyZW50bHkgcGVuZGluZy4gKi9cbiAgd2FpdGluZzogQXJyYXk8KHZhbHVlOiB2b2lkIHwgUHJvbWlzZUxpa2U8dm9pZD4pID0+IHZvaWQ+XG4gIC8qKiBXaGV0aGVyIG9yIG5vdCB0aGUgd2FpdGluZyBxdWV1ZSBpcyBhbHJlYWR5IHByb2Nlc3NpbmcuICovXG4gIHByb2Nlc3Npbmc6IGJvb2xlYW5cblxuICAvKiogR2l2ZXMgdGhlIG51bWJlciBvZiByZXF1ZXN0cyB0aGF0IGFyZSBjdXJyZW50bHkgYWxsb3dlZC4gKi9cbiAgcmVxdWVzdHNBbGxvd2VkOiAoKSA9PiBudW1iZXJcbiAgLyoqIENoZWNrcyBpZiBhIHJlcXVlc3QgaXMgYWxsb3dlZCBhdCB0aGlzIHRpbWUuICovXG4gIGlzUmVxdWVzdEFsbG93ZWQ6ICgpID0+IGJvb2xlYW5cbiAgLyoqIFdhaXRzIHVudGlsIGEgcmVxdWVzdCBpcyBhdmFpbGFibGUgKi9cbiAgd2FpdFVudGlsUmVxdWVzdEF2YWlsYWJsZTogKCkgPT4gUHJvbWlzZTx2b2lkPlxuICAvKiogQmVnaW5zIHByb2Nlc3NpbmcgdGhlIHdhaXRpbmcgcXVldWUgb2YgcmVxdWVzdHMuICovXG4gIHByb2Nlc3NXYWl0aW5nOiAoKSA9PiBQcm9taXNlPHZvaWQ+XG4gIC8qKiBIYW5kbGVyIGZvciB3aGVuZXZlciBhIHJlcXVlc3QgaXMgdmFsaWRhdGVkLiBUaGlzIHNob3VsZCB1cGRhdGUgdGhlIHJlcXVlc3RlZCB2YWx1ZXMgb3IgdHJpZ2dlciBhbnkgb3RoZXIgbmVjZXNzYXJ5IHN0dWZmLiAqL1xuICBoYW5kbGVDb21wbGV0ZWRSZXF1ZXN0OiAoY29kZTogbnVtYmVyLCBzaGFyZWRTY29wZTogYm9vbGVhbikgPT4gdm9pZFxufVxuIl0sIm5hbWVzIjpbImNyZWF0ZUludmFsaWRSZXF1ZXN0QnVja2V0Iiwib3B0aW9ucyIsImJ1Y2tldCIsImludmFsaWRSZXF1ZXN0cyIsImN1cnJlbnQiLCJtYXgiLCJpbnRlcnZhbCIsInJlc2V0QXQiLCJzYWZldHkiLCJlcnJvclN0YXR1c2VzIiwiYWN0aXZlUmVxdWVzdHMiLCJyZXF1ZXN0ZWQiLCJwcm9jZXNzaW5nIiwid2FpdGluZyIsInJlcXVlc3RzQWxsb3dlZCIsInVuZGVmaW5lZCIsIkRhdGUiLCJub3ciLCJpc1JlcXVlc3RBbGxvd2VkIiwid2FpdFVudGlsUmVxdWVzdEF2YWlsYWJsZSIsIlByb21pc2UiLCJyZXNvbHZlIiwicHVzaCIsInByb2Nlc3NXYWl0aW5nIiwibGVuZ3RoIiwibG9nZ2VyIiwiaW5mbyIsIkpTT04iLCJzdHJpbmdpZnkiLCJ3YXJuIiwiZGVsYXkiLCJzaGlmdCIsImhhbmRsZUNvbXBsZXRlZFJlcXVlc3QiLCJjb2RlIiwic2hhcmVkU2NvcGUiLCJpbmNsdWRlcyJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFTZ0JB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