@gomomento/sdk-core 1.65.4 → 1.67.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/dist/src/clients/ICacheClient.d.ts +4 -1
- package/dist/src/clients/ICacheClient.js +1 -1
- package/dist/src/clients/IMomentoCache.d.ts +4 -1
- package/dist/src/clients/IMomentoCache.js +1 -1
- package/dist/src/clients/IVectorIndexClient.d.ts +1 -1
- package/dist/src/clients/IVectorIndexClient.js +1 -1
- package/dist/src/index.d.ts +3 -1
- package/dist/src/index.js +7 -3
- package/dist/src/internal/clients/cache/AbstractCacheClient.d.ts +26 -2
- package/dist/src/internal/clients/cache/AbstractCacheClient.js +30 -1
- package/dist/src/internal/clients/cache/IDataClient.d.ts +3 -1
- package/dist/src/internal/clients/cache/IDataClient.js +1 -1
- package/dist/src/internal/clients/cache/momento-cache.d.ts +4 -1
- package/dist/src/internal/clients/cache/momento-cache.js +7 -1
- package/dist/src/internal/clients/vector/AbstractVectorIndexClient.d.ts +4 -3
- package/dist/src/internal/clients/vector/AbstractVectorIndexClient.js +3 -2
- package/dist/src/internal/clients/vector/IVectorIndexDataClient.d.ts +2 -1
- package/dist/src/internal/clients/vector/IVectorIndexDataClient.js +1 -1
- package/dist/src/internal/utils/validators.d.ts +1 -0
- package/dist/src/internal/utils/validators.js +12 -4
- package/dist/src/messages/responses/cache-batch-get.d.ts +116 -0
- package/dist/src/messages/responses/cache-batch-get.js +162 -0
- package/dist/src/messages/responses/cache-batch-set.d.ts +73 -0
- package/dist/src/messages/responses/cache-batch-set.js +71 -0
- package/dist/src/utils/collection-ttl.js +5 -1
- package/package.json +1 -1
@@ -0,0 +1,162 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Error = exports.Success = exports.Response = void 0;
|
4
|
+
const response_base_1 = require("./response-base");
|
5
|
+
const TEXT_DECODER = new TextDecoder();
|
6
|
+
/**
|
7
|
+
* Parent response type for a cache get batch request. The
|
8
|
+
* response object is resolved to a type-safe object of one of
|
9
|
+
* the following subtypes:
|
10
|
+
*
|
11
|
+
* - {Success}
|
12
|
+
* - {Error}
|
13
|
+
*
|
14
|
+
* `instanceof` type guards can be used to operate on the appropriate subtype.
|
15
|
+
* @example
|
16
|
+
* For example:
|
17
|
+
* ```
|
18
|
+
* if (response instanceof BatchGet.Error) {
|
19
|
+
* // Handle error as appropriate. The compiler will smart-cast `response` to type
|
20
|
+
* // `BatchGet.Error` in this block, so you will have access to the properties
|
21
|
+
* // of the Error class; e.g. `response.errorCode()`.
|
22
|
+
* }
|
23
|
+
* ```
|
24
|
+
*/
|
25
|
+
class Response extends response_base_1.ResponseBase {
|
26
|
+
values() {
|
27
|
+
if (this instanceof Success) {
|
28
|
+
return this.values();
|
29
|
+
}
|
30
|
+
return undefined;
|
31
|
+
}
|
32
|
+
results() {
|
33
|
+
if (this instanceof Success) {
|
34
|
+
return this.results();
|
35
|
+
}
|
36
|
+
return undefined;
|
37
|
+
}
|
38
|
+
}
|
39
|
+
exports.Response = Response;
|
40
|
+
class _Success extends Response {
|
41
|
+
constructor(items, keys) {
|
42
|
+
super();
|
43
|
+
this.items = items;
|
44
|
+
this.keys = keys;
|
45
|
+
}
|
46
|
+
/**
|
47
|
+
* Returns the status for each request in the batch as a list of CacheGet.Response objects.
|
48
|
+
* @returns {CacheGet.Response[]}
|
49
|
+
*/
|
50
|
+
results() {
|
51
|
+
return this.items;
|
52
|
+
}
|
53
|
+
/**
|
54
|
+
* Returns the data as a Record whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
55
|
+
* This can be used in most places where an Object is desired. This is a convenience alias for
|
56
|
+
* {valueRecordStringString}.
|
57
|
+
* @returns {Record<string, string>}
|
58
|
+
*/
|
59
|
+
values() {
|
60
|
+
return this.valuesRecordStringString();
|
61
|
+
}
|
62
|
+
/**
|
63
|
+
* Returns the data as a Record whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
64
|
+
* This can be used in most places where an Object is desired. This is a convenience alias for
|
65
|
+
* {valueRecordStringString}.
|
66
|
+
* @returns {Record<string, string>}
|
67
|
+
*/
|
68
|
+
valuesRecord() {
|
69
|
+
return this.valuesRecordStringString();
|
70
|
+
}
|
71
|
+
/**
|
72
|
+
* Returns the data as a Record whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
73
|
+
* This can be used in most places where an Object is desired.
|
74
|
+
* @returns {Record<string, string>}
|
75
|
+
*/
|
76
|
+
valuesRecordStringString() {
|
77
|
+
return this.items.reduce((acc, item, index) => {
|
78
|
+
if (item.value() !== undefined) {
|
79
|
+
acc[TEXT_DECODER.decode(this.keys[index])] = item.valueString();
|
80
|
+
}
|
81
|
+
return acc;
|
82
|
+
}, {});
|
83
|
+
}
|
84
|
+
/**
|
85
|
+
* Returns the data as a Record whose keys are utf-8 strings, decoded from the underlying byte array, and whose
|
86
|
+
* values are byte arrays. This can be used in most places where an Object is desired.
|
87
|
+
* @returns {Record<string, Uint8Array>}
|
88
|
+
*/
|
89
|
+
valuesRecordStringUint8Array() {
|
90
|
+
return this.items.reduce((acc, item, index) => {
|
91
|
+
if (item.value() !== undefined) {
|
92
|
+
acc[TEXT_DECODER.decode(this.keys[index])] = item.valueUint8Array();
|
93
|
+
}
|
94
|
+
return acc;
|
95
|
+
}, {});
|
96
|
+
}
|
97
|
+
/**
|
98
|
+
* Returns the data as a Map whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
99
|
+
* This is a convenience alias for {valueMapStringString}.
|
100
|
+
* @returns {Map<string, string>}
|
101
|
+
*/
|
102
|
+
valuesMap() {
|
103
|
+
return this.valuesMapStringString();
|
104
|
+
}
|
105
|
+
/**
|
106
|
+
* Returns the data as a Map whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
107
|
+
* @returns {Map<string, string>}
|
108
|
+
*/
|
109
|
+
valuesMapStringString() {
|
110
|
+
return this.items.reduce((acc, item, index) => {
|
111
|
+
if (item.value() !== undefined) {
|
112
|
+
acc.set(TEXT_DECODER.decode(this.keys[index]), item.valueString());
|
113
|
+
}
|
114
|
+
return acc;
|
115
|
+
}, new Map());
|
116
|
+
}
|
117
|
+
/**
|
118
|
+
* Returns the data as a Map whose keys and values are byte arrays.
|
119
|
+
* @returns {Map<Uint8Array, Uint8Array>}
|
120
|
+
*/
|
121
|
+
valuesMapUint8ArrayUint8Array() {
|
122
|
+
return this.items.reduce((acc, item, index) => {
|
123
|
+
if (item.value() !== undefined) {
|
124
|
+
acc.set(this.keys[index], item.valueUint8Array());
|
125
|
+
}
|
126
|
+
return acc;
|
127
|
+
}, new Map());
|
128
|
+
}
|
129
|
+
toString() {
|
130
|
+
const display = this.results()
|
131
|
+
.map(result => result.toString())
|
132
|
+
.toString();
|
133
|
+
return `${super.toString()}: ${display}`;
|
134
|
+
}
|
135
|
+
}
|
136
|
+
/**
|
137
|
+
* Indicates that the requested data was successfully retrieved from the cache. Provides
|
138
|
+
* `value*` accessors to retrieve the data in the appropriate format.
|
139
|
+
*/
|
140
|
+
class Success extends (0, response_base_1.ResponseSuccess)(_Success) {
|
141
|
+
}
|
142
|
+
exports.Success = Success;
|
143
|
+
class _Error extends Response {
|
144
|
+
constructor(_innerException) {
|
145
|
+
super();
|
146
|
+
this._innerException = _innerException;
|
147
|
+
}
|
148
|
+
}
|
149
|
+
/**
|
150
|
+
* Indicates that an error occurred during the cache get request.
|
151
|
+
*
|
152
|
+
* This response object includes the following fields that you can use to determine
|
153
|
+
* how you would like to handle the error:
|
154
|
+
*
|
155
|
+
* - `errorCode()` - a unique Momento error code indicating the type of error that occurred.
|
156
|
+
* - `message()` - a human-readable description of the error
|
157
|
+
* - `innerException()` - the original error that caused the failure; can be re-thrown.
|
158
|
+
*/
|
159
|
+
class Error extends (0, response_base_1.ResponseError)(_Error) {
|
160
|
+
}
|
161
|
+
exports.Error = Error;
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cache-batch-get.js","sourceRoot":"","sources":["../../../../src/messages/responses/cache-batch-get.ts"],"names":[],"mappings":"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","sourcesContent":["import {SdkError} from '../../errors';\nimport {ResponseBase, ResponseError, ResponseSuccess} from './response-base';\nimport {CacheGet} from '../..';\n\nconst TEXT_DECODER = new TextDecoder();\n\n/**\n * Parent response type for a cache get batch request.  The\n * response object is resolved to a type-safe object of one of\n * the following subtypes:\n *\n * - {Success}\n * - {Error}\n *\n * `instanceof` type guards can be used to operate on the appropriate subtype.\n * @example\n * For example:\n * ```\n * if (response instanceof BatchGet.Error) {\n *   // Handle error as appropriate.  The compiler will smart-cast `response` to type\n *   // `BatchGet.Error` in this block, so you will have access to the properties\n *   // of the Error class; e.g. `response.errorCode()`.\n * }\n * ```\n */\nexport abstract class Response extends ResponseBase {\n  public values(): Record<string, string> | undefined {\n    if (this instanceof Success) {\n      return (this as Success).values();\n    }\n    return undefined;\n  }\n\n  public results(): CacheGet.Response[] | undefined {\n    if (this instanceof Success) {\n      return (this as Success).results();\n    }\n    return undefined;\n  }\n}\n\nclass _Success extends Response {\n  private readonly items: CacheGet.Response[];\n  private readonly keys: Uint8Array[];\n\n  constructor(items: CacheGet.Response[], keys: Uint8Array[]) {\n    super();\n    this.items = items;\n    this.keys = keys;\n  }\n\n  /**\n   * Returns the status for each request in the batch as a list of CacheGet.Response objects.\n   * @returns {CacheGet.Response[]}\n   */\n  public results(): CacheGet.Response[] {\n    return this.items;\n  }\n\n  /**\n   * Returns the data as a Record whose keys and values are utf-8 strings, decoded from the underlying byte arrays.\n   * This can be used in most places where an Object is desired.  This is a convenience alias for\n   * {valueRecordStringString}.\n   * @returns {Record<string, string>}\n   */\n  public values(): Record<string, string> {\n    return this.valuesRecordStringString();\n  }\n\n  /**\n   * Returns the data as a Record whose keys and values are utf-8 strings, decoded from the underlying byte arrays.\n   * This can be used in most places where an Object is desired.  This is a convenience alias for\n   * {valueRecordStringString}.\n   * @returns {Record<string, string>}\n   */\n  public valuesRecord(): Record<string, string> {\n    return this.valuesRecordStringString();\n  }\n\n  /**\n   * Returns the data as a Record whose keys and values are utf-8 strings, decoded from the underlying byte arrays.\n   * This can be used in most places where an Object is desired.\n   * @returns {Record<string, string>}\n   */\n  public valuesRecordStringString(): Record<string, string> {\n    return this.items.reduce<Record<string, string>>((acc, item, index) => {\n      if (item.value() !== undefined) {\n        acc[TEXT_DECODER.decode(this.keys[index])] = (\n          item as CacheGet.Hit\n        ).valueString();\n      }\n      return acc;\n    }, {});\n  }\n\n  /**\n   * Returns the data as a Record whose keys are utf-8 strings, decoded from the underlying byte array, and whose\n   * values are byte arrays.  This can be used in most places where an Object is desired.\n   * @returns {Record<string, Uint8Array>}\n   */\n  public valuesRecordStringUint8Array(): Record<string, Uint8Array> {\n    return this.items.reduce<Record<string, Uint8Array>>((acc, item, index) => {\n      if (item.value() !== undefined) {\n        acc[TEXT_DECODER.decode(this.keys[index])] = (\n          item as CacheGet.Hit\n        ).valueUint8Array();\n      }\n      return acc;\n    }, {});\n  }\n\n  /**\n   * Returns the data as a Map whose keys and values are utf-8 strings, decoded from the underlying byte arrays.\n   * This is a convenience alias for {valueMapStringString}.\n   * @returns {Map<string, string>}\n   */\n  public valuesMap(): Map<string, string> {\n    return this.valuesMapStringString();\n  }\n\n  /**\n   * Returns the data as a Map whose keys and values are utf-8 strings, decoded from the underlying byte arrays.\n   * @returns {Map<string, string>}\n   */\n  public valuesMapStringString(): Map<string, string> {\n    return this.items.reduce((acc, item, index) => {\n      if (item.value() !== undefined) {\n        acc.set(\n          TEXT_DECODER.decode(this.keys[index]),\n          (item as CacheGet.Hit).valueString()\n        );\n      }\n      return acc;\n    }, new Map<string, string>());\n  }\n\n  /**\n   * Returns the data as a Map whose keys and values are byte arrays.\n   * @returns {Map<Uint8Array, Uint8Array>}\n   */\n  public valuesMapUint8ArrayUint8Array(): Map<Uint8Array, Uint8Array> {\n    return this.items.reduce((acc, item, index) => {\n      if (item.value() !== undefined) {\n        acc.set(this.keys[index], (item as CacheGet.Hit).valueUint8Array());\n      }\n      return acc;\n    }, new Map<Uint8Array, Uint8Array>());\n  }\n\n  public override toString(): string {\n    const display = this.results()\n      .map(result => result.toString())\n      .toString();\n    return `${super.toString()}: ${display}`;\n  }\n}\n\n/**\n * Indicates that the requested data was successfully retrieved from the cache.  Provides\n * `value*` accessors to retrieve the data in the appropriate format.\n */\nexport class Success extends ResponseSuccess(_Success) {}\n\nclass _Error extends Response {\n  constructor(protected _innerException: SdkError) {\n    super();\n  }\n}\n\n/**\n * Indicates that an error occurred during the cache get request.\n *\n * This response object includes the following fields that you can use to determine\n * how you would like to handle the error:\n *\n * - `errorCode()` - a unique Momento error code indicating the type of error that occurred.\n * - `message()` - a human-readable description of the error\n * - `innerException()` - the original error that caused the failure; can be re-thrown.\n */\nexport class Error extends ResponseError(_Error) {}\n"]}
|
@@ -0,0 +1,73 @@
|
|
1
|
+
import { CacheSet } from '../..';
|
2
|
+
import { SdkError } from '../../errors';
|
3
|
+
import { ResponseBase } from './response-base';
|
4
|
+
/**
|
5
|
+
* Parent response type for a cache set batch request. The
|
6
|
+
* response object is resolved to a type-safe object of one of
|
7
|
+
* the following subtypes:
|
8
|
+
*
|
9
|
+
* - {Success}
|
10
|
+
* - {Error}
|
11
|
+
*
|
12
|
+
* `instanceof` type guards can be used to operate on the appropriate subtype.
|
13
|
+
* @example
|
14
|
+
* For example:
|
15
|
+
* ```
|
16
|
+
* if (response instanceof SetBatch.Error) {
|
17
|
+
* // Handle error as appropriate. The compiler will smart-cast `response` to type
|
18
|
+
* // `SetBatch.Error` in this block, so you will have access to the properties
|
19
|
+
* // of the Error class; e.g. `response.errorCode()`.
|
20
|
+
* }
|
21
|
+
* ```
|
22
|
+
*/
|
23
|
+
export declare abstract class Response extends ResponseBase {
|
24
|
+
results(): CacheSet.Response[] | undefined;
|
25
|
+
}
|
26
|
+
declare class _Success extends Response {
|
27
|
+
private readonly body;
|
28
|
+
constructor(body: CacheSet.Response[]);
|
29
|
+
/**
|
30
|
+
* Returns the status for each request in the batch as a list of CacheGet.Response objects.
|
31
|
+
* @returns {CacheSet.Response[]}
|
32
|
+
*/
|
33
|
+
results(): CacheSet.Response[];
|
34
|
+
}
|
35
|
+
declare const Success_base: {
|
36
|
+
new (...args: any[]): {
|
37
|
+
readonly is_success: boolean;
|
38
|
+
};
|
39
|
+
} & typeof _Success;
|
40
|
+
/**
|
41
|
+
* Indicates a Successful cache set request.
|
42
|
+
*/
|
43
|
+
export declare class Success extends Success_base {
|
44
|
+
}
|
45
|
+
declare class _Error extends Response {
|
46
|
+
protected _innerException: SdkError;
|
47
|
+
constructor(_innerException: SdkError);
|
48
|
+
}
|
49
|
+
declare const Error_base: {
|
50
|
+
new (...args: any[]): {
|
51
|
+
_innerException: SdkError;
|
52
|
+
message(): string;
|
53
|
+
innerException(): SdkError; /**
|
54
|
+
* Returns the status for each request in the batch as a list of CacheGet.Response objects.
|
55
|
+
* @returns {CacheSet.Response[]}
|
56
|
+
*/
|
57
|
+
errorCode(): import("../..").MomentoErrorCode;
|
58
|
+
toString(): string;
|
59
|
+
};
|
60
|
+
} & typeof _Error;
|
61
|
+
/**
|
62
|
+
* Indicates that an error occurred during the cache set request.
|
63
|
+
*
|
64
|
+
* This response object includes the following fields that you can use to determine
|
65
|
+
* how you would like to handle the error:
|
66
|
+
*
|
67
|
+
* - `errorCode()` - a unique Momento error code indicating the type of error that occurred.
|
68
|
+
* - `message()` - a human-readable description of the error
|
69
|
+
* - `innerException()` - the original error that caused the failure; can be re-thrown.
|
70
|
+
*/
|
71
|
+
export declare class Error extends Error_base {
|
72
|
+
}
|
73
|
+
export {};
|
@@ -0,0 +1,71 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Error = exports.Success = exports.Response = void 0;
|
4
|
+
const response_base_1 = require("./response-base");
|
5
|
+
/**
|
6
|
+
* Parent response type for a cache set batch request. The
|
7
|
+
* response object is resolved to a type-safe object of one of
|
8
|
+
* the following subtypes:
|
9
|
+
*
|
10
|
+
* - {Success}
|
11
|
+
* - {Error}
|
12
|
+
*
|
13
|
+
* `instanceof` type guards can be used to operate on the appropriate subtype.
|
14
|
+
* @example
|
15
|
+
* For example:
|
16
|
+
* ```
|
17
|
+
* if (response instanceof SetBatch.Error) {
|
18
|
+
* // Handle error as appropriate. The compiler will smart-cast `response` to type
|
19
|
+
* // `SetBatch.Error` in this block, so you will have access to the properties
|
20
|
+
* // of the Error class; e.g. `response.errorCode()`.
|
21
|
+
* }
|
22
|
+
* ```
|
23
|
+
*/
|
24
|
+
class Response extends response_base_1.ResponseBase {
|
25
|
+
results() {
|
26
|
+
if (this instanceof Success) {
|
27
|
+
return this.results();
|
28
|
+
}
|
29
|
+
return undefined;
|
30
|
+
}
|
31
|
+
}
|
32
|
+
exports.Response = Response;
|
33
|
+
class _Success extends Response {
|
34
|
+
constructor(body) {
|
35
|
+
super();
|
36
|
+
this.body = body;
|
37
|
+
}
|
38
|
+
/**
|
39
|
+
* Returns the status for each request in the batch as a list of CacheGet.Response objects.
|
40
|
+
* @returns {CacheSet.Response[]}
|
41
|
+
*/
|
42
|
+
results() {
|
43
|
+
return this.body;
|
44
|
+
}
|
45
|
+
}
|
46
|
+
/**
|
47
|
+
* Indicates a Successful cache set request.
|
48
|
+
*/
|
49
|
+
class Success extends (0, response_base_1.ResponseSuccess)(_Success) {
|
50
|
+
}
|
51
|
+
exports.Success = Success;
|
52
|
+
class _Error extends Response {
|
53
|
+
constructor(_innerException) {
|
54
|
+
super();
|
55
|
+
this._innerException = _innerException;
|
56
|
+
}
|
57
|
+
}
|
58
|
+
/**
|
59
|
+
* Indicates that an error occurred during the cache set request.
|
60
|
+
*
|
61
|
+
* This response object includes the following fields that you can use to determine
|
62
|
+
* how you would like to handle the error:
|
63
|
+
*
|
64
|
+
* - `errorCode()` - a unique Momento error code indicating the type of error that occurred.
|
65
|
+
* - `message()` - a human-readable description of the error
|
66
|
+
* - `innerException()` - the original error that caused the failure; can be re-thrown.
|
67
|
+
*/
|
68
|
+
class Error extends (0, response_base_1.ResponseError)(_Error) {
|
69
|
+
}
|
70
|
+
exports.Error = Error;
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FjaGUtYmF0Y2gtc2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL21lc3NhZ2VzL3Jlc3BvbnNlcy9jYWNoZS1iYXRjaC1zZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBRUEsbURBQTZFO0FBRTdFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FrQkc7QUFDSCxNQUFzQixRQUFTLFNBQVEsNEJBQVk7SUFDMUMsT0FBTztRQUNaLElBQUksSUFBSSxZQUFZLE9BQU8sRUFBRTtZQUMzQixPQUFRLElBQWdCLENBQUMsT0FBTyxFQUFFLENBQUM7U0FDcEM7UUFDRCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0NBQ0Y7QUFQRCw0QkFPQztBQUVELE1BQU0sUUFBUyxTQUFRLFFBQVE7SUFFN0IsWUFBWSxJQUF5QjtRQUNuQyxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO0lBQ25CLENBQUM7SUFFRDs7O09BR0c7SUFDSSxPQUFPO1FBQ1osT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25CLENBQUM7Q0FDRjtBQUVEOztHQUVHO0FBQ0gsTUFBYSxPQUFRLFNBQVEsSUFBQSwrQkFBZSxFQUFDLFFBQVEsQ0FBQztDQUFHO0FBQXpELDBCQUF5RDtBQUV6RCxNQUFNLE1BQU8sU0FBUSxRQUFRO0lBQzNCLFlBQXNCLGVBQXlCO1FBQzdDLEtBQUssRUFBRSxDQUFDO1FBRFksb0JBQWUsR0FBZixlQUFlLENBQVU7SUFFL0MsQ0FBQztDQUNGO0FBRUQ7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBYSxLQUFNLFNBQVEsSUFBQSw2QkFBYSxFQUFDLE1BQU0sQ0FBQztDQUFHO0FBQW5ELHNCQUFtRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2FjaGVTZXR9IGZyb20gJy4uLy4uJztcbmltcG9ydCB7U2RrRXJyb3J9IGZyb20gJy4uLy4uL2Vycm9ycyc7XG5pbXBvcnQge1Jlc3BvbnNlQmFzZSwgUmVzcG9uc2VFcnJvciwgUmVzcG9uc2VTdWNjZXNzfSBmcm9tICcuL3Jlc3BvbnNlLWJhc2UnO1xuXG4vKipcbiAqIFBhcmVudCByZXNwb25zZSB0eXBlIGZvciBhIGNhY2hlIHNldCBiYXRjaCByZXF1ZXN0LiAgVGhlXG4gKiByZXNwb25zZSBvYmplY3QgaXMgcmVzb2x2ZWQgdG8gYSB0eXBlLXNhZmUgb2JqZWN0IG9mIG9uZSBvZlxuICogdGhlIGZvbGxvd2luZyBzdWJ0eXBlczpcbiAqXG4gKiAtIHtTdWNjZXNzfVxuICogLSB7RXJyb3J9XG4gKlxuICogYGluc3RhbmNlb2ZgIHR5cGUgZ3VhcmRzIGNhbiBiZSB1c2VkIHRvIG9wZXJhdGUgb24gdGhlIGFwcHJvcHJpYXRlIHN1YnR5cGUuXG4gKiBAZXhhbXBsZVxuICogRm9yIGV4YW1wbGU6XG4gKiBgYGBcbiAqIGlmIChyZXNwb25zZSBpbnN0YW5jZW9mIFNldEJhdGNoLkVycm9yKSB7XG4gKiAgIC8vIEhhbmRsZSBlcnJvciBhcyBhcHByb3ByaWF0ZS4gIFRoZSBjb21waWxlciB3aWxsIHNtYXJ0LWNhc3QgYHJlc3BvbnNlYCB0byB0eXBlXG4gKiAgIC8vIGBTZXRCYXRjaC5FcnJvcmAgaW4gdGhpcyBibG9jaywgc28geW91IHdpbGwgaGF2ZSBhY2Nlc3MgdG8gdGhlIHByb3BlcnRpZXNcbiAqICAgLy8gb2YgdGhlIEVycm9yIGNsYXNzOyBlLmcuIGByZXNwb25zZS5lcnJvckNvZGUoKWAuXG4gKiB9XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFJlc3BvbnNlIGV4dGVuZHMgUmVzcG9uc2VCYXNlIHtcbiAgcHVibGljIHJlc3VsdHMoKTogQ2FjaGVTZXQuUmVzcG9uc2VbXSB8IHVuZGVmaW5lZCB7XG4gICAgaWYgKHRoaXMgaW5zdGFuY2VvZiBTdWNjZXNzKSB7XG4gICAgICByZXR1cm4gKHRoaXMgYXMgU3VjY2VzcykucmVzdWx0cygpO1xuICAgIH1cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG59XG5cbmNsYXNzIF9TdWNjZXNzIGV4dGVuZHMgUmVzcG9uc2Uge1xuICBwcml2YXRlIHJlYWRvbmx5IGJvZHk6IENhY2hlU2V0LlJlc3BvbnNlW107XG4gIGNvbnN0cnVjdG9yKGJvZHk6IENhY2hlU2V0LlJlc3BvbnNlW10pIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMuYm9keSA9IGJvZHk7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgc3RhdHVzIGZvciBlYWNoIHJlcXVlc3QgaW4gdGhlIGJhdGNoIGFzIGEgbGlzdCBvZiBDYWNoZUdldC5SZXNwb25zZSBvYmplY3RzLlxuICAgKiBAcmV0dXJucyB7Q2FjaGVTZXQuUmVzcG9uc2VbXX1cbiAgICovXG4gIHB1YmxpYyByZXN1bHRzKCk6IENhY2hlU2V0LlJlc3BvbnNlW10ge1xuICAgIHJldHVybiB0aGlzLmJvZHk7XG4gIH1cbn1cblxuLyoqXG4gKiBJbmRpY2F0ZXMgYSBTdWNjZXNzZnVsIGNhY2hlIHNldCByZXF1ZXN0LlxuICovXG5leHBvcnQgY2xhc3MgU3VjY2VzcyBleHRlbmRzIFJlc3BvbnNlU3VjY2VzcyhfU3VjY2Vzcykge31cblxuY2xhc3MgX0Vycm9yIGV4dGVuZHMgUmVzcG9uc2Uge1xuICBjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgX2lubmVyRXhjZXB0aW9uOiBTZGtFcnJvcikge1xuICAgIHN1cGVyKCk7XG4gIH1cbn1cblxuLyoqXG4gKiBJbmRpY2F0ZXMgdGhhdCBhbiBlcnJvciBvY2N1cnJlZCBkdXJpbmcgdGhlIGNhY2hlIHNldCByZXF1ZXN0LlxuICpcbiAqIFRoaXMgcmVzcG9uc2Ugb2JqZWN0IGluY2x1ZGVzIHRoZSBmb2xsb3dpbmcgZmllbGRzIHRoYXQgeW91IGNhbiB1c2UgdG8gZGV0ZXJtaW5lXG4gKiBob3cgeW91IHdvdWxkIGxpa2UgdG8gaGFuZGxlIHRoZSBlcnJvcjpcbiAqXG4gKiAtIGBlcnJvckNvZGUoKWAgLSBhIHVuaXF1ZSBNb21lbnRvIGVycm9yIGNvZGUgaW5kaWNhdGluZyB0aGUgdHlwZSBvZiBlcnJvciB0aGF0IG9jY3VycmVkLlxuICogLSBgbWVzc2FnZSgpYCAtIGEgaHVtYW4tcmVhZGFibGUgZGVzY3JpcHRpb24gb2YgdGhlIGVycm9yXG4gKiAtIGBpbm5lckV4Y2VwdGlvbigpYCAtIHRoZSBvcmlnaW5hbCBlcnJvciB0aGF0IGNhdXNlZCB0aGUgZmFpbHVyZTsgY2FuIGJlIHJlLXRocm93bi5cbiAqL1xuZXhwb3J0IGNsYXNzIEVycm9yIGV4dGVuZHMgUmVzcG9uc2VFcnJvcihfRXJyb3IpIHt9XG4iXX0=
|
@@ -1,6 +1,7 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.CollectionTtl = void 0;
|
4
|
+
const utils_1 = require("../internal/utils");
|
4
5
|
/** Represents the desired behavior for managing the TTL on collection
|
5
6
|
* objects (dictionaries, lists, sets) in your cache.
|
6
7
|
*
|
@@ -26,6 +27,9 @@ class CollectionTtl {
|
|
26
27
|
* @param {boolean} [refreshTtl=true]
|
27
28
|
*/
|
28
29
|
constructor(ttlSeconds = null, refreshTtl = true) {
|
30
|
+
if (ttlSeconds !== null) {
|
31
|
+
(0, utils_1.validateTtlSeconds)(ttlSeconds);
|
32
|
+
}
|
29
33
|
this._refreshTtl = refreshTtl;
|
30
34
|
this._ttlSeconds = ttlSeconds;
|
31
35
|
}
|
@@ -99,4 +103,4 @@ class CollectionTtl {
|
|
99
103
|
}
|
100
104
|
}
|
101
105
|
exports.CollectionTtl = CollectionTtl;
|
102
|
-
//# sourceMappingURL=data:application/json;base64,
|
106
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi10dGwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvY29sbGVjdGlvbi10dGwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkNBQXFEO0FBRXJEOzs7Ozs7Ozs7Ozs7Ozs7R0FlRztBQUNILE1BQWEsYUFBYTtJQUl4Qjs7Ozs7O09BTUc7SUFDSCxZQUFZLGFBQTRCLElBQUksRUFBRSxVQUFVLEdBQUcsSUFBSTtRQUM3RCxJQUFJLFVBQVUsS0FBSyxJQUFJLEVBQUU7WUFDdkIsSUFBQSwwQkFBa0IsRUFBQyxVQUFVLENBQUMsQ0FBQztTQUNoQztRQUNELElBQUksQ0FBQyxXQUFXLEdBQUcsVUFBVSxDQUFDO1FBQzlCLElBQUksQ0FBQyxXQUFXLEdBQUcsVUFBVSxDQUFDO0lBQ2hDLENBQUM7SUFFRDs7T0FFRztJQUNJLFVBQVU7UUFDZixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDMUIsQ0FBQztJQUVEOztPQUVHO0lBQ0ksZUFBZTtRQUNwQixPQUFPLElBQUksQ0FBQyxXQUFXLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO0lBQ3BFLENBQUM7SUFFRDs7T0FFRztJQUNJLFVBQVU7UUFDZixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDMUIsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0ksTUFBTSxDQUFDLFlBQVk7UUFDeEIsT0FBTyxJQUFJLGFBQWEsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVEOzs7Ozs7T0FNRztJQUNJLE1BQU0sQ0FBQyxFQUFFLENBQUMsVUFBa0I7UUFDakMsT0FBTyxJQUFJLGFBQWEsQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0ksTUFBTSxDQUFDLG9CQUFvQixDQUNoQyxhQUE0QixJQUFJO1FBRWhDLE9BQU8sSUFBSSxhQUFhLENBQUMsVUFBVSxFQUFFLFVBQVUsS0FBSyxJQUFJLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksdUJBQXVCO1FBQzVCLE9BQU8sSUFBSSxhQUFhLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNuRCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSx5QkFBeUI7UUFDOUIsT0FBTyxJQUFJLGFBQWEsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFRDs7T0FFRztJQUNJLFFBQVE7UUFDYixPQUFPLFFBQVEsSUFBSSxDQUFDLFdBQVcsSUFBSSxNQUFNLGlCQUN2QyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE9BQzlCLEVBQUUsQ0FBQztJQUNMLENBQUM7Q0FDRjtBQW5HRCxzQ0FtR0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge3ZhbGlkYXRlVHRsU2Vjb25kc30gZnJvbSAnLi4vaW50ZXJuYWwvdXRpbHMnO1xuXG4vKiogUmVwcmVzZW50cyB0aGUgZGVzaXJlZCBiZWhhdmlvciBmb3IgbWFuYWdpbmcgdGhlIFRUTCBvbiBjb2xsZWN0aW9uXG4gKiAgb2JqZWN0cyAoZGljdGlvbmFyaWVzLCBsaXN0cywgc2V0cykgaW4geW91ciBjYWNoZS5cbiAqXG4gKiAgRm9yIGNhY2hlIG9wZXJhdGlvbnMgdGhhdCBtb2RpZnkgYSBjb2xsZWN0aW9uLCB0aGVyZSBhcmUgYSBmZXcgdGhpbmdzXG4gKiAgdG8gY29uc2lkZXIuICBUaGUgZmlyc3QgdGltZSB0aGUgY29sbGVjdGlvbiBpcyBjcmVhdGVkLCB3ZSBuZWVkIHRvXG4gKiAgc2V0IGEgVFRMIG9uIGl0LiAgRm9yIHN1YnNlcXVlbnQgb3BlcmF0aW9ucyB0aGF0IG1vZGlmeSB0aGUgY29sbGVjdGlvblxuICogIHlvdSBtYXkgY2hvb3NlIHRvIHVwZGF0ZSB0aGUgVFRMIGluIG9yZGVyIHRvIHByb2xvbmcgdGhlIGxpZmUgb2YgdGhlXG4gKiAgY2FjaGVkIGNvbGxlY3Rpb24gb2JqZWN0LCBvciB5b3UgbWF5IGNob29zZSB0byBsZWF2ZSB0aGUgVFRMIHVubW9kaWZpZWRcbiAqICBpbiBvcmRlciB0byBlbnN1cmUgdGhhdCB0aGUgY29sbGVjdGlvbiBleHBpcmVzIGF0IHRoZSBvcmlnaW5hbCBUVEwuXG4gKlxuICogIFRoZSBkZWZhdWx0IGJlaGF2aW9yIGlzIHRvIHJlZnJlc2ggdGhlIFRUTCAodG8gcHJvbG9uZyB0aGUgbGlmZSBvZiB0aGVcbiAqICBjb2xsZWN0aW9uKSBlYWNoIHRpbWUgaXQgaXMgd3JpdHRlbi4gIFRoaXMgYmVoYXZpb3IgY2FuIGJlIG1vZGlmaWVkXG4gKiAgYnkgY2FsbGluZyBDb2xsZWN0aW9uVHRsLndpdGhOb1JlZnJlc2hUdGxPblVwZGF0ZXMoKS5cbiAqXG4gKiAgQSBudWxsIFRUTCBtZWFucyB0byB1c2UgdGhlIGNsaWVudCdzIFRUTC5cbiAqL1xuZXhwb3J0IGNsYXNzIENvbGxlY3Rpb25UdGwge1xuICBwcml2YXRlIHJlYWRvbmx5IF90dGxTZWNvbmRzOiBudW1iZXIgfCBudWxsO1xuICBwcml2YXRlIHJlYWRvbmx5IF9yZWZyZXNoVHRsOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBJZiByZWZyZXNoVHRsIGlzIHRydWUsIHRoZSBjbGllbnQgbXVzdCB1cGRhdGUgdGhlIGNvbGxlY3Rpb24ncyBUVExcbiAgICogd2hlbiBpdCBtb2RpZmllcyBhIGNvbGxlY3Rpb24uXG4gICAqIEEgbnVsbCB0dGwgbWVhbnMgdG8gdXNlIHRoZSBjbGllbnQncyBUVEwuXG4gICAqIEBwYXJhbSB7bnVtYmVyIHwgbnVsbH0gW3R0bFNlY29uZHM9bnVsbF1cbiAgICogQHBhcmFtIHtib29sZWFufSBbcmVmcmVzaFR0bD10cnVlXVxuICAgKi9cbiAgY29uc3RydWN0b3IodHRsU2Vjb25kczogbnVtYmVyIHwgbnVsbCA9IG51bGwsIHJlZnJlc2hUdGwgPSB0cnVlKSB7XG4gICAgaWYgKHR0bFNlY29uZHMgIT09IG51bGwpIHtcbiAgICAgIHZhbGlkYXRlVHRsU2Vjb25kcyh0dGxTZWNvbmRzKTtcbiAgICB9XG4gICAgdGhpcy5fcmVmcmVzaFR0bCA9IHJlZnJlc2hUdGw7XG4gICAgdGhpcy5fdHRsU2Vjb25kcyA9IHR0bFNlY29uZHM7XG4gIH1cblxuICAvKiogVGltZS10by1saXZlLCBpbiBzZWNvbmRzLlxuICAgKiBAcmV0dXJucyB7bnVtYmVyIHwgbnVsbH1cbiAgICovXG4gIHB1YmxpYyB0dGxTZWNvbmRzKCk6IG51bWJlciB8IG51bGwge1xuICAgIHJldHVybiB0aGlzLl90dGxTZWNvbmRzO1xuICB9XG5cbiAgLyoqIFRpbWUtdG8tbGl2ZSwgaW4gbWlsbGlzZWNvbmRzLlxuICAgKiBAcmV0dXJucyB7bnVtYmVyIHwgbnVsbH1cbiAgICovXG4gIHB1YmxpYyB0dGxNaWxsaXNlY29uZHMoKTogbnVtYmVyIHwgbnVsbCB7XG4gICAgcmV0dXJuIHRoaXMuX3R0bFNlY29uZHMgPT09IG51bGwgPyBudWxsIDogdGhpcy5fdHRsU2Vjb25kcyAqIDEwMDA7XG4gIH1cblxuICAvKiogV2hldGhlciBvciBub3QgdG8gcmVmcmVzaCBhIGNvbGxlY3Rpb24ncyBUVEwgd2hlbiBpdCdzIG1vZGlmaWVkLlxuICAgKiBAcmV0dXJucyB7Ym9vbGVhbn1cbiAgICovXG4gIHB1YmxpYyByZWZyZXNoVHRsKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLl9yZWZyZXNoVHRsO1xuICB9XG5cbiAgLyoqIFRoZSBkZWZhdWx0IHdheSB0byBoYW5kbGUgVFRMcyBmb3IgY29sbGVjdGlvbnMuIFRoZSBjbGllbnQncyBkZWZhdWx0IFRUTFxuICAgKiAgd2lsbCBiZSB1c2VkLCBhbmQgdGhlIFRUTCBmb3IgdGhlIGNvbGxlY3Rpb24gd2lsbCBiZSByZWZyZXNoZWQgYW55XG4gICAqICB0aW1lIHRoZSBjb2xsZWN0aW9uIGlzIG1vZGlmaWVkLlxuICAgKiBAY29uc3RydWN0b3JcbiAgICogQHJldHVybnMge0NvbGxlY3Rpb25UdGx9XG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGZyb21DYWNoZVR0bCgpOiBDb2xsZWN0aW9uVHRsIHtcbiAgICByZXR1cm4gbmV3IENvbGxlY3Rpb25UdGwobnVsbCwgdHJ1ZSk7XG4gIH1cblxuICAvKiogQ29uc3RydWN0cyBhIENvbGxlY3Rpb25UdGwgd2l0aCB0aGUgc3BlY2lmaWVkIFRUTC4gVGhlIFRUTFxuICAgKiAgZm9yIHRoZSBjb2xsZWN0aW9uIHdpbGwgYmUgcmVmcmVzaGVkIGFueSB0aW1lIHRoZSBjb2xsZWN0aW9uIGlzXG4gICAqICBtb2RpZmllZC5cbiAgICogQGNvbnN0cnVjdG9yXG4gICAqIEBwYXJhbSB7bnVtYmVyfSBbdHRsU2Vjb25kc11cbiAgICogQHJldHVybnMge0NvbGxlY3Rpb25UdGx9XG4gICAqL1xuICBwdWJsaWMgc3RhdGljIG9mKHR0bFNlY29uZHM6IG51bWJlcik6IENvbGxlY3Rpb25UdGwge1xuICAgIHJldHVybiBuZXcgQ29sbGVjdGlvblR0bCh0dGxTZWNvbmRzLCB0cnVlKTtcbiAgfVxuXG4gIC8qKiBDb25zdHJ1Y3RzIGEgQ29sbGVjdGlvblR0bCB3aXRoIHRoZSBzcGVjaWZpZWQgVFRMLlxuICAgKiAgV2lsbCBvbmx5IHJlZnJlc2ggaWYgdGhlIFRUTCBpcyBwcm92aWRlZC5cbiAgICogQGNvbnN0cnVjdG9yXG4gICAqIEBwYXJhbSB7bnVtYmVyIHwgbnVsbH0gW3R0bFNlY29uZHM9bnVsbF1cbiAgICogQHJldHVybnMge0NvbGxlY3Rpb25UdGx9XG4gICAqL1xuICBwdWJsaWMgc3RhdGljIHJlZnJlc2hUdGxJZlByb3ZpZGVkKFxuICAgIHR0bFNlY29uZHM6IG51bWJlciB8IG51bGwgPSBudWxsXG4gICk6IENvbGxlY3Rpb25UdGwge1xuICAgIHJldHVybiBuZXcgQ29sbGVjdGlvblR0bCh0dGxTZWNvbmRzLCB0dGxTZWNvbmRzICE9PSBudWxsKTtcbiAgfVxuXG4gIC8qKiBDb3BpZXMgdGhlIENvbGxlY3Rpb25UdGwsIGJ1dCBpdCB3aWxsIHJlZnJlc2ggdGhlIFRUTCB3aGVuXG4gICAqICB0aGUgY29sbGVjdGlvbiBpcyBtb2RpZmllZC5cbiAgICogQHJldHVybnMge0NvbGxlY3Rpb25UdGx9XG4gICAqL1xuICBwdWJsaWMgd2l0aFJlZnJlc2hUdGxPblVwZGF0ZXMoKTogQ29sbGVjdGlvblR0bCB7XG4gICAgcmV0dXJuIG5ldyBDb2xsZWN0aW9uVHRsKHRoaXMuX3R0bFNlY29uZHMsIHRydWUpO1xuICB9XG5cbiAgLyoqIENvcGllcyB0aGUgQ29sbGVjdGlvblRUTCwgYnV0IHRoZSBUVEwgd2lsbCBub3QgYmUgcmVmcmVzaGVkXG4gICAqICB3aGVuIHRoZSBjb2xsZWN0aW9uIGlzIG1vZGlmaWVkLiBVc2UgdGhpcyBpZiB5b3Ugd2FudCB0byBlbnN1cmVcbiAgICogIHRoYXQgeW91ciBjb2xsZWN0aW9uIGV4cGlyZXMgYXQgdGhlIG9yaWdpbmFsbHkgc3BlY2lmaWVkIHRpbWUsIGV2ZW5cbiAgICogIGlmIHlvdSBtYWtlIG1vZGlmaWNhdGlvbnMgdG8gdGhlIHZhbHVlIG9mIHRoZSBjb2xsZWN0aW9uLlxuICAgKiBAcmV0dXJucyB7Q29sbGVjdGlvblR0bH1cbiAgICovXG4gIHB1YmxpYyB3aXRoTm9SZWZyZXNoVHRsT25VcGRhdGVzKCk6IENvbGxlY3Rpb25UdGwge1xuICAgIHJldHVybiBuZXcgQ29sbGVjdGlvblR0bCh0aGlzLl90dGxTZWNvbmRzLCBmYWxzZSk7XG4gIH1cblxuICAvKiogQSBzdHJpbmcgcmVwcmVzZW5hdGlvbiBvZiB0aGUgQ29sbGVjdGlvblR0bCBmb3IgZGVidWdnaW5nIHB1cnBvc2VzLlxuICAgKiBAcmV0dXJuIHtDb2xsZWN0aW9uVHRsfVxuICAgKi9cbiAgcHVibGljIHRvU3RyaW5nKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGB0dGw6ICR7dGhpcy5fdHRsU2Vjb25kcyB8fCAnbnVsbCd9LCByZWZyZXNoVHRsOiAke1xuICAgICAgdGhpcy5fcmVmcmVzaFR0bCA/ICd0cnVlJyA6ICdmYWxzZSdcbiAgICB9YDtcbiAgfVxufVxuIl19
|