@gomomento/sdk-core 1.12.8
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/auth/credential-provider.d.ts +83 -0
- package/dist/src/auth/credential-provider.js +82 -0
- package/dist/src/auth/index.d.ts +1 -0
- package/dist/src/auth/index.js +18 -0
- package/dist/src/config/logging/default-momento-logger.d.ts +24 -0
- package/dist/src/config/logging/default-momento-logger.js +69 -0
- package/dist/src/config/logging/index.d.ts +3 -0
- package/dist/src/config/logging/index.js +20 -0
- package/dist/src/config/logging/momento-logger.d.ts +10 -0
- package/dist/src/config/logging/momento-logger.js +3 -0
- package/dist/src/config/logging/noop-momento-logger.d.ts +11 -0
- package/dist/src/config/logging/noop-momento-logger.js +34 -0
- package/dist/src/config/transport/grpc-configuration.d.ts +41 -0
- package/dist/src/config/transport/grpc-configuration.js +3 -0
- package/dist/src/config/transport/index.d.ts +2 -0
- package/dist/src/config/transport/index.js +19 -0
- package/dist/src/config/transport/transport-strategy.d.ts +77 -0
- package/dist/src/config/transport/transport-strategy.js +60 -0
- package/dist/src/errors/error-utils.d.ts +2 -0
- package/dist/src/errors/error-utils.js +12 -0
- package/dist/src/errors/errors.d.ts +140 -0
- package/dist/src/errors/errors.js +229 -0
- package/dist/src/errors/index.d.ts +2 -0
- package/dist/src/errors/index.js +19 -0
- package/dist/src/index.d.ts +57 -0
- package/dist/src/index.js +137 -0
- package/dist/src/internal/clients/auth/AbstractAuthClient.d.ts +10 -0
- package/dist/src/internal/clients/auth/AbstractAuthClient.js +13 -0
- package/dist/src/internal/clients/auth/IAuthClient.d.ts +4 -0
- package/dist/src/internal/clients/auth/IAuthClient.js +3 -0
- package/dist/src/internal/clients/auth/index.d.ts +2 -0
- package/dist/src/internal/clients/auth/index.js +19 -0
- package/dist/src/internal/clients/cache/AbstractCacheClient.d.ts +638 -0
- package/dist/src/internal/clients/cache/AbstractCacheClient.js +870 -0
- package/dist/src/internal/clients/cache/ICacheClient.d.ts +45 -0
- package/dist/src/internal/clients/cache/ICacheClient.js +3 -0
- package/dist/src/internal/clients/cache/IControlClient.d.ts +7 -0
- package/dist/src/internal/clients/cache/IControlClient.js +3 -0
- package/dist/src/internal/clients/cache/IDataClient.d.ts +29 -0
- package/dist/src/internal/clients/cache/IDataClient.js +3 -0
- package/dist/src/internal/clients/cache/index.d.ts +4 -0
- package/dist/src/internal/clients/cache/index.js +21 -0
- package/dist/src/internal/clients/index.d.ts +3 -0
- package/dist/src/internal/clients/index.js +20 -0
- package/dist/src/internal/clients/ping/AbstractPingClient.d.ts +25 -0
- package/dist/src/internal/clients/ping/AbstractPingClient.js +29 -0
- package/dist/src/internal/clients/ping/IPingClient.d.ts +3 -0
- package/dist/src/internal/clients/ping/IPingClient.js +3 -0
- package/dist/src/internal/clients/ping/index.d.ts +2 -0
- package/dist/src/internal/clients/ping/index.js +19 -0
- package/dist/src/internal/subscription-state.d.ts +15 -0
- package/dist/src/internal/subscription-state.js +38 -0
- package/dist/src/internal/utils/auth.d.ts +25 -0
- package/dist/src/internal/utils/auth.js +50 -0
- package/dist/src/internal/utils/collections.d.ts +1 -0
- package/dist/src/internal/utils/collections.js +8 -0
- package/dist/src/internal/utils/display.d.ts +2 -0
- package/dist/src/internal/utils/display.js +30 -0
- package/dist/src/internal/utils/index.d.ts +7 -0
- package/dist/src/internal/utils/index.js +24 -0
- package/dist/src/internal/utils/object.d.ts +1 -0
- package/dist/src/internal/utils/object.js +8 -0
- package/dist/src/internal/utils/sleep.d.ts +1 -0
- package/dist/src/internal/utils/sleep.js +6 -0
- package/dist/src/internal/utils/string.d.ts +2 -0
- package/dist/src/internal/utils/string.js +17 -0
- package/dist/src/internal/utils/validators.d.ts +13 -0
- package/dist/src/internal/utils/validators.js +105 -0
- package/dist/src/internal/vendor/printf/README.md +31 -0
- package/dist/src/internal/vendor/printf/printf.d.ts +9 -0
- package/dist/src/internal/vendor/printf/printf.js +478 -0
- package/dist/src/messages/cache-info.d.ts +5 -0
- package/dist/src/messages/cache-info.js +13 -0
- package/dist/src/messages/responses/cache-delete.d.ts +61 -0
- package/dist/src/messages/responses/cache-delete.js +54 -0
- package/dist/src/messages/responses/cache-dictionary-fetch.d.ts +120 -0
- package/dist/src/messages/responses/cache-dictionary-fetch.js +162 -0
- package/dist/src/messages/responses/cache-dictionary-get-field.d.ts +123 -0
- package/dist/src/messages/responses/cache-dictionary-get-field.js +143 -0
- package/dist/src/messages/responses/cache-dictionary-get-fields.d.ts +122 -0
- package/dist/src/messages/responses/cache-dictionary-get-fields.js +173 -0
- package/dist/src/messages/responses/cache-dictionary-increment.d.ts +69 -0
- package/dist/src/messages/responses/cache-dictionary-increment.js +68 -0
- package/dist/src/messages/responses/cache-dictionary-remove-field.d.ts +61 -0
- package/dist/src/messages/responses/cache-dictionary-remove-field.js +54 -0
- package/dist/src/messages/responses/cache-dictionary-remove-fields.d.ts +61 -0
- package/dist/src/messages/responses/cache-dictionary-remove-fields.js +54 -0
- package/dist/src/messages/responses/cache-dictionary-set-field.d.ts +61 -0
- package/dist/src/messages/responses/cache-dictionary-set-field.js +54 -0
- package/dist/src/messages/responses/cache-dictionary-set-fields.d.ts +61 -0
- package/dist/src/messages/responses/cache-dictionary-set-fields.js +54 -0
- package/dist/src/messages/responses/cache-flush.d.ts +61 -0
- package/dist/src/messages/responses/cache-flush.js +54 -0
- package/dist/src/messages/responses/cache-get.d.ts +86 -0
- package/dist/src/messages/responses/cache-get.js +88 -0
- package/dist/src/messages/responses/cache-increment.d.ts +69 -0
- package/dist/src/messages/responses/cache-increment.js +68 -0
- package/dist/src/messages/responses/cache-list-concatenate-back.d.ts +69 -0
- package/dist/src/messages/responses/cache-list-concatenate-back.js +68 -0
- package/dist/src/messages/responses/cache-list-concatenate-front.d.ts +69 -0
- package/dist/src/messages/responses/cache-list-concatenate-front.js +68 -0
- package/dist/src/messages/responses/cache-list-fetch.d.ts +92 -0
- package/dist/src/messages/responses/cache-list-fetch.js +96 -0
- package/dist/src/messages/responses/cache-list-length.d.ts +84 -0
- package/dist/src/messages/responses/cache-list-length.js +78 -0
- package/dist/src/messages/responses/cache-list-pop-back.d.ts +86 -0
- package/dist/src/messages/responses/cache-list-pop-back.js +88 -0
- package/dist/src/messages/responses/cache-list-pop-front.d.ts +86 -0
- package/dist/src/messages/responses/cache-list-pop-front.js +88 -0
- package/dist/src/messages/responses/cache-list-push-back.d.ts +69 -0
- package/dist/src/messages/responses/cache-list-push-back.js +68 -0
- package/dist/src/messages/responses/cache-list-push-front.d.ts +69 -0
- package/dist/src/messages/responses/cache-list-push-front.js +68 -0
- package/dist/src/messages/responses/cache-list-remove-value.d.ts +61 -0
- package/dist/src/messages/responses/cache-list-remove-value.js +54 -0
- package/dist/src/messages/responses/cache-list-retain.d.ts +61 -0
- package/dist/src/messages/responses/cache-list-retain.js +54 -0
- package/dist/src/messages/responses/cache-set-add-element.d.ts +71 -0
- package/dist/src/messages/responses/cache-set-add-element.js +54 -0
- package/dist/src/messages/responses/cache-set-add-elements.d.ts +65 -0
- package/dist/src/messages/responses/cache-set-add-elements.js +61 -0
- package/dist/src/messages/responses/cache-set-fetch.d.ts +111 -0
- package/dist/src/messages/responses/cache-set-fetch.js +121 -0
- package/dist/src/messages/responses/cache-set-if-not-exists.d.ts +74 -0
- package/dist/src/messages/responses/cache-set-if-not-exists.js +63 -0
- package/dist/src/messages/responses/cache-set-remove-element.d.ts +61 -0
- package/dist/src/messages/responses/cache-set-remove-element.js +54 -0
- package/dist/src/messages/responses/cache-set-remove-elements.d.ts +65 -0
- package/dist/src/messages/responses/cache-set-remove-elements.js +61 -0
- package/dist/src/messages/responses/cache-set.d.ts +61 -0
- package/dist/src/messages/responses/cache-set.js +54 -0
- package/dist/src/messages/responses/cache-sorted-set-fetch.d.ts +107 -0
- package/dist/src/messages/responses/cache-sorted-set-fetch.js +124 -0
- package/dist/src/messages/responses/cache-sorted-set-get-rank.d.ts +81 -0
- package/dist/src/messages/responses/cache-sorted-set-get-rank.js +78 -0
- package/dist/src/messages/responses/cache-sorted-set-get-score.d.ts +118 -0
- package/dist/src/messages/responses/cache-sorted-set-get-score.js +131 -0
- package/dist/src/messages/responses/cache-sorted-set-get-scores.d.ts +109 -0
- package/dist/src/messages/responses/cache-sorted-set-get-scores.js +148 -0
- package/dist/src/messages/responses/cache-sorted-set-increment-score.d.ts +69 -0
- package/dist/src/messages/responses/cache-sorted-set-increment-score.js +68 -0
- package/dist/src/messages/responses/cache-sorted-set-put-element.d.ts +61 -0
- package/dist/src/messages/responses/cache-sorted-set-put-element.js +54 -0
- package/dist/src/messages/responses/cache-sorted-set-put-elements.d.ts +61 -0
- package/dist/src/messages/responses/cache-sorted-set-put-elements.js +54 -0
- package/dist/src/messages/responses/cache-sorted-set-remove-element.d.ts +61 -0
- package/dist/src/messages/responses/cache-sorted-set-remove-element.js +54 -0
- package/dist/src/messages/responses/cache-sorted-set-remove-elements.d.ts +61 -0
- package/dist/src/messages/responses/cache-sorted-set-remove-elements.js +54 -0
- package/dist/src/messages/responses/create-cache.d.ts +77 -0
- package/dist/src/messages/responses/create-cache.js +61 -0
- package/dist/src/messages/responses/create-signing-key.d.ts +71 -0
- package/dist/src/messages/responses/create-signing-key.js +76 -0
- package/dist/src/messages/responses/delete-cache.d.ts +61 -0
- package/dist/src/messages/responses/delete-cache.js +54 -0
- package/dist/src/messages/responses/generate-api-token.d.ts +50 -0
- package/dist/src/messages/responses/generate-api-token.js +52 -0
- package/dist/src/messages/responses/grpc-response-types.d.ts +41 -0
- package/dist/src/messages/responses/grpc-response-types.js +53 -0
- package/dist/src/messages/responses/list-caches.d.ts +70 -0
- package/dist/src/messages/responses/list-caches.js +69 -0
- package/dist/src/messages/responses/list-signing-keys.d.ts +68 -0
- package/dist/src/messages/responses/list-signing-keys.js +68 -0
- package/dist/src/messages/responses/response-base.d.ts +43 -0
- package/dist/src/messages/responses/response-base.js +50 -0
- package/dist/src/messages/responses/revoke-signing-key.d.ts +61 -0
- package/dist/src/messages/responses/revoke-signing-key.js +54 -0
- package/dist/src/messages/responses/topic-item.d.ts +27 -0
- package/dist/src/messages/responses/topic-item.js +43 -0
- package/dist/src/messages/responses/topic-publish.d.ts +61 -0
- package/dist/src/messages/responses/topic-publish.js +54 -0
- package/dist/src/messages/responses/topic-subscribe.d.ts +69 -0
- package/dist/src/messages/responses/topic-subscribe.js +72 -0
- package/dist/src/messages/signing-key.d.ts +9 -0
- package/dist/src/messages/signing-key.js +21 -0
- package/dist/src/utils/cache-call-options.d.ts +99 -0
- package/dist/src/utils/cache-call-options.js +9 -0
- package/dist/src/utils/collection-ttl.d.ts +78 -0
- package/dist/src/utils/collection-ttl.js +102 -0
- package/dist/src/utils/index.d.ts +3 -0
- package/dist/src/utils/index.js +20 -0
- package/dist/src/utils/topic-call-options.d.ts +19 -0
- package/dist/src/utils/topic-call-options.js +3 -0
- package/package.json +53 -0
@@ -0,0 +1,143 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Error = exports.Miss = exports.Hit = exports.Response = void 0;
|
4
|
+
const response_base_1 = require("./response-base");
|
5
|
+
const display_1 = require("../../internal/utils/display");
|
6
|
+
const TEXT_DECODER = new TextDecoder();
|
7
|
+
/**
|
8
|
+
* Parent response type for a dictionary get field request. The
|
9
|
+
* response object is resolved to a type-safe object of one of
|
10
|
+
* the following subtypes:
|
11
|
+
*
|
12
|
+
* - {Hit}
|
13
|
+
* - {Miss}
|
14
|
+
* - {Error}
|
15
|
+
*
|
16
|
+
* `instanceof` type guards can be used to operate on the appropriate subtype.
|
17
|
+
* @example
|
18
|
+
* For example:
|
19
|
+
* ```
|
20
|
+
* if (response instanceof CacheDictionaryGetField.Error) {
|
21
|
+
* // Handle error as appropriate. The compiler will smart-cast `response` to type
|
22
|
+
* // `CacheDictionaryGetField.Error` in this block, so you will have access to the properties
|
23
|
+
* // of the Error class; e.g. `response.errorCode()`.
|
24
|
+
* }
|
25
|
+
* ```
|
26
|
+
*/
|
27
|
+
class Response extends response_base_1.ResponseBase {
|
28
|
+
}
|
29
|
+
exports.Response = Response;
|
30
|
+
class _Hit extends Response {
|
31
|
+
constructor(body) {
|
32
|
+
super();
|
33
|
+
this.body = body;
|
34
|
+
}
|
35
|
+
/**
|
36
|
+
* Returns the data as a utf-8 string, decoded from the underlying byte array.
|
37
|
+
* @returns string
|
38
|
+
*/
|
39
|
+
valueString() {
|
40
|
+
return TEXT_DECODER.decode(this.body);
|
41
|
+
}
|
42
|
+
/**
|
43
|
+
* Returns the data as a byte array.
|
44
|
+
* @returns {Uint8Array}
|
45
|
+
*/
|
46
|
+
valueUint8Array() {
|
47
|
+
return this.body;
|
48
|
+
}
|
49
|
+
toString() {
|
50
|
+
const display = (0, display_1.truncateString)(this.valueString());
|
51
|
+
return `${super.toString()}: ${display}`;
|
52
|
+
}
|
53
|
+
}
|
54
|
+
/**
|
55
|
+
* Indicates that the requested data was successfully retrieved from the cache. Provides
|
56
|
+
* `value*` accessors to retrieve the data in the appropriate format.
|
57
|
+
*/
|
58
|
+
class Hit extends (0, response_base_1.ResponseHit)(_Hit) {
|
59
|
+
constructor(body, field) {
|
60
|
+
super(body);
|
61
|
+
this.field = field;
|
62
|
+
}
|
63
|
+
/**
|
64
|
+
* Returns the field name for the retrieved element, as a utf-8 string decoded from the underlying byte array.
|
65
|
+
* @returns {string}
|
66
|
+
*/
|
67
|
+
fieldString() {
|
68
|
+
return TEXT_DECODER.decode(this.field);
|
69
|
+
}
|
70
|
+
/**
|
71
|
+
* Returns the field name for the retrieved element, as a byte array.
|
72
|
+
* @returns {Uint8Array}
|
73
|
+
*/
|
74
|
+
fieldUint8Array() {
|
75
|
+
return this.field;
|
76
|
+
}
|
77
|
+
}
|
78
|
+
exports.Hit = Hit;
|
79
|
+
class _Miss extends Response {
|
80
|
+
}
|
81
|
+
/**
|
82
|
+
* Indicates that the requested data was not available in the cache.
|
83
|
+
*/
|
84
|
+
class Miss extends (0, response_base_1.ResponseMiss)(_Miss) {
|
85
|
+
constructor(field) {
|
86
|
+
super();
|
87
|
+
this.field = field;
|
88
|
+
}
|
89
|
+
/**
|
90
|
+
* Returns the field name for the retrieved element, as a utf-8 string decoded from the underlying byte array.
|
91
|
+
* @returns {string}
|
92
|
+
*/
|
93
|
+
fieldString() {
|
94
|
+
return TEXT_DECODER.decode(this.field);
|
95
|
+
}
|
96
|
+
/**
|
97
|
+
* Returns the field name for the retrieved element, as a byte array.
|
98
|
+
* @returns {Uint8Array}
|
99
|
+
*/
|
100
|
+
fieldUint8Array() {
|
101
|
+
return this.field;
|
102
|
+
}
|
103
|
+
}
|
104
|
+
exports.Miss = Miss;
|
105
|
+
class _Error extends Response {
|
106
|
+
constructor(_innerException) {
|
107
|
+
super();
|
108
|
+
this._innerException = _innerException;
|
109
|
+
}
|
110
|
+
}
|
111
|
+
/**
|
112
|
+
* Indicates that an error occurred during the dictionary get field request.
|
113
|
+
*
|
114
|
+
* This response object includes the following fields that you can use to determine
|
115
|
+
* how you would like to handle the error:
|
116
|
+
*
|
117
|
+
* - `errorCode()` - a unique Momento error code indicating the type of error that occurred.
|
118
|
+
* - `message()` - a human-readable description of the error
|
119
|
+
* - `innerException()` - the original error that caused the failure; can be re-thrown.
|
120
|
+
*/
|
121
|
+
class Error extends (0, response_base_1.ResponseError)(_Error) {
|
122
|
+
constructor(_innerException, field) {
|
123
|
+
super(_innerException);
|
124
|
+
this._innerException = _innerException;
|
125
|
+
this.field = field;
|
126
|
+
}
|
127
|
+
/**
|
128
|
+
* Returns the field name for the retrieved element, as a utf-8 string decoded from the underlying byte array.
|
129
|
+
* @returns {string}
|
130
|
+
*/
|
131
|
+
fieldString() {
|
132
|
+
return TEXT_DECODER.decode(this.field);
|
133
|
+
}
|
134
|
+
/**
|
135
|
+
* Returns the field name for the retrieved element, as a byte array.
|
136
|
+
* @returns {Uint8Array}
|
137
|
+
*/
|
138
|
+
fieldUint8Array() {
|
139
|
+
return this.field;
|
140
|
+
}
|
141
|
+
}
|
142
|
+
exports.Error = Error;
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cache-dictionary-get-field.js","sourceRoot":"","sources":["../../../../src/messages/responses/cache-dictionary-get-field.ts"],"names":[],"mappings":";;;AACA,mDAKyB;AACzB,0DAA4D;AAE5D,MAAM,YAAY,GAAG,IAAI,WAAW,EAAE,CAAC;AAEvC;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAsB,QAAS,SAAQ,4BAAY;CAAG;AAAtD,4BAAsD;AAEtD,MAAM,IAAK,SAAQ,QAAQ;IAEzB,YAAY,IAAgB;QAC1B,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IACD;;;OAGG;IACI,WAAW;QAChB,OAAO,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACxC,CAAC;IAED;;;OAGG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAEe,QAAQ;QACtB,MAAM,OAAO,GAAG,IAAA,wBAAc,EAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACnD,OAAO,GAAG,KAAK,CAAC,QAAQ,EAAE,KAAK,OAAO,EAAE,CAAC;IAC3C,CAAC;CACF;AAED;;;GAGG;AACH,MAAa,GAAI,SAAQ,IAAA,2BAAW,EAAC,IAAI,CAAC;IAGxC,YAAY,IAAgB,EAAE,KAAiB;QAC7C,KAAK,CAAC,IAAI,CAAC,CAAC;QACZ,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED;;;OAGG;IACI,WAAW;QAChB,OAAO,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED;;;OAGG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;CACF;AAvBD,kBAuBC;AAED,MAAM,KAAM,SAAQ,QAAQ;CAAG;AAE/B;;GAEG;AACH,MAAa,IAAK,SAAQ,IAAA,4BAAY,EAAC,KAAK,CAAC;IAG3C,YAAY,KAAiB;QAC3B,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED;;;OAGG;IACI,WAAW;QAChB,OAAO,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED;;;OAGG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;CACF;AAvBD,oBAuBC;AAED,MAAM,MAAO,SAAQ,QAAQ;IAC3B,YAAsB,eAAyB;QAC7C,KAAK,EAAE,CAAC;QADY,oBAAe,GAAf,eAAe,CAAU;IAE/C,CAAC;CACF;AAED;;;;;;;;;GASG;AACH,MAAa,KAAM,SAAQ,IAAA,6BAAa,EAAC,MAAM,CAAC;IAG9C,YAAmB,eAAyB,EAAE,KAAiB;QAC7D,KAAK,CAAC,eAAe,CAAC,CAAC;QADN,oBAAe,GAAf,eAAe,CAAU;QAE1C,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED;;;OAGG;IACI,WAAW;QAChB,OAAO,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED;;;OAGG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;CACF;AAvBD,sBAuBC","sourcesContent":["import {SdkError} from '../../errors/errors';\nimport {\n  ResponseBase,\n  ResponseError,\n  ResponseHit,\n  ResponseMiss,\n} from './response-base';\nimport {truncateString} from '../../internal/utils/display';\n\nconst TEXT_DECODER = new TextDecoder();\n\n/**\n * Parent response type for a dictionary get field request.  The\n * response object is resolved to a type-safe object of one of\n * the following subtypes:\n *\n * - {Hit}\n * - {Miss}\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 CacheDictionaryGetField.Error) {\n *   // Handle error as appropriate.  The compiler will smart-cast `response` to type\n *   // `CacheDictionaryGetField.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\nclass _Hit extends Response {\n  private readonly body: Uint8Array;\n  constructor(body: Uint8Array) {\n    super();\n    this.body = body;\n  }\n  /**\n   * Returns the data as a utf-8 string, decoded from the underlying byte array.\n   * @returns string\n   */\n  public valueString(): string {\n    return TEXT_DECODER.decode(this.body);\n  }\n\n  /**\n   * Returns the data as a byte array.\n   * @returns {Uint8Array}\n   */\n  public valueUint8Array(): Uint8Array {\n    return this.body;\n  }\n\n  public override toString(): string {\n    const display = truncateString(this.valueString());\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 Hit extends ResponseHit(_Hit) {\n  private readonly field: Uint8Array;\n\n  constructor(body: Uint8Array, field: Uint8Array) {\n    super(body);\n    this.field = field;\n  }\n\n  /**\n   * Returns the field name for the retrieved element, as a utf-8 string decoded from the underlying byte array.\n   * @returns {string}\n   */\n  public fieldString(): string {\n    return TEXT_DECODER.decode(this.field);\n  }\n\n  /**\n   * Returns the field name for the retrieved element, as a byte array.\n   * @returns {Uint8Array}\n   */\n  public fieldUint8Array(): Uint8Array {\n    return this.field;\n  }\n}\n\nclass _Miss extends Response {}\n\n/**\n * Indicates that the requested data was not available in the cache.\n */\nexport class Miss extends ResponseMiss(_Miss) {\n  private readonly field: Uint8Array;\n\n  constructor(field: Uint8Array) {\n    super();\n    this.field = field;\n  }\n\n  /**\n   * Returns the field name for the retrieved element, as a utf-8 string decoded from the underlying byte array.\n   * @returns {string}\n   */\n  public fieldString(): string {\n    return TEXT_DECODER.decode(this.field);\n  }\n\n  /**\n   * Returns the field name for the retrieved element, as a byte array.\n   * @returns {Uint8Array}\n   */\n  public fieldUint8Array(): Uint8Array {\n    return this.field;\n  }\n}\n\nclass _Error extends Response {\n  constructor(protected _innerException: SdkError) {\n    super();\n  }\n}\n\n/**\n * Indicates that an error occurred during the dictionary get field 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  private readonly field: Uint8Array;\n\n  constructor(public _innerException: SdkError, field: Uint8Array) {\n    super(_innerException);\n    this.field = field;\n  }\n\n  /**\n   * Returns the field name for the retrieved element, as a utf-8 string decoded from the underlying byte array.\n   * @returns {string}\n   */\n  public fieldString(): string {\n    return TEXT_DECODER.decode(this.field);\n  }\n\n  /**\n   * Returns the field name for the retrieved element, as a byte array.\n   * @returns {Uint8Array}\n   */\n  public fieldUint8Array(): Uint8Array {\n    return this.field;\n  }\n}\n"]}
|
@@ -0,0 +1,122 @@
|
|
1
|
+
import { SdkError } from '../../errors/errors';
|
2
|
+
import { ResponseBase } from './response-base';
|
3
|
+
import * as CacheDictionaryGetFieldResponse from './cache-dictionary-get-field';
|
4
|
+
import { _DictionaryGetResponsePart } from './grpc-response-types';
|
5
|
+
type CacheDictionaryGetFieldResponseType = CacheDictionaryGetFieldResponse.Hit | CacheDictionaryGetFieldResponse.Miss | CacheDictionaryGetFieldResponse.Error;
|
6
|
+
/**
|
7
|
+
* Parent response type for a dictionary get fields request. The
|
8
|
+
* response object is resolved to a type-safe object of one of
|
9
|
+
* the following subtypes:
|
10
|
+
*
|
11
|
+
* - {Hit}
|
12
|
+
* - {Miss}
|
13
|
+
* - {Error}
|
14
|
+
*
|
15
|
+
* `instanceof` type guards can be used to operate on the appropriate subtype.
|
16
|
+
* @example
|
17
|
+
* For example:
|
18
|
+
* ```
|
19
|
+
* if (response instanceof CacheDictionaryGetFields.Error) {
|
20
|
+
* // Handle error as appropriate. The compiler will smart-cast `response` to type
|
21
|
+
* // `CacheDictionaryGetFields.Error` in this block, so you will have access to the properties
|
22
|
+
* // of the Error class; e.g. `response.errorCode()`.
|
23
|
+
* }
|
24
|
+
* ```
|
25
|
+
*/
|
26
|
+
export declare abstract class Response extends ResponseBase {
|
27
|
+
}
|
28
|
+
declare class _Hit extends Response {
|
29
|
+
private readonly items;
|
30
|
+
private readonly fields;
|
31
|
+
responses: CacheDictionaryGetFieldResponseType[];
|
32
|
+
constructor(items: _DictionaryGetResponsePart[], fields: Uint8Array[]);
|
33
|
+
/**
|
34
|
+
* Returns the data as a Map whose keys and values are byte arrays.
|
35
|
+
* @returns {Map<Uint8Array, Uint8Array>}
|
36
|
+
*/
|
37
|
+
valueMapUint8ArrayUint8Array(): Map<Uint8Array, Uint8Array>;
|
38
|
+
/**
|
39
|
+
* Returns the data as a Map whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
40
|
+
* @returns {Map<string, string>}
|
41
|
+
*/
|
42
|
+
valueMapStringString(): Map<string, string>;
|
43
|
+
/**
|
44
|
+
* Returns the data as a Map whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
45
|
+
* This is a convenience alias for {valueMapStringString}.
|
46
|
+
* @returns {Map<string, string>}
|
47
|
+
*/
|
48
|
+
valueMap(): Map<string, string>;
|
49
|
+
/**
|
50
|
+
* Returns the data as a Map whose keys are utf-8 strings, decoded from the underlying byte array, and whose values
|
51
|
+
* are byte arrays.
|
52
|
+
* @returns {Map<string, Uint8Array>}
|
53
|
+
*/
|
54
|
+
valueMapStringUint8Array(): Map<string, Uint8Array>;
|
55
|
+
/**
|
56
|
+
* Returns the data as a Record whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
57
|
+
* This can be used in most places where an Object is desired.
|
58
|
+
* @returns {Record<string, string>}
|
59
|
+
*/
|
60
|
+
valueRecordStringString(): Record<string, string>;
|
61
|
+
/**
|
62
|
+
* Returns the data as a Record whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
63
|
+
* This can be used in most places where an Object is desired. This is a convenience alias for
|
64
|
+
* {valueRecordStringString}.
|
65
|
+
* @returns {Record<string, string>}
|
66
|
+
*/
|
67
|
+
valueRecord(): Record<string, string>;
|
68
|
+
/**
|
69
|
+
* Returns the data as a Record whose keys are utf-8 strings, decoded from the underlying byte array, and whose
|
70
|
+
* values are byte arrays. This can be used in most places where an Object is desired.
|
71
|
+
* @returns {Record<string, Uint8Array>}
|
72
|
+
*/
|
73
|
+
valueRecordStringUint8Array(): Record<string, Uint8Array>;
|
74
|
+
toString(): string;
|
75
|
+
}
|
76
|
+
declare const Hit_base: {
|
77
|
+
new (...args: any[]): {};
|
78
|
+
} & typeof _Hit;
|
79
|
+
/**
|
80
|
+
* Indicates that the requested data was successfully retrieved from the cache. Provides
|
81
|
+
* `value*` accessors to retrieve the data in the appropriate format.
|
82
|
+
*/
|
83
|
+
export declare class Hit extends Hit_base {
|
84
|
+
}
|
85
|
+
declare class _Miss extends Response {
|
86
|
+
}
|
87
|
+
declare const Miss_base: {
|
88
|
+
new (...args: any[]): {
|
89
|
+
readonly is_miss: boolean;
|
90
|
+
};
|
91
|
+
} & typeof _Miss;
|
92
|
+
/**
|
93
|
+
* Indicates that the requested data was not available in the cache.
|
94
|
+
*/
|
95
|
+
export declare class Miss extends Miss_base {
|
96
|
+
}
|
97
|
+
declare class _Error extends Response {
|
98
|
+
_innerException: SdkError;
|
99
|
+
constructor(_innerException: SdkError);
|
100
|
+
}
|
101
|
+
declare const Error_base: {
|
102
|
+
new (...args: any[]): {
|
103
|
+
_innerException: SdkError;
|
104
|
+
message(): string;
|
105
|
+
innerException(): SdkError;
|
106
|
+
errorCode(): import("../../errors/errors").MomentoErrorCode;
|
107
|
+
toString(): string;
|
108
|
+
};
|
109
|
+
} & typeof _Error;
|
110
|
+
/**
|
111
|
+
* Indicates that an error occurred during the dictionary get fields request.
|
112
|
+
*
|
113
|
+
* This response object includes the following fields that you can use to determine
|
114
|
+
* how you would like to handle the error:
|
115
|
+
*
|
116
|
+
* - `errorCode()` - a unique Momento error code indicating the type of error that occurred.
|
117
|
+
* - `message()` - a human-readable description of the error
|
118
|
+
* - `innerException()` - the original error that caused the failure; can be re-thrown.
|
119
|
+
*/
|
120
|
+
export declare class Error extends Error_base {
|
121
|
+
}
|
122
|
+
export {};
|
@@ -0,0 +1,173 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Error = exports.Miss = exports.Hit = exports.Response = void 0;
|
4
|
+
const errors_1 = require("../../errors/errors");
|
5
|
+
const response_base_1 = require("./response-base");
|
6
|
+
const CacheDictionaryGetFieldResponse = require("./cache-dictionary-get-field");
|
7
|
+
const grpc_response_types_1 = require("./grpc-response-types");
|
8
|
+
const TEXT_DECODER = new TextDecoder();
|
9
|
+
/**
|
10
|
+
* Parent response type for a dictionary get fields request. The
|
11
|
+
* response object is resolved to a type-safe object of one of
|
12
|
+
* the following subtypes:
|
13
|
+
*
|
14
|
+
* - {Hit}
|
15
|
+
* - {Miss}
|
16
|
+
* - {Error}
|
17
|
+
*
|
18
|
+
* `instanceof` type guards can be used to operate on the appropriate subtype.
|
19
|
+
* @example
|
20
|
+
* For example:
|
21
|
+
* ```
|
22
|
+
* if (response instanceof CacheDictionaryGetFields.Error) {
|
23
|
+
* // Handle error as appropriate. The compiler will smart-cast `response` to type
|
24
|
+
* // `CacheDictionaryGetFields.Error` in this block, so you will have access to the properties
|
25
|
+
* // of the Error class; e.g. `response.errorCode()`.
|
26
|
+
* }
|
27
|
+
* ```
|
28
|
+
*/
|
29
|
+
class Response extends response_base_1.ResponseBase {
|
30
|
+
}
|
31
|
+
exports.Response = Response;
|
32
|
+
class _Hit extends Response {
|
33
|
+
constructor(items, fields) {
|
34
|
+
super();
|
35
|
+
this.responses = [];
|
36
|
+
this.items = items;
|
37
|
+
this.fields = fields;
|
38
|
+
items.forEach((item, index) => {
|
39
|
+
if (item.result === grpc_response_types_1._ECacheResult.Hit) {
|
40
|
+
this.responses.push(new CacheDictionaryGetFieldResponse.Hit(item.cacheBody, fields[index]));
|
41
|
+
}
|
42
|
+
else if (item.result === grpc_response_types_1._ECacheResult.Miss) {
|
43
|
+
this.responses.push(new CacheDictionaryGetFieldResponse.Miss(fields[index]));
|
44
|
+
}
|
45
|
+
else {
|
46
|
+
this.responses.push(new CacheDictionaryGetFieldResponse.Error(new errors_1.UnknownError(item.result.toString()), fields[index]));
|
47
|
+
}
|
48
|
+
});
|
49
|
+
}
|
50
|
+
/**
|
51
|
+
* Returns the data as a Map whose keys and values are byte arrays.
|
52
|
+
* @returns {Map<Uint8Array, Uint8Array>}
|
53
|
+
*/
|
54
|
+
valueMapUint8ArrayUint8Array() {
|
55
|
+
return this.items.reduce((acc, item, index) => {
|
56
|
+
if (item.result === grpc_response_types_1._ECacheResult.Hit) {
|
57
|
+
acc.set(this.fields[index], item.cacheBody);
|
58
|
+
}
|
59
|
+
return acc;
|
60
|
+
}, new Map());
|
61
|
+
}
|
62
|
+
/**
|
63
|
+
* Returns the data as a Map whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
64
|
+
* @returns {Map<string, string>}
|
65
|
+
*/
|
66
|
+
valueMapStringString() {
|
67
|
+
return this.items.reduce((acc, item, index) => {
|
68
|
+
if (item.result === grpc_response_types_1._ECacheResult.Hit) {
|
69
|
+
acc.set(TEXT_DECODER.decode(this.fields[index]), TEXT_DECODER.decode(item.cacheBody));
|
70
|
+
}
|
71
|
+
return acc;
|
72
|
+
}, new Map());
|
73
|
+
}
|
74
|
+
/**
|
75
|
+
* Returns the data as a Map whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
76
|
+
* This is a convenience alias for {valueMapStringString}.
|
77
|
+
* @returns {Map<string, string>}
|
78
|
+
*/
|
79
|
+
valueMap() {
|
80
|
+
return this.valueMapStringString();
|
81
|
+
}
|
82
|
+
/**
|
83
|
+
* Returns the data as a Map whose keys are utf-8 strings, decoded from the underlying byte array, and whose values
|
84
|
+
* are byte arrays.
|
85
|
+
* @returns {Map<string, Uint8Array>}
|
86
|
+
*/
|
87
|
+
valueMapStringUint8Array() {
|
88
|
+
return this.items.reduce((acc, item, index) => {
|
89
|
+
if (item.result === grpc_response_types_1._ECacheResult.Hit) {
|
90
|
+
acc.set(TEXT_DECODER.decode(this.fields[index]), item.cacheBody);
|
91
|
+
}
|
92
|
+
return acc;
|
93
|
+
}, new Map());
|
94
|
+
}
|
95
|
+
/**
|
96
|
+
* Returns the data as a Record whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
97
|
+
* This can be used in most places where an Object is desired.
|
98
|
+
* @returns {Record<string, string>}
|
99
|
+
*/
|
100
|
+
valueRecordStringString() {
|
101
|
+
return this.items.reduce((acc, item, index) => {
|
102
|
+
if (item.result === grpc_response_types_1._ECacheResult.Hit) {
|
103
|
+
acc[TEXT_DECODER.decode(this.fields[index])] = TEXT_DECODER.decode(item.cacheBody);
|
104
|
+
}
|
105
|
+
return acc;
|
106
|
+
}, {});
|
107
|
+
}
|
108
|
+
/**
|
109
|
+
* Returns the data as a Record whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
|
110
|
+
* This can be used in most places where an Object is desired. This is a convenience alias for
|
111
|
+
* {valueRecordStringString}.
|
112
|
+
* @returns {Record<string, string>}
|
113
|
+
*/
|
114
|
+
valueRecord() {
|
115
|
+
return this.valueRecordStringString();
|
116
|
+
}
|
117
|
+
/**
|
118
|
+
* Returns the data as a Record whose keys are utf-8 strings, decoded from the underlying byte array, and whose
|
119
|
+
* values are byte arrays. This can be used in most places where an Object is desired.
|
120
|
+
* @returns {Record<string, Uint8Array>}
|
121
|
+
*/
|
122
|
+
valueRecordStringUint8Array() {
|
123
|
+
return this.items.reduce((acc, item, index) => {
|
124
|
+
if (item.result === grpc_response_types_1._ECacheResult.Hit) {
|
125
|
+
acc[TEXT_DECODER.decode(this.fields[index])] = item.cacheBody;
|
126
|
+
}
|
127
|
+
return acc;
|
128
|
+
}, {});
|
129
|
+
}
|
130
|
+
toString() {
|
131
|
+
let stringRepresentation = '';
|
132
|
+
this.valueMapStringString().forEach((value, key) => {
|
133
|
+
const keyValue = `${key}: ${value}, `;
|
134
|
+
stringRepresentation = stringRepresentation + keyValue;
|
135
|
+
});
|
136
|
+
return `${super.toString()}: valueDictionaryStringString: ${stringRepresentation.slice(0, -2)}`;
|
137
|
+
}
|
138
|
+
}
|
139
|
+
/**
|
140
|
+
* Indicates that the requested data was successfully retrieved from the cache. Provides
|
141
|
+
* `value*` accessors to retrieve the data in the appropriate format.
|
142
|
+
*/
|
143
|
+
class Hit extends (0, response_base_1.ResponseHit)(_Hit) {
|
144
|
+
}
|
145
|
+
exports.Hit = Hit;
|
146
|
+
class _Miss extends Response {
|
147
|
+
}
|
148
|
+
/**
|
149
|
+
* Indicates that the requested data was not available in the cache.
|
150
|
+
*/
|
151
|
+
class Miss extends (0, response_base_1.ResponseMiss)(_Miss) {
|
152
|
+
}
|
153
|
+
exports.Miss = Miss;
|
154
|
+
class _Error extends Response {
|
155
|
+
constructor(_innerException) {
|
156
|
+
super();
|
157
|
+
this._innerException = _innerException;
|
158
|
+
}
|
159
|
+
}
|
160
|
+
/**
|
161
|
+
* Indicates that an error occurred during the dictionary get fields request.
|
162
|
+
*
|
163
|
+
* This response object includes the following fields that you can use to determine
|
164
|
+
* how you would like to handle the error:
|
165
|
+
*
|
166
|
+
* - `errorCode()` - a unique Momento error code indicating the type of error that occurred.
|
167
|
+
* - `message()` - a human-readable description of the error
|
168
|
+
* - `innerException()` - the original error that caused the failure; can be re-thrown.
|
169
|
+
*/
|
170
|
+
class Error extends (0, response_base_1.ResponseError)(_Error) {
|
171
|
+
}
|
172
|
+
exports.Error = Error;
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cache-dictionary-get-fields.js","sourceRoot":"","sources":["../../../../src/messages/responses/cache-dictionary-get-fields.ts"],"names":[],"mappings":"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","sourcesContent":["import {SdkError, UnknownError} from '../../errors/errors';\nimport {\n  ResponseBase,\n  ResponseHit,\n  ResponseMiss,\n  ResponseError,\n} from './response-base';\nimport * as CacheDictionaryGetFieldResponse from './cache-dictionary-get-field';\nimport {_DictionaryGetResponsePart, _ECacheResult} from './grpc-response-types';\n\nconst TEXT_DECODER = new TextDecoder();\ntype CacheDictionaryGetFieldResponseType =\n  | CacheDictionaryGetFieldResponse.Hit\n  | CacheDictionaryGetFieldResponse.Miss\n  | CacheDictionaryGetFieldResponse.Error;\n\n/**\n * Parent response type for a dictionary get fields request.  The\n * response object is resolved to a type-safe object of one of\n * the following subtypes:\n *\n * - {Hit}\n * - {Miss}\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 CacheDictionaryGetFields.Error) {\n *   // Handle error as appropriate.  The compiler will smart-cast `response` to type\n *   // `CacheDictionaryGetFields.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\nclass _Hit extends Response {\n  private readonly items: _DictionaryGetResponsePart[];\n  private readonly fields: Uint8Array[];\n  public responses: CacheDictionaryGetFieldResponseType[] = [];\n\n  constructor(items: _DictionaryGetResponsePart[], fields: Uint8Array[]) {\n    super();\n    this.items = items;\n    this.fields = fields;\n\n    items.forEach((item, index) => {\n      if (item.result === _ECacheResult.Hit) {\n        this.responses.push(\n          new CacheDictionaryGetFieldResponse.Hit(item.cacheBody, fields[index])\n        );\n      } else if (item.result === _ECacheResult.Miss) {\n        this.responses.push(\n          new CacheDictionaryGetFieldResponse.Miss(fields[index])\n        );\n      } else {\n        this.responses.push(\n          new CacheDictionaryGetFieldResponse.Error(\n            new UnknownError(item.result.toString()),\n            fields[index]\n          )\n        );\n      }\n    });\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 valueMapUint8ArrayUint8Array(): Map<Uint8Array, Uint8Array> {\n    return this.items.reduce((acc, item, index) => {\n      if (item.result === _ECacheResult.Hit) {\n        acc.set(this.fields[index], item.cacheBody);\n      }\n      return acc;\n    }, new Map<Uint8Array, Uint8Array>());\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 valueMapStringString(): Map<string, string> {\n    return this.items.reduce((acc, item, index) => {\n      if (item.result === _ECacheResult.Hit) {\n        acc.set(\n          TEXT_DECODER.decode(this.fields[index]),\n          TEXT_DECODER.decode(item.cacheBody)\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 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 valueMap(): Map<string, string> {\n    return this.valueMapStringString();\n  }\n\n  /**\n   * Returns the data as a Map whose keys are utf-8 strings, decoded from the underlying byte array, and whose values\n   * are byte arrays.\n   * @returns {Map<string, Uint8Array>}\n   */\n  public valueMapStringUint8Array(): Map<string, Uint8Array> {\n    return this.items.reduce((acc, item, index) => {\n      if (item.result === _ECacheResult.Hit) {\n        acc.set(TEXT_DECODER.decode(this.fields[index]), item.cacheBody);\n      }\n      return acc;\n    }, new Map<string, Uint8Array>());\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 valueRecordStringString(): Record<string, string> {\n    return this.items.reduce<Record<string, string>>((acc, item, index) => {\n      if (item.result === _ECacheResult.Hit) {\n        acc[TEXT_DECODER.decode(this.fields[index])] = TEXT_DECODER.decode(\n          item.cacheBody\n        );\n      }\n      return acc;\n    }, {});\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 valueRecord(): Record<string, string> {\n    return this.valueRecordStringString();\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 valueRecordStringUint8Array(): Record<string, Uint8Array> {\n    return this.items.reduce<Record<string, Uint8Array>>((acc, item, index) => {\n      if (item.result === _ECacheResult.Hit) {\n        acc[TEXT_DECODER.decode(this.fields[index])] = item.cacheBody;\n      }\n      return acc;\n    }, {});\n  }\n\n  public override toString(): string {\n    let stringRepresentation = '';\n    this.valueMapStringString().forEach((value, key) => {\n      const keyValue = `${key}: ${value}, `;\n      stringRepresentation = stringRepresentation + keyValue;\n    });\n    return `${super.toString()}: valueDictionaryStringString: ${stringRepresentation.slice(\n      0,\n      -2\n    )}`;\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 Hit extends ResponseHit(_Hit) {}\n\nclass _Miss extends Response {}\n\n/**\n * Indicates that the requested data was not available in the cache.\n */\nexport class Miss extends ResponseMiss(_Miss) {}\n\nclass _Error extends Response {\n  constructor(public _innerException: SdkError) {\n    super();\n  }\n}\n\n/**\n * Indicates that an error occurred during the dictionary get fields 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,69 @@
|
|
1
|
+
import { SdkError } from '../../errors/errors';
|
2
|
+
import { ResponseBase } from './response-base';
|
3
|
+
/**
|
4
|
+
* Parent response type for a dictionary increment request. The
|
5
|
+
* response object is resolved to a type-safe object of one of
|
6
|
+
* the following subtypes:
|
7
|
+
*
|
8
|
+
* - {Success}
|
9
|
+
* - {Error}
|
10
|
+
*
|
11
|
+
* `instanceof` type guards can be used to operate on the appropriate subtype.
|
12
|
+
* @example
|
13
|
+
* For example:
|
14
|
+
* ```
|
15
|
+
* if (response instanceof CacheDictionaryIncrement.Error) {
|
16
|
+
* // Handle error as appropriate. The compiler will smart-cast `response` to type
|
17
|
+
* // `CacheDictionaryIncrement.Error` in this block, so you will have access to the properties
|
18
|
+
* // of the Error class; e.g. `response.errorCode()`.
|
19
|
+
* }
|
20
|
+
* ```
|
21
|
+
*/
|
22
|
+
export declare abstract class Response extends ResponseBase {
|
23
|
+
}
|
24
|
+
declare class _Success extends Response {
|
25
|
+
private readonly value;
|
26
|
+
constructor(value: number);
|
27
|
+
/**
|
28
|
+
* The new value of the element after incrementing.
|
29
|
+
* @returns {number}
|
30
|
+
*/
|
31
|
+
valueNumber(): number;
|
32
|
+
toString(): string;
|
33
|
+
}
|
34
|
+
declare const Success_base: {
|
35
|
+
new (...args: any[]): {
|
36
|
+
readonly is_success: boolean;
|
37
|
+
};
|
38
|
+
} & typeof _Success;
|
39
|
+
/**
|
40
|
+
* Indicates a Successful dictionary increment request.
|
41
|
+
*/
|
42
|
+
export declare class Success extends Success_base {
|
43
|
+
}
|
44
|
+
declare class _Error extends Response {
|
45
|
+
protected _innerException: SdkError;
|
46
|
+
constructor(_innerException: SdkError);
|
47
|
+
}
|
48
|
+
declare const Error_base: {
|
49
|
+
new (...args: any[]): {
|
50
|
+
_innerException: SdkError;
|
51
|
+
message(): string;
|
52
|
+
innerException(): SdkError;
|
53
|
+
errorCode(): import("../../errors/errors").MomentoErrorCode;
|
54
|
+
toString(): string;
|
55
|
+
};
|
56
|
+
} & typeof _Error;
|
57
|
+
/**
|
58
|
+
* Indicates that an error occurred during the dictionary increment request.
|
59
|
+
*
|
60
|
+
* This response object includes the following fields that you can use to determine
|
61
|
+
* how you would like to handle the error:
|
62
|
+
*
|
63
|
+
* - `errorCode()` - a unique Momento error code indicating the type of error that occurred.
|
64
|
+
* - `message()` - a human-readable description of the error
|
65
|
+
* - `innerException()` - the original error that caused the failure; can be re-thrown.
|
66
|
+
*/
|
67
|
+
export declare class Error extends Error_base {
|
68
|
+
}
|
69
|
+
export {};
|
@@ -0,0 +1,68 @@
|
|
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 dictionary increment 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 CacheDictionaryIncrement.Error) {
|
18
|
+
* // Handle error as appropriate. The compiler will smart-cast `response` to type
|
19
|
+
* // `CacheDictionaryIncrement.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
|
+
}
|
26
|
+
exports.Response = Response;
|
27
|
+
class _Success extends Response {
|
28
|
+
constructor(value) {
|
29
|
+
super();
|
30
|
+
this.value = value;
|
31
|
+
}
|
32
|
+
/**
|
33
|
+
* The new value of the element after incrementing.
|
34
|
+
* @returns {number}
|
35
|
+
*/
|
36
|
+
valueNumber() {
|
37
|
+
return this.value;
|
38
|
+
}
|
39
|
+
toString() {
|
40
|
+
return `${super.toString()}: value: ${this.valueNumber()}`;
|
41
|
+
}
|
42
|
+
}
|
43
|
+
/**
|
44
|
+
* Indicates a Successful dictionary increment request.
|
45
|
+
*/
|
46
|
+
class Success extends (0, response_base_1.ResponseSuccess)(_Success) {
|
47
|
+
}
|
48
|
+
exports.Success = Success;
|
49
|
+
class _Error extends Response {
|
50
|
+
constructor(_innerException) {
|
51
|
+
super();
|
52
|
+
this._innerException = _innerException;
|
53
|
+
}
|
54
|
+
}
|
55
|
+
/**
|
56
|
+
* Indicates that an error occurred during the dictionary increment request.
|
57
|
+
*
|
58
|
+
* This response object includes the following fields that you can use to determine
|
59
|
+
* how you would like to handle the error:
|
60
|
+
*
|
61
|
+
* - `errorCode()` - a unique Momento error code indicating the type of error that occurred.
|
62
|
+
* - `message()` - a human-readable description of the error
|
63
|
+
* - `innerException()` - the original error that caused the failure; can be re-thrown.
|
64
|
+
*/
|
65
|
+
class Error extends (0, response_base_1.ResponseError)(_Error) {
|
66
|
+
}
|
67
|
+
exports.Error = Error;
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FjaGUtZGljdGlvbmFyeS1pbmNyZW1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbWVzc2FnZXMvcmVzcG9uc2VzL2NhY2hlLWRpY3Rpb25hcnktaW5jcmVtZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLG1EQUE2RTtBQUU3RTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBa0JHO0FBQ0gsTUFBc0IsUUFBUyxTQUFRLDRCQUFZO0NBQUc7QUFBdEQsNEJBQXNEO0FBRXRELE1BQU0sUUFBUyxTQUFRLFFBQVE7SUFHN0IsWUFBWSxLQUFhO1FBQ3ZCLEtBQUssRUFBRSxDQUFDO1FBQ1IsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7SUFDckIsQ0FBQztJQUVEOzs7T0FHRztJQUNJLFdBQVc7UUFDaEIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3BCLENBQUM7SUFFZSxRQUFRO1FBQ3RCLE9BQU8sR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFFLFlBQVksSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLENBQUM7SUFDN0QsQ0FBQztDQUNGO0FBRUQ7O0dBRUc7QUFDSCxNQUFhLE9BQVEsU0FBUSxJQUFBLCtCQUFlLEVBQUMsUUFBUSxDQUFDO0NBQUc7QUFBekQsMEJBQXlEO0FBRXpELE1BQU0sTUFBTyxTQUFRLFFBQVE7SUFDM0IsWUFBc0IsZUFBeUI7UUFDN0MsS0FBSyxFQUFFLENBQUM7UUFEWSxvQkFBZSxHQUFmLGVBQWUsQ0FBVTtJQUUvQyxDQUFDO0NBQ0Y7QUFFRDs7Ozs7Ozs7O0dBU0c7QUFDSCxNQUFhLEtBQU0sU0FBUSxJQUFBLDZCQUFhLEVBQUMsTUFBTSxDQUFDO0NBQUc7QUFBbkQsc0JBQW1EIiwic291cmNlc0NvbnRlbnQiOlsiLy8gb2xkZXIgdmVyc2lvbnMgb2Ygbm9kZSBkb24ndCBoYXZlIHRoZSBnbG9iYWwgdXRpbCB2YXJpYWJsZXMgaHR0cHM6Ly9naXRodWIuY29tL25vZGVqcy9ub2RlL2lzc3Vlcy8yMDM2NVxuaW1wb3J0IHtTZGtFcnJvcn0gZnJvbSAnLi4vLi4vZXJyb3JzL2Vycm9ycyc7XG5pbXBvcnQge1Jlc3BvbnNlQmFzZSwgUmVzcG9uc2VFcnJvciwgUmVzcG9uc2VTdWNjZXNzfSBmcm9tICcuL3Jlc3BvbnNlLWJhc2UnO1xuXG4vKipcbiAqIFBhcmVudCByZXNwb25zZSB0eXBlIGZvciBhIGRpY3Rpb25hcnkgaW5jcmVtZW50IHJlcXVlc3QuICBUaGVcbiAqIHJlc3BvbnNlIG9iamVjdCBpcyByZXNvbHZlZCB0byBhIHR5cGUtc2FmZSBvYmplY3Qgb2Ygb25lIG9mXG4gKiB0aGUgZm9sbG93aW5nIHN1YnR5cGVzOlxuICpcbiAqIC0ge1N1Y2Nlc3N9XG4gKiAtIHtFcnJvcn1cbiAqXG4gKiBgaW5zdGFuY2VvZmAgdHlwZSBndWFyZHMgY2FuIGJlIHVzZWQgdG8gb3BlcmF0ZSBvbiB0aGUgYXBwcm9wcmlhdGUgc3VidHlwZS5cbiAqIEBleGFtcGxlXG4gKiBGb3IgZXhhbXBsZTpcbiAqIGBgYFxuICogaWYgKHJlc3BvbnNlIGluc3RhbmNlb2YgQ2FjaGVEaWN0aW9uYXJ5SW5jcmVtZW50LkVycm9yKSB7XG4gKiAgIC8vIEhhbmRsZSBlcnJvciBhcyBhcHByb3ByaWF0ZS4gIFRoZSBjb21waWxlciB3aWxsIHNtYXJ0LWNhc3QgYHJlc3BvbnNlYCB0byB0eXBlXG4gKiAgIC8vIGBDYWNoZURpY3Rpb25hcnlJbmNyZW1lbnQuRXJyb3JgIGluIHRoaXMgYmxvY2ssIHNvIHlvdSB3aWxsIGhhdmUgYWNjZXNzIHRvIHRoZSBwcm9wZXJ0aWVzXG4gKiAgIC8vIG9mIHRoZSBFcnJvciBjbGFzczsgZS5nLiBgcmVzcG9uc2UuZXJyb3JDb2RlKClgLlxuICogfVxuICogYGBgXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBSZXNwb25zZSBleHRlbmRzIFJlc3BvbnNlQmFzZSB7fVxuXG5jbGFzcyBfU3VjY2VzcyBleHRlbmRzIFJlc3BvbnNlIHtcbiAgcHJpdmF0ZSByZWFkb25seSB2YWx1ZTogbnVtYmVyO1xuXG4gIGNvbnN0cnVjdG9yKHZhbHVlOiBudW1iZXIpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMudmFsdWUgPSB2YWx1ZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGUgbmV3IHZhbHVlIG9mIHRoZSBlbGVtZW50IGFmdGVyIGluY3JlbWVudGluZy5cbiAgICogQHJldHVybnMge251bWJlcn1cbiAgICovXG4gIHB1YmxpYyB2YWx1ZU51bWJlcigpOiBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLnZhbHVlO1xuICB9XG5cbiAgcHVibGljIG92ZXJyaWRlIHRvU3RyaW5nKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGAke3N1cGVyLnRvU3RyaW5nKCl9OiB2YWx1ZTogJHt0aGlzLnZhbHVlTnVtYmVyKCl9YDtcbiAgfVxufVxuXG4vKipcbiAqIEluZGljYXRlcyBhIFN1Y2Nlc3NmdWwgZGljdGlvbmFyeSBpbmNyZW1lbnQgcmVxdWVzdC5cbiAqL1xuZXhwb3J0IGNsYXNzIFN1Y2Nlc3MgZXh0ZW5kcyBSZXNwb25zZVN1Y2Nlc3MoX1N1Y2Nlc3MpIHt9XG5cbmNsYXNzIF9FcnJvciBleHRlbmRzIFJlc3BvbnNlIHtcbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIF9pbm5lckV4Y2VwdGlvbjogU2RrRXJyb3IpIHtcbiAgICBzdXBlcigpO1xuICB9XG59XG5cbi8qKlxuICogSW5kaWNhdGVzIHRoYXQgYW4gZXJyb3Igb2NjdXJyZWQgZHVyaW5nIHRoZSBkaWN0aW9uYXJ5IGluY3JlbWVudCByZXF1ZXN0LlxuICpcbiAqIFRoaXMgcmVzcG9uc2Ugb2JqZWN0IGluY2x1ZGVzIHRoZSBmb2xsb3dpbmcgZmllbGRzIHRoYXQgeW91IGNhbiB1c2UgdG8gZGV0ZXJtaW5lXG4gKiBob3cgeW91IHdvdWxkIGxpa2UgdG8gaGFuZGxlIHRoZSBlcnJvcjpcbiAqXG4gKiAtIGBlcnJvckNvZGUoKWAgLSBhIHVuaXF1ZSBNb21lbnRvIGVycm9yIGNvZGUgaW5kaWNhdGluZyB0aGUgdHlwZSBvZiBlcnJvciB0aGF0IG9jY3VycmVkLlxuICogLSBgbWVzc2FnZSgpYCAtIGEgaHVtYW4tcmVhZGFibGUgZGVzY3JpcHRpb24gb2YgdGhlIGVycm9yXG4gKiAtIGBpbm5lckV4Y2VwdGlvbigpYCAtIHRoZSBvcmlnaW5hbCBlcnJvciB0aGF0IGNhdXNlZCB0aGUgZmFpbHVyZTsgY2FuIGJlIHJlLXRocm93bi5cbiAqL1xuZXhwb3J0IGNsYXNzIEVycm9yIGV4dGVuZHMgUmVzcG9uc2VFcnJvcihfRXJyb3IpIHt9XG4iXX0=
|