@gomomento/sdk-core 1.85.0 → 1.87.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.
Files changed (33) hide show
  1. package/dist/src/auth/credential-provider.d.ts +26 -0
  2. package/dist/src/auth/credential-provider.js +45 -7
  3. package/dist/src/index.d.ts +1 -0
  4. package/dist/src/index.js +2 -1
  5. package/dist/src/internal/clients/cache/AbstractCacheClient.d.ts +1 -1
  6. package/dist/src/internal/clients/cache/AbstractCacheClient.js +1 -1
  7. package/dist/src/internal/clients/pubsub/AbstractTopicClient.d.ts +4 -1
  8. package/dist/src/internal/clients/pubsub/AbstractTopicClient.js +15 -3
  9. package/dist/src/internal/utils/auth.d.ts +7 -3
  10. package/dist/src/internal/utils/auth.js +19 -7
  11. package/dist/src/messages/responses/cache-batch-set.d.ts +1 -4
  12. package/dist/src/messages/responses/cache-dictionary-fetch.d.ts +18 -54
  13. package/dist/src/messages/responses/cache-dictionary-fetch.js +23 -46
  14. package/dist/src/messages/responses/cache-dictionary-get-field.d.ts +19 -58
  15. package/dist/src/messages/responses/cache-dictionary-get-field.js +19 -52
  16. package/dist/src/messages/responses/cache-dictionary-get-fields.d.ts +19 -56
  17. package/dist/src/messages/responses/cache-dictionary-get-fields.js +27 -50
  18. package/dist/src/messages/responses/cache-get.d.ts +19 -54
  19. package/dist/src/messages/responses/cache-get.js +22 -45
  20. package/dist/src/messages/responses/cache-list-concatenate-back.d.ts +10 -0
  21. package/dist/src/messages/responses/cache-list-length.d.ts +11 -4
  22. package/dist/src/messages/responses/cache-set-add-element.d.ts +0 -10
  23. package/dist/src/messages/responses/cache-set-if-absent.d.ts +1 -10
  24. package/dist/src/messages/responses/cache-set.d.ts +10 -43
  25. package/dist/src/messages/responses/cache-set.js +13 -34
  26. package/dist/src/messages/responses/create-cache.d.ts +0 -10
  27. package/dist/src/messages/responses/enums/index.d.ts +24 -0
  28. package/dist/src/messages/responses/enums/index.js +33 -0
  29. package/dist/src/messages/responses/response-base.d.ts +14 -0
  30. package/dist/src/messages/responses/response-base.js +35 -2
  31. package/dist/src/messages/responses/webhook/list-webhooks.d.ts +10 -1
  32. package/dist/src/messages/responses/webhook/put-webhook.d.ts +1 -10
  33. package/package.json +1 -1
@@ -20,10 +20,14 @@ interface TokenAndEndpoints {
20
20
  tokenEndpoint: string | undefined;
21
21
  authToken: string;
22
22
  }
23
+ export interface Endpoint {
24
+ endpoint: string;
25
+ secureConnection?: boolean;
26
+ }
23
27
  export interface AllEndpoints {
24
- controlEndpoint: string;
25
- cacheEndpoint: string;
26
- tokenEndpoint: string;
28
+ controlEndpoint: Endpoint;
29
+ cacheEndpoint: Endpoint;
30
+ tokenEndpoint: Endpoint;
27
31
  }
28
32
  export declare function populateAllEndpointsFromBaseEndpoint(endpointOverride: BaseEndpointOverride): AllEndpoints;
29
33
  /**
@@ -15,9 +15,18 @@ function populateAllEndpointsFromBaseEndpoint(endpointOverride) {
15
15
  prefix = `${endpointOverride.endpointPrefix}.`;
16
16
  }
17
17
  return {
18
- controlEndpoint: `${prefix}control.${endpointOverride.baseEndpoint}`,
19
- cacheEndpoint: `${prefix}cache.${endpointOverride.baseEndpoint}`,
20
- tokenEndpoint: `${prefix}token.${endpointOverride.baseEndpoint}`,
18
+ controlEndpoint: {
19
+ endpoint: `${prefix}control.${endpointOverride.baseEndpoint}`,
20
+ secureConnection: endpointOverride.secureConnection,
21
+ },
22
+ cacheEndpoint: {
23
+ endpoint: `${prefix}cache.${endpointOverride.baseEndpoint}`,
24
+ secureConnection: endpointOverride.secureConnection,
25
+ },
26
+ tokenEndpoint: {
27
+ endpoint: `${prefix}token.${endpointOverride.baseEndpoint}`,
28
+ secureConnection: endpointOverride.secureConnection,
29
+ },
21
30
  };
22
31
  }
23
32
  exports.populateAllEndpointsFromBaseEndpoint = populateAllEndpointsFromBaseEndpoint;
@@ -40,10 +49,13 @@ const decodeAuthToken = (token) => {
40
49
  if (!base64DecodedToken.endpoint || !base64DecodedToken.api_key) {
41
50
  throw new errors_1.InvalidArgumentError('failed to parse token');
42
51
  }
52
+ const endpoints = populateAllEndpointsFromBaseEndpoint({
53
+ baseEndpoint: base64DecodedToken.endpoint,
54
+ });
43
55
  return {
44
- ...populateAllEndpointsFromBaseEndpoint({
45
- baseEndpoint: base64DecodedToken.endpoint,
46
- }),
56
+ controlEndpoint: endpoints.controlEndpoint.endpoint,
57
+ cacheEndpoint: endpoints.cacheEndpoint.endpoint,
58
+ tokenEndpoint: endpoints.tokenEndpoint.endpoint,
47
59
  authToken: base64DecodedToken.api_key,
48
60
  };
49
61
  }
@@ -69,4 +81,4 @@ exports.decodeAuthToken = decodeAuthToken;
69
81
  class InternalSuperUserPermissions extends permission_scope_1.PredefinedScope {
70
82
  }
71
83
  exports.InternalSuperUserPermissions = InternalSuperUserPermissions;
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9pbnRlcm5hbC91dGlscy9hdXRoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHlDQUFrRDtBQUNsRCwyQ0FBbUM7QUFDbkMsNkNBQXNDO0FBQ3RDLHFDQUEwQztBQUMxQyx5RUFBbUU7QUFtQm5FLFNBQVMscUJBQXFCLENBQUksU0FBaUI7SUFDakQsT0FBTyxJQUFBLG9CQUFTLEVBQUksU0FBUyxDQUFDLENBQUM7QUFDakMsQ0FBQztBQWlCRCxTQUFnQixvQ0FBb0MsQ0FDbEQsZ0JBQXNDO0lBRXRDLElBQUksTUFBTSxHQUFHLEVBQUUsQ0FBQztJQUNoQixJQUFJLGdCQUFnQixDQUFDLGNBQWMsRUFBRTtRQUNuQyxNQUFNLEdBQUcsR0FBRyxnQkFBZ0IsQ0FBQyxjQUFjLEdBQUcsQ0FBQztLQUNoRDtJQUNELE9BQU87UUFDTCxlQUFlLEVBQUUsR0FBRyxNQUFNLFdBQVcsZ0JBQWdCLENBQUMsWUFBWSxFQUFFO1FBQ3BFLGFBQWEsRUFBRSxHQUFHLE1BQU0sU0FBUyxnQkFBZ0IsQ0FBQyxZQUFZLEVBQUU7UUFDaEUsYUFBYSxFQUFFLEdBQUcsTUFBTSxTQUFTLGdCQUFnQixDQUFDLFlBQVksRUFBRTtLQUNqRSxDQUFDO0FBQ0osQ0FBQztBQVpELG9GQVlDO0FBRUQ7OztHQUdHO0FBQ0ksTUFBTSxlQUFlLEdBQUcsQ0FBQyxLQUFjLEVBQXFCLEVBQUU7SUFDbkUsSUFBSSxDQUFDLEtBQUssRUFBRTtRQUNWLE1BQU0sSUFBSSw2QkFBb0IsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO0tBQ3hEO0lBRUQsSUFBSTtRQUNGLHlHQUF5RztRQUN6RyxnSEFBZ0g7UUFDaEgscUhBQXFIO1FBQ3JILHlIQUF5SDtRQUN6SCxnQ0FBZ0M7UUFDaEMsSUFBSSxJQUFBLHFCQUFRLEVBQUMsS0FBSyxDQUFDLEVBQUU7WUFDbkIsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUNuQyxJQUFBLHlCQUFnQixFQUFDLEtBQUssQ0FBQyxDQUNBLENBQUM7WUFDMUIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFFBQVEsSUFBSSxDQUFDLGtCQUFrQixDQUFDLE9BQU8sRUFBRTtnQkFDL0QsTUFBTSxJQUFJLDZCQUFvQixDQUFDLHVCQUF1QixDQUFDLENBQUM7YUFDekQ7WUFDRCxPQUFPO2dCQUNMLEdBQUcsb0NBQW9DLENBQUM7b0JBQ3RDLFlBQVksRUFBRSxrQkFBa0IsQ0FBQyxRQUFRO2lCQUMxQyxDQUFDO2dCQUNGLFNBQVMsRUFBRSxrQkFBa0IsQ0FBQyxPQUFPO2FBQ3RDLENBQUM7U0FDSDthQUFNO1lBQ0wsa0hBQWtIO1lBQ2xILGdIQUFnSDtZQUNoSCxvSEFBb0g7WUFDcEgsTUFBTSxrQkFBa0IsR0FBRyxxQkFBcUIsQ0FBZSxLQUFLLENBQUMsQ0FBQztZQUN0RSxPQUFPO2dCQUNMLGVBQWUsRUFBRSxrQkFBa0IsQ0FBQyxFQUFFO2dCQUN0QyxhQUFhLEVBQUUsa0JBQWtCLENBQUMsQ0FBQztnQkFDbkMsYUFBYSxFQUFFLGtCQUFrQixDQUFDLENBQUM7Z0JBQ25DLFNBQVMsRUFBRSxLQUFLO2FBQ2pCLENBQUM7U0FDSDtLQUNGO0lBQUMsT0FBTyxDQUFDLEVBQUU7UUFDViw0RUFBNEU7UUFDNUUsTUFBTSxJQUFJLDZCQUFvQixDQUFDLDBCQUEwQixDQUFDLEVBQUUsQ0FBQyxDQUFDO0tBQy9EO0FBQ0gsQ0FBQyxDQUFDO0FBeENXLFFBQUEsZUFBZSxtQkF3QzFCO0FBRUYsTUFBYSw0QkFBNkIsU0FBUSxrQ0FBZTtDQUFHO0FBQXBFLG9FQUFvRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW52YWxpZEFyZ3VtZW50RXJyb3J9IGZyb20gJy4uLy4uL2Vycm9ycyc7XG5pbXBvcnQgand0RGVjb2RlIGZyb20gJ2p3dC1kZWNvZGUnO1xuaW1wb3J0IHtpc0Jhc2U2NH0gZnJvbSAnLi92YWxpZGF0b3JzJztcbmltcG9ydCB7ZGVjb2RlRnJvbUJhc2U2NH0gZnJvbSAnLi9zdHJpbmcnO1xuaW1wb3J0IHtQcmVkZWZpbmVkU2NvcGV9IGZyb20gJy4uLy4uL2F1dGgvdG9rZW5zL3Blcm1pc3Npb24tc2NvcGUnO1xuaW1wb3J0IHtCYXNlRW5kcG9pbnRPdmVycmlkZX0gZnJvbSAnLi4vLi4vYXV0aCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGVnYWN5Q2xhaW1zIHtcbiAgLyoqXG4gICAqIGNvbnRyb2wgcGxhbmUgZW5kcG9pbnRcbiAgICovXG4gIGNwOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBjYWNoZSBlbmRwb2ludFxuICAgKi9cbiAgYzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEJhc2U2NERlY29kZWRWMVRva2VuIHtcbiAgYXBpX2tleTogc3RyaW5nO1xuICBlbmRwb2ludDogc3RyaW5nO1xufVxuXG5mdW5jdGlvbiBkZWNvZGVBdXRoVG9rZW5DbGFpbXM8VD4oYXV0aFRva2VuOiBzdHJpbmcpOiBUIHtcbiAgcmV0dXJuIGp3dERlY29kZTxUPihhdXRoVG9rZW4pO1xufVxuXG5pbnRlcmZhY2UgVG9rZW5BbmRFbmRwb2ludHMge1xuICAvLyBJZiB3ZSBkZWNvZGUgYSBKV1QgdGhhdCBkb2Vzbid0IGFjdHVhbGx5IGhhdmUgdGhlIGNvbnRyb2xFbmRwb2ludC9jYWNoZUVuZHBvaW50IGNsYWltcywgdGhlbiB0aGV5IHdpbGwgY29tZSBiYWNrXG4gIC8vIGFzIHVuZGVmaW5lZDsgdGh1cyB3ZSBuZWVkIHRoZSB0eXBlcyBoZXJlIHRvIGJlIGBzdHJpbmcgfCB1bmRlZmluZWRgLlxuICBjb250cm9sRW5kcG9pbnQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgY2FjaGVFbmRwb2ludDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICB0b2tlbkVuZHBvaW50OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIGF1dGhUb2tlbjogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFsbEVuZHBvaW50cyB7XG4gIGNvbnRyb2xFbmRwb2ludDogc3RyaW5nO1xuICBjYWNoZUVuZHBvaW50OiBzdHJpbmc7XG4gIHRva2VuRW5kcG9pbnQ6IHN0cmluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHBvcHVsYXRlQWxsRW5kcG9pbnRzRnJvbUJhc2VFbmRwb2ludChcbiAgZW5kcG9pbnRPdmVycmlkZTogQmFzZUVuZHBvaW50T3ZlcnJpZGVcbik6IEFsbEVuZHBvaW50cyB7XG4gIGxldCBwcmVmaXggPSAnJztcbiAgaWYgKGVuZHBvaW50T3ZlcnJpZGUuZW5kcG9pbnRQcmVmaXgpIHtcbiAgICBwcmVmaXggPSBgJHtlbmRwb2ludE92ZXJyaWRlLmVuZHBvaW50UHJlZml4fS5gO1xuICB9XG4gIHJldHVybiB7XG4gICAgY29udHJvbEVuZHBvaW50OiBgJHtwcmVmaXh9Y29udHJvbC4ke2VuZHBvaW50T3ZlcnJpZGUuYmFzZUVuZHBvaW50fWAsXG4gICAgY2FjaGVFbmRwb2ludDogYCR7cHJlZml4fWNhY2hlLiR7ZW5kcG9pbnRPdmVycmlkZS5iYXNlRW5kcG9pbnR9YCxcbiAgICB0b2tlbkVuZHBvaW50OiBgJHtwcmVmaXh9dG9rZW4uJHtlbmRwb2ludE92ZXJyaWRlLmJhc2VFbmRwb2ludH1gLFxuICB9O1xufVxuXG4vKipcbiAqIEBwYXJhbSB7c3RyaW5nfSB0b2tlblxuICogQHJldHVybnMgVG9rZW5BbmRFbmRwb2ludHNcbiAqL1xuZXhwb3J0IGNvbnN0IGRlY29kZUF1dGhUb2tlbiA9ICh0b2tlbj86IHN0cmluZyk6IFRva2VuQW5kRW5kcG9pbnRzID0+IHtcbiAgaWYgKCF0b2tlbikge1xuICAgIHRocm93IG5ldyBJbnZhbGlkQXJndW1lbnRFcnJvcignbWFsZm9ybWVkIGF1dGggdG9rZW4nKTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgLy8gdjEgYXBpIHRva2VucyBkb24ndCBoYXZlIGFuIGVuZHBvaW50IGFzIHBhcnQgb2YgdGhlaXIgY2xhaW1zLiBJbnN0ZWFkLCB3aGVuIHRoZSBTREsgcmV0dXJucyB0b2tlbnMsIHdlXG4gICAgLy8gZ2l2ZSBpdCB0byB0aGVtIGFzIGEgYmFzZTY0IGVuY29kZWQgc3RyaW5nIG9mICd7IFwiYXBpX2tleVwiOiBcIjx0aGUga2V5PlwiLCBcImVuZHBvaW50XCI6IFwicHJvZC5tb21lbnRvaHEuY29tXCIgfScuXG4gICAgLy8gU2luY2UgaW4gdGhlIG5lYXIgZnV0dXJlLCBtb3N0IGN1c3RvbWVycyBhcmUgZ29pbmcgdG8gYmUgdXNpbmcgdGhlc2UgbmV3ZXIgdG9rZW5zLCB3ZSBhcmUgZmlyc3QgY2hlY2tpbmcgdG8gc2VlIGlmXG4gICAgLy8gdGhleSBhcmUgYmFzZTY0IGVuY29kZWQsIHdoaWNoIHdpbGwgdGVsbCB1cyB0aGF0IHRoZXkgYXJlIG91ciB2MSBhcGkgdG9rZW5zLiBJZiBpdHMgbm90LCB3ZSB3aWxsIGZhbGwgYmFjayB0byBkZWNvZGluZ1xuICAgIC8vIGl0IGFzIG9uZSBvZiBvdXIgbGVnYWN5IGp3dHMuXG4gICAgaWYgKGlzQmFzZTY0KHRva2VuKSkge1xuICAgICAgY29uc3QgYmFzZTY0RGVjb2RlZFRva2VuID0gSlNPTi5wYXJzZShcbiAgICAgICAgZGVjb2RlRnJvbUJhc2U2NCh0b2tlbilcbiAgICAgICkgYXMgQmFzZTY0RGVjb2RlZFYxVG9rZW47XG4gICAgICBpZiAoIWJhc2U2NERlY29kZWRUb2tlbi5lbmRwb2ludCB8fCAhYmFzZTY0RGVjb2RlZFRva2VuLmFwaV9rZXkpIHtcbiAgICAgICAgdGhyb3cgbmV3IEludmFsaWRBcmd1bWVudEVycm9yKCdmYWlsZWQgdG8gcGFyc2UgdG9rZW4nKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiB7XG4gICAgICAgIC4uLnBvcHVsYXRlQWxsRW5kcG9pbnRzRnJvbUJhc2VFbmRwb2ludCh7XG4gICAgICAgICAgYmFzZUVuZHBvaW50OiBiYXNlNjREZWNvZGVkVG9rZW4uZW5kcG9pbnQsXG4gICAgICAgIH0pLFxuICAgICAgICBhdXRoVG9rZW46IGJhc2U2NERlY29kZWRUb2tlbi5hcGlfa2V5LFxuICAgICAgfTtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gVGhpcyBkZWNvZGUgZnVuY3Rpb24gdXNlcyBnZW5lcmljcyB0byBhZHZlcnRpc2UgdGhhdCB3ZSB3aWxsIHVzdWFsbHkgZXhwZWN0IHRvIGZpbmQgdGhlIExlZ2FjeUNsYWltcy4gIEhvd2V2ZXIsXG4gICAgICAvLyBpZiB0aGUgdG9rZW4gaXMgYSB2YWxpZCBKV1QgYnV0IG5vdCBhY3R1YWxseSBvbmUgb2Ygb3VyIGxlZ2FjeSB0b2tlbnMsIHRoZSBlbmRwb2ludCBjbGFpbXMgd2lsbCBiZSB1bmRlZmluZWQsXG4gICAgICAvLyB3aGljaCBpcyB3aHkgdGhlIHJldHVybiB0eXBlIGZvciB0aGlzIGZ1bmN0aW9uIHNwZWNpZmllcyB0aGF0IHRoZSBjb250cm9sRW5kcG9pbnQvY2FjaGVFbmRwb2ludCBtYXkgYmUgdW5kZWZpbmVkLlxuICAgICAgY29uc3QgZGVjb2RlZExlZ2FjeVRva2VuID0gZGVjb2RlQXV0aFRva2VuQ2xhaW1zPExlZ2FjeUNsYWltcz4odG9rZW4pO1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgY29udHJvbEVuZHBvaW50OiBkZWNvZGVkTGVnYWN5VG9rZW4uY3AsXG4gICAgICAgIGNhY2hlRW5kcG9pbnQ6IGRlY29kZWRMZWdhY3lUb2tlbi5jLFxuICAgICAgICB0b2tlbkVuZHBvaW50OiBkZWNvZGVkTGVnYWN5VG9rZW4uYyxcbiAgICAgICAgYXV0aFRva2VuOiB0b2tlbixcbiAgICAgIH07XG4gICAgfVxuICB9IGNhdGNoIChlKSB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9yZXN0cmljdC10ZW1wbGF0ZS1leHByZXNzaW9uc1xuICAgIHRocm93IG5ldyBJbnZhbGlkQXJndW1lbnRFcnJvcihgZmFpbGVkIHRvIHBhcnNlIHRva2VuOiAke2V9YCk7XG4gIH1cbn07XG5cbmV4cG9ydCBjbGFzcyBJbnRlcm5hbFN1cGVyVXNlclBlcm1pc3Npb25zIGV4dGVuZHMgUHJlZGVmaW5lZFNjb3BlIHt9XG4iXX0=
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../../../src/internal/utils/auth.ts"],"names":[],"mappings":";;;AAAA,yCAAkD;AAClD,2CAAmC;AACnC,6CAAsC;AACtC,qCAA0C;AAC1C,yEAAmE;AAmBnE,SAAS,qBAAqB,CAAI,SAAiB;IACjD,OAAO,IAAA,oBAAS,EAAI,SAAS,CAAC,CAAC;AACjC,CAAC;AAsBD,SAAgB,oCAAoC,CAClD,gBAAsC;IAEtC,IAAI,MAAM,GAAG,EAAE,CAAC;IAChB,IAAI,gBAAgB,CAAC,cAAc,EAAE;QACnC,MAAM,GAAG,GAAG,gBAAgB,CAAC,cAAc,GAAG,CAAC;KAChD;IACD,OAAO;QACL,eAAe,EAAE;YACf,QAAQ,EAAE,GAAG,MAAM,WAAW,gBAAgB,CAAC,YAAY,EAAE;YAC7D,gBAAgB,EAAE,gBAAgB,CAAC,gBAAgB;SACpD;QACD,aAAa,EAAE;YACb,QAAQ,EAAE,GAAG,MAAM,SAAS,gBAAgB,CAAC,YAAY,EAAE;YAC3D,gBAAgB,EAAE,gBAAgB,CAAC,gBAAgB;SACpD;QACD,aAAa,EAAE;YACb,QAAQ,EAAE,GAAG,MAAM,SAAS,gBAAgB,CAAC,YAAY,EAAE;YAC3D,gBAAgB,EAAE,gBAAgB,CAAC,gBAAgB;SACpD;KACF,CAAC;AACJ,CAAC;AArBD,oFAqBC;AAED;;;GAGG;AACI,MAAM,eAAe,GAAG,CAAC,KAAc,EAAqB,EAAE;IACnE,IAAI,CAAC,KAAK,EAAE;QACV,MAAM,IAAI,6BAAoB,CAAC,sBAAsB,CAAC,CAAC;KACxD;IAED,IAAI;QACF,yGAAyG;QACzG,gHAAgH;QAChH,qHAAqH;QACrH,yHAAyH;QACzH,gCAAgC;QAChC,IAAI,IAAA,qBAAQ,EAAC,KAAK,CAAC,EAAE;YACnB,MAAM,kBAAkB,GAAG,IAAI,CAAC,KAAK,CACnC,IAAA,yBAAgB,EAAC,KAAK,CAAC,CACA,CAAC;YAC1B,IAAI,CAAC,kBAAkB,CAAC,QAAQ,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE;gBAC/D,MAAM,IAAI,6BAAoB,CAAC,uBAAuB,CAAC,CAAC;aACzD;YACD,MAAM,SAAS,GAAG,oCAAoC,CAAC;gBACrD,YAAY,EAAE,kBAAkB,CAAC,QAAQ;aAC1C,CAAC,CAAC;YACH,OAAO;gBACL,eAAe,EAAE,SAAS,CAAC,eAAe,CAAC,QAAQ;gBACnD,aAAa,EAAE,SAAS,CAAC,aAAa,CAAC,QAAQ;gBAC/C,aAAa,EAAE,SAAS,CAAC,aAAa,CAAC,QAAQ;gBAC/C,SAAS,EAAE,kBAAkB,CAAC,OAAO;aACtC,CAAC;SACH;aAAM;YACL,kHAAkH;YAClH,gHAAgH;YAChH,oHAAoH;YACpH,MAAM,kBAAkB,GAAG,qBAAqB,CAAe,KAAK,CAAC,CAAC;YACtE,OAAO;gBACL,eAAe,EAAE,kBAAkB,CAAC,EAAE;gBACtC,aAAa,EAAE,kBAAkB,CAAC,CAAC;gBACnC,aAAa,EAAE,kBAAkB,CAAC,CAAC;gBACnC,SAAS,EAAE,KAAK;aACjB,CAAC;SACH;KACF;IAAC,OAAO,CAAC,EAAE;QACV,4EAA4E;QAC5E,MAAM,IAAI,6BAAoB,CAAC,0BAA0B,CAAC,EAAE,CAAC,CAAC;KAC/D;AACH,CAAC,CAAC;AA3CW,QAAA,eAAe,mBA2C1B;AAEF,MAAa,4BAA6B,SAAQ,kCAAe;CAAG;AAApE,oEAAoE","sourcesContent":["import {InvalidArgumentError} from '../../errors';\nimport jwtDecode from 'jwt-decode';\nimport {isBase64} from './validators';\nimport {decodeFromBase64} from './string';\nimport {PredefinedScope} from '../../auth/tokens/permission-scope';\nimport {BaseEndpointOverride} from '../../auth';\n\nexport interface LegacyClaims {\n  /**\n   * control plane endpoint\n   */\n  cp: string;\n  /**\n   * cache endpoint\n   */\n  c: string;\n}\n\nexport interface Base64DecodedV1Token {\n  api_key: string;\n  endpoint: string;\n}\n\nfunction decodeAuthTokenClaims<T>(authToken: string): T {\n  return jwtDecode<T>(authToken);\n}\n\ninterface TokenAndEndpoints {\n  // If we decode a JWT that doesn't actually have the controlEndpoint/cacheEndpoint claims, then they will come back\n  // as undefined; thus we need the types here to be `string | undefined`.\n  controlEndpoint: string | undefined;\n  cacheEndpoint: string | undefined;\n  tokenEndpoint: string | undefined;\n  authToken: string;\n}\n\nexport interface Endpoint {\n  endpoint: string;\n  secureConnection?: boolean;\n}\n\nexport interface AllEndpoints {\n  controlEndpoint: Endpoint;\n  cacheEndpoint: Endpoint;\n  tokenEndpoint: Endpoint;\n}\n\nexport function populateAllEndpointsFromBaseEndpoint(\n  endpointOverride: BaseEndpointOverride\n): AllEndpoints {\n  let prefix = '';\n  if (endpointOverride.endpointPrefix) {\n    prefix = `${endpointOverride.endpointPrefix}.`;\n  }\n  return {\n    controlEndpoint: {\n      endpoint: `${prefix}control.${endpointOverride.baseEndpoint}`,\n      secureConnection: endpointOverride.secureConnection,\n    },\n    cacheEndpoint: {\n      endpoint: `${prefix}cache.${endpointOverride.baseEndpoint}`,\n      secureConnection: endpointOverride.secureConnection,\n    },\n    tokenEndpoint: {\n      endpoint: `${prefix}token.${endpointOverride.baseEndpoint}`,\n      secureConnection: endpointOverride.secureConnection,\n    },\n  };\n}\n\n/**\n * @param {string} token\n * @returns TokenAndEndpoints\n */\nexport const decodeAuthToken = (token?: string): TokenAndEndpoints => {\n  if (!token) {\n    throw new InvalidArgumentError('malformed auth token');\n  }\n\n  try {\n    // v1 api tokens don't have an endpoint as part of their claims. Instead, when the SDK returns tokens, we\n    // give it to them as a base64 encoded string of '{ \"api_key\": \"<the key>\", \"endpoint\": \"prod.momentohq.com\" }'.\n    // Since in the near future, most customers are going to be using these newer tokens, we are first checking to see if\n    // they are base64 encoded, which will tell us that they are our v1 api tokens. If its not, we will fall back to decoding\n    // it as one of our legacy jwts.\n    if (isBase64(token)) {\n      const base64DecodedToken = JSON.parse(\n        decodeFromBase64(token)\n      ) as Base64DecodedV1Token;\n      if (!base64DecodedToken.endpoint || !base64DecodedToken.api_key) {\n        throw new InvalidArgumentError('failed to parse token');\n      }\n      const endpoints = populateAllEndpointsFromBaseEndpoint({\n        baseEndpoint: base64DecodedToken.endpoint,\n      });\n      return {\n        controlEndpoint: endpoints.controlEndpoint.endpoint,\n        cacheEndpoint: endpoints.cacheEndpoint.endpoint,\n        tokenEndpoint: endpoints.tokenEndpoint.endpoint,\n        authToken: base64DecodedToken.api_key,\n      };\n    } else {\n      // This decode function uses generics to advertise that we will usually expect to find the LegacyClaims.  However,\n      // if the token is a valid JWT but not actually one of our legacy tokens, the endpoint claims will be undefined,\n      // which is why the return type for this function specifies that the controlEndpoint/cacheEndpoint may be undefined.\n      const decodedLegacyToken = decodeAuthTokenClaims<LegacyClaims>(token);\n      return {\n        controlEndpoint: decodedLegacyToken.cp,\n        cacheEndpoint: decodedLegacyToken.c,\n        tokenEndpoint: decodedLegacyToken.c,\n        authToken: token,\n      };\n    }\n  } catch (e) {\n    // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n    throw new InvalidArgumentError(`failed to parse token: ${e}`);\n  }\n};\n\nexport class InternalSuperUserPermissions extends PredefinedScope {}\n"]}
@@ -50,10 +50,7 @@ declare const Error_base: {
50
50
  new (...args: any[]): {
51
51
  _innerException: SdkError;
52
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
- */
53
+ innerException(): SdkError;
57
54
  errorCode(): import("../..").MomentoErrorCode;
58
55
  toString(): string;
59
56
  };
@@ -1,32 +1,19 @@
1
- import { ResponseBase } from './response-base';
1
+ import { ResponseBase, BaseResponseMiss, BaseResponseError } from './response-base';
2
2
  import { SdkError } from '../../errors';
3
3
  import { _DictionaryFieldValuePair } from './grpc-response-types';
4
- /**
5
- * Parent response type for a dictionary fetch request. The
6
- * response object is resolved to a type-safe object of one of
7
- * the following subtypes:
8
- *
9
- * - {Hit}
10
- * - {Miss}
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 CacheDictionaryFetch.Error) {
18
- * // Handle error as appropriate. The compiler will smart-cast `response` to type
19
- * // `CacheDictionaryFetch.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
- export declare abstract class Response extends ResponseBase {
4
+ import { DictionaryFetchResponse } from './enums';
5
+ interface IResponse {
25
6
  value(): Record<string, string> | undefined;
7
+ type: DictionaryFetchResponse;
26
8
  }
27
- declare class _Hit extends Response {
9
+ /**
10
+ * Indicates that the requested data was successfully retrieved from the cache. Provides
11
+ * `value*` accessors to retrieve the data in the appropriate format.
12
+ */
13
+ export declare class Hit extends ResponseBase implements IResponse {
28
14
  private readonly items;
29
15
  private readonly _displayListSizeLimit;
16
+ readonly type: DictionaryFetchResponse.Hit;
30
17
  constructor(items: _DictionaryFieldValuePair[]);
31
18
  /**
32
19
  * Returns the data as a Map whose keys and values are utf-8 strings, decoded from the underlying byte arrays.
@@ -74,40 +61,13 @@ declare class _Hit extends Response {
74
61
  private truncateValueStrings;
75
62
  toString(): string;
76
63
  }
77
- declare const Hit_base: {
78
- new (...args: any[]): {};
79
- } & typeof _Hit;
80
- /**
81
- * Indicates that the requested data was successfully retrieved from the cache. Provides
82
- * `value*` accessors to retrieve the data in the appropriate format.
83
- */
84
- export declare class Hit extends Hit_base {
85
- }
86
- declare class _Miss extends Response {
87
- }
88
- declare const Miss_base: {
89
- new (...args: any[]): {
90
- readonly is_miss: boolean;
91
- };
92
- } & typeof _Miss;
93
64
  /**
94
65
  * Indicates that the requested data was not available in the cache.
95
66
  */
96
- export declare class Miss extends Miss_base {
97
- }
98
- declare class _Error extends Response {
99
- protected _innerException: SdkError;
100
- constructor(_innerException: SdkError);
67
+ export declare class Miss extends BaseResponseMiss implements IResponse {
68
+ readonly type: DictionaryFetchResponse.Miss;
69
+ value(): Record<string, string> | undefined;
101
70
  }
102
- declare const Error_base: {
103
- new (...args: any[]): {
104
- _innerException: SdkError;
105
- message(): string;
106
- innerException(): SdkError;
107
- errorCode(): import("../../errors").MomentoErrorCode;
108
- toString(): string;
109
- };
110
- } & typeof _Error;
111
71
  /**
112
72
  * Indicates that an error occurred during the dictionary fetch request.
113
73
  *
@@ -118,6 +78,10 @@ declare const Error_base: {
118
78
  * - `message()` - a human-readable description of the error
119
79
  * - `innerException()` - the original error that caused the failure; can be re-thrown.
120
80
  */
121
- export declare class Error extends Error_base {
81
+ export declare class Error extends BaseResponseError implements IResponse {
82
+ readonly type: DictionaryFetchResponse.Error;
83
+ constructor(_innerException: SdkError);
84
+ value(): Record<string, string> | undefined;
122
85
  }
86
+ export type Response = Hit | Miss | Error;
123
87
  export {};
@@ -1,41 +1,18 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Error = exports.Miss = exports.Hit = exports.Response = void 0;
3
+ exports.Error = exports.Miss = exports.Hit = void 0;
4
4
  const response_base_1 = require("./response-base");
5
+ const enums_1 = require("./enums");
5
6
  const TEXT_DECODER = new TextDecoder();
6
7
  /**
7
- * Parent response type for a dictionary fetch 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 CacheDictionaryFetch.Error) {
20
- * // Handle error as appropriate. The compiler will smart-cast `response` to type
21
- * // `CacheDictionaryFetch.Error` in this block, so you will have access to the properties
22
- * // of the Error class; e.g. `response.errorCode()`.
23
- * }
24
- * ```
8
+ * Indicates that the requested data was successfully retrieved from the cache. Provides
9
+ * `value*` accessors to retrieve the data in the appropriate format.
25
10
  */
26
- class Response extends response_base_1.ResponseBase {
27
- value() {
28
- if (this instanceof Hit) {
29
- return this.value();
30
- }
31
- return undefined;
32
- }
33
- }
34
- exports.Response = Response;
35
- class _Hit extends Response {
11
+ class Hit extends response_base_1.ResponseBase {
36
12
  constructor(items) {
37
13
  super();
38
14
  this._displayListSizeLimit = 5;
15
+ this.type = enums_1.DictionaryFetchResponse.Hit;
39
16
  this.items = items;
40
17
  }
41
18
  /**
@@ -130,27 +107,20 @@ class _Hit extends Response {
130
107
  return `${super.toString()}: valueDictionaryStringString: ${this.truncateValueStrings()}`;
131
108
  }
132
109
  }
133
- /**
134
- * Indicates that the requested data was successfully retrieved from the cache. Provides
135
- * `value*` accessors to retrieve the data in the appropriate format.
136
- */
137
- class Hit extends (0, response_base_1.ResponseHit)(_Hit) {
138
- }
139
110
  exports.Hit = Hit;
140
- class _Miss extends Response {
141
- }
142
111
  /**
143
112
  * Indicates that the requested data was not available in the cache.
144
113
  */
145
- class Miss extends (0, response_base_1.ResponseMiss)(_Miss) {
146
- }
147
- exports.Miss = Miss;
148
- class _Error extends Response {
149
- constructor(_innerException) {
150
- super();
151
- this._innerException = _innerException;
114
+ class Miss extends response_base_1.BaseResponseMiss {
115
+ constructor() {
116
+ super(...arguments);
117
+ this.type = enums_1.DictionaryFetchResponse.Miss;
118
+ }
119
+ value() {
120
+ return undefined;
152
121
  }
153
122
  }
123
+ exports.Miss = Miss;
154
124
  /**
155
125
  * Indicates that an error occurred during the dictionary fetch request.
156
126
  *
@@ -161,7 +131,14 @@ class _Error extends Response {
161
131
  * - `message()` - a human-readable description of the error
162
132
  * - `innerException()` - the original error that caused the failure; can be re-thrown.
163
133
  */
164
- class Error extends (0, response_base_1.ResponseError)(_Error) {
134
+ class Error extends response_base_1.BaseResponseError {
135
+ constructor(_innerException) {
136
+ super(_innerException);
137
+ this.type = enums_1.DictionaryFetchResponse.Error;
138
+ }
139
+ value() {
140
+ return undefined;
141
+ }
165
142
  }
166
143
  exports.Error = Error;
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cache-dictionary-fetch.js","sourceRoot":"","sources":["../../../../src/messages/responses/cache-dictionary-fetch.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ResponseBase,\n  ResponseHit,\n  ResponseMiss,\n  ResponseError,\n} from './response-base';\nimport {SdkError} from '../../errors';\nimport {_DictionaryFieldValuePair} from './grpc-response-types';\n\nconst TEXT_DECODER = new TextDecoder();\n\n/**\n * Parent response type for a dictionary fetch 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 CacheDictionaryFetch.Error) {\n *   // Handle error as appropriate.  The compiler will smart-cast `response` to type\n *   // `CacheDictionaryFetch.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 value(): Record<string, string> | undefined {\n    if (this instanceof Hit) {\n      return (this as Hit).value();\n    }\n    return undefined;\n  }\n}\n\nclass _Hit extends Response {\n  private readonly items: _DictionaryFieldValuePair[];\n  private readonly _displayListSizeLimit = 5;\n\n  constructor(items: _DictionaryFieldValuePair[]) {\n    super();\n    this.items = items;\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 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) => {\n      acc.set(TEXT_DECODER.decode(item.field), TEXT_DECODER.decode(item.value));\n      return acc;\n    }, new Map<string, string>());\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) => {\n      acc.set(TEXT_DECODER.decode(item.field), item.value);\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.  This is a convenience alias for\n   * {valueRecordStringString}.\n   * @returns {Record<string, string>}\n   */\n  public value(): Record<string, string> {\n    return this.valueRecordStringString();\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 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) => {\n      acc[TEXT_DECODER.decode(item.field)] = TEXT_DECODER.decode(item.value);\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 valueRecordStringUint8Array(): Record<string, Uint8Array> {\n    return this.items.reduce<Record<string, Uint8Array>>((acc, item) => {\n      acc[TEXT_DECODER.decode(item.field)] = item.value;\n      return acc;\n    }, {});\n  }\n\n  private truncateValueStrings(): string {\n    const keyValueIterable = this.valueMapStringString().entries();\n    const keyValueArray = Array.from(keyValueIterable);\n    if (keyValueArray.length <= this._displayListSizeLimit) {\n      const pairs: string[] = [];\n      keyValueArray.forEach(pair => {\n        pairs.push(`${pair[0]}: ${pair[1]}`);\n      });\n      return pairs.join(',');\n    } else {\n      const slicedArray = keyValueArray.slice(0, this._displayListSizeLimit);\n      const pairs: string[] = [];\n      slicedArray.forEach(pair => {\n        pairs.push(`${pair[0]}: ${pair[1]}`);\n      });\n      return pairs.join(',');\n    }\n  }\n\n  public override toString(): string {\n    return `${super.toString()}: valueDictionaryStringString: ${this.truncateValueStrings()}`;\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(protected _innerException: SdkError) {\n    super();\n  }\n}\n\n/**\n * Indicates that an error occurred during the dictionary fetch 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"]}
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cache-dictionary-fetch.js","sourceRoot":"","sources":["../../../../src/messages/responses/cache-dictionary-fetch.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ResponseBase,\n  BaseResponseMiss,\n  BaseResponseError,\n} from './response-base';\nimport {SdkError} from '../../errors';\nimport {_DictionaryFieldValuePair} from './grpc-response-types';\nimport {DictionaryFetchResponse} from './enums';\n\nconst TEXT_DECODER = new TextDecoder();\n\ninterface IResponse {\n  value(): Record<string, string> | undefined;\n  type: DictionaryFetchResponse;\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 ResponseBase implements IResponse {\n  private readonly items: _DictionaryFieldValuePair[];\n  private readonly _displayListSizeLimit = 5;\n  readonly type: DictionaryFetchResponse.Hit = DictionaryFetchResponse.Hit;\n\n  constructor(items: _DictionaryFieldValuePair[]) {\n    super();\n    this.items = items;\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 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) => {\n      acc.set(TEXT_DECODER.decode(item.field), TEXT_DECODER.decode(item.value));\n      return acc;\n    }, new Map<string, string>());\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) => {\n      acc.set(TEXT_DECODER.decode(item.field), item.value);\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.  This is a convenience alias for\n   * {valueRecordStringString}.\n   * @returns {Record<string, string>}\n   */\n  public value(): Record<string, string> {\n    return this.valueRecordStringString();\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 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) => {\n      acc[TEXT_DECODER.decode(item.field)] = TEXT_DECODER.decode(item.value);\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 valueRecordStringUint8Array(): Record<string, Uint8Array> {\n    return this.items.reduce<Record<string, Uint8Array>>((acc, item) => {\n      acc[TEXT_DECODER.decode(item.field)] = item.value;\n      return acc;\n    }, {});\n  }\n\n  private truncateValueStrings(): string {\n    const keyValueIterable = this.valueMapStringString().entries();\n    const keyValueArray = Array.from(keyValueIterable);\n    if (keyValueArray.length <= this._displayListSizeLimit) {\n      const pairs: string[] = [];\n      keyValueArray.forEach(pair => {\n        pairs.push(`${pair[0]}: ${pair[1]}`);\n      });\n      return pairs.join(',');\n    } else {\n      const slicedArray = keyValueArray.slice(0, this._displayListSizeLimit);\n      const pairs: string[] = [];\n      slicedArray.forEach(pair => {\n        pairs.push(`${pair[0]}: ${pair[1]}`);\n      });\n      return pairs.join(',');\n    }\n  }\n\n  public override toString(): string {\n    return `${super.toString()}: valueDictionaryStringString: ${this.truncateValueStrings()}`;\n  }\n}\n\n/**\n * Indicates that the requested data was not available in the cache.\n */\nexport class Miss extends BaseResponseMiss implements IResponse {\n  readonly type: DictionaryFetchResponse.Miss = DictionaryFetchResponse.Miss;\n\n  value(): Record<string, string> | undefined {\n    return undefined;\n  }\n}\n\n/**\n * Indicates that an error occurred during the dictionary fetch 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 BaseResponseError implements IResponse {\n  readonly type: DictionaryFetchResponse.Error = DictionaryFetchResponse.Error;\n  constructor(_innerException: SdkError) {\n    super(_innerException);\n  }\n\n  value(): Record<string, string> | undefined {\n    return undefined;\n  }\n}\n\nexport type Response = Hit | Miss | Error;\n"]}
@@ -1,31 +1,19 @@
1
1
  import { SdkError } from '../../errors';
2
- import { ResponseBase } from './response-base';
3
- /**
4
- * Parent response type for a dictionary get field request. The
5
- * response object is resolved to a type-safe object of one of
6
- * the following subtypes:
7
- *
8
- * - {Hit}
9
- * - {Miss}
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 CacheDictionaryGetField.Error) {
17
- * // Handle error as appropriate. The compiler will smart-cast `response` to type
18
- * // `CacheDictionaryGetField.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 {
2
+ import { BaseResponseError, BaseResponseMiss, ResponseBase } from './response-base';
3
+ import { DictionaryGetFieldResponse } from './enums';
4
+ interface IResponse {
24
5
  value(): string | undefined;
6
+ type: DictionaryGetFieldResponse;
25
7
  }
26
- declare class _Hit extends Response {
8
+ /**
9
+ * Indicates that the requested data was successfully retrieved from the cache. Provides
10
+ * `value*` accessors to retrieve the data in the appropriate format.
11
+ */
12
+ export declare class Hit extends ResponseBase implements IResponse {
27
13
  private readonly body;
28
- constructor(body: Uint8Array);
14
+ private readonly field;
15
+ readonly type: DictionaryGetFieldResponse.Hit;
16
+ constructor(body: Uint8Array, field: Uint8Array);
29
17
  /**
30
18
  * Returns the data as a utf-8 string, decoded from the underlying byte array.
31
19
  * @returns string
@@ -42,17 +30,6 @@ declare class _Hit extends Response {
42
30
  */
43
31
  valueUint8Array(): Uint8Array;
44
32
  toString(): string;
45
- }
46
- declare const Hit_base: {
47
- new (...args: any[]): {};
48
- } & typeof _Hit;
49
- /**
50
- * Indicates that the requested data was successfully retrieved from the cache. Provides
51
- * `value*` accessors to retrieve the data in the appropriate format.
52
- */
53
- export declare class Hit extends Hit_base {
54
- private readonly field;
55
- constructor(body: Uint8Array, field: Uint8Array);
56
33
  /**
57
34
  * Returns the field name for the retrieved element, as a utf-8 string decoded from the underlying byte array.
58
35
  * @returns {string}
@@ -64,18 +41,12 @@ export declare class Hit extends Hit_base {
64
41
  */
65
42
  fieldUint8Array(): Uint8Array;
66
43
  }
67
- declare class _Miss extends Response {
68
- }
69
- declare const Miss_base: {
70
- new (...args: any[]): {
71
- readonly is_miss: boolean;
72
- };
73
- } & typeof _Miss;
74
44
  /**
75
45
  * Indicates that the requested data was not available in the cache.
76
46
  */
77
- export declare class Miss extends Miss_base {
47
+ export declare class Miss extends BaseResponseMiss implements IResponse {
78
48
  private readonly field;
49
+ readonly type: DictionaryGetFieldResponse.Miss;
79
50
  constructor(field: Uint8Array);
80
51
  /**
81
52
  * Returns the field name for the retrieved element, as a utf-8 string decoded from the underlying byte array.
@@ -87,20 +58,8 @@ export declare class Miss extends Miss_base {
87
58
  * @returns {Uint8Array}
88
59
  */
89
60
  fieldUint8Array(): Uint8Array;
61
+ value(): string | undefined;
90
62
  }
91
- declare class _Error extends Response {
92
- protected _innerException: SdkError;
93
- constructor(_innerException: SdkError);
94
- }
95
- declare const Error_base: {
96
- new (...args: any[]): {
97
- _innerException: SdkError;
98
- message(): string;
99
- innerException(): SdkError;
100
- errorCode(): import("../../errors").MomentoErrorCode;
101
- toString(): string;
102
- };
103
- } & typeof _Error;
104
63
  /**
105
64
  * Indicates that an error occurred during the dictionary get field request.
106
65
  *
@@ -111,9 +70,9 @@ declare const Error_base: {
111
70
  * - `message()` - a human-readable description of the error
112
71
  * - `innerException()` - the original error that caused the failure; can be re-thrown.
113
72
  */
114
- export declare class Error extends Error_base {
115
- _innerException: SdkError;
73
+ export declare class Error extends BaseResponseError implements IResponse {
116
74
  private readonly field;
75
+ readonly type: DictionaryGetFieldResponse.Error;
117
76
  constructor(_innerException: SdkError, field: Uint8Array);
118
77
  /**
119
78
  * Returns the field name for the retrieved element, as a utf-8 string decoded from the underlying byte array.
@@ -125,5 +84,7 @@ export declare class Error extends Error_base {
125
84
  * @returns {Uint8Array}
126
85
  */
127
86
  fieldUint8Array(): Uint8Array;
87
+ value(): string | undefined;
128
88
  }
89
+ export type Response = Hit | Miss | Error;
129
90
  export {};
@@ -1,42 +1,20 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Error = exports.Miss = exports.Hit = exports.Response = void 0;
3
+ exports.Error = exports.Miss = exports.Hit = void 0;
4
4
  const response_base_1 = require("./response-base");
5
5
  const utils_1 = require("../../internal/utils");
6
+ const enums_1 = require("./enums");
6
7
  const TEXT_DECODER = new TextDecoder();
7
8
  /**
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
- * ```
9
+ * Indicates that the requested data was successfully retrieved from the cache. Provides
10
+ * `value*` accessors to retrieve the data in the appropriate format.
26
11
  */
27
- class Response extends response_base_1.ResponseBase {
28
- value() {
29
- if (this instanceof Hit) {
30
- return this.value();
31
- }
32
- return undefined;
33
- }
34
- }
35
- exports.Response = Response;
36
- class _Hit extends Response {
37
- constructor(body) {
12
+ class Hit extends response_base_1.ResponseBase {
13
+ constructor(body, field) {
38
14
  super();
15
+ this.type = enums_1.DictionaryGetFieldResponse.Hit;
39
16
  this.body = body;
17
+ this.field = field;
40
18
  }
41
19
  /**
42
20
  * Returns the data as a utf-8 string, decoded from the underlying byte array.
@@ -63,16 +41,6 @@ class _Hit extends Response {
63
41
  const display = (0, utils_1.truncateString)(this.valueString());
64
42
  return `${super.toString()}: ${display}`;
65
43
  }
66
- }
67
- /**
68
- * Indicates that the requested data was successfully retrieved from the cache. Provides
69
- * `value*` accessors to retrieve the data in the appropriate format.
70
- */
71
- class Hit extends (0, response_base_1.ResponseHit)(_Hit) {
72
- constructor(body, field) {
73
- super(body);
74
- this.field = field;
75
- }
76
44
  /**
77
45
  * Returns the field name for the retrieved element, as a utf-8 string decoded from the underlying byte array.
78
46
  * @returns {string}
@@ -89,14 +57,13 @@ class Hit extends (0, response_base_1.ResponseHit)(_Hit) {
89
57
  }
90
58
  }
91
59
  exports.Hit = Hit;
92
- class _Miss extends Response {
93
- }
94
60
  /**
95
61
  * Indicates that the requested data was not available in the cache.
96
62
  */
97
- class Miss extends (0, response_base_1.ResponseMiss)(_Miss) {
63
+ class Miss extends response_base_1.BaseResponseMiss {
98
64
  constructor(field) {
99
65
  super();
66
+ this.type = enums_1.DictionaryGetFieldResponse.Miss;
100
67
  this.field = field;
101
68
  }
102
69
  /**
@@ -113,14 +80,11 @@ class Miss extends (0, response_base_1.ResponseMiss)(_Miss) {
113
80
  fieldUint8Array() {
114
81
  return this.field;
115
82
  }
116
- }
117
- exports.Miss = Miss;
118
- class _Error extends Response {
119
- constructor(_innerException) {
120
- super();
121
- this._innerException = _innerException;
83
+ value() {
84
+ return undefined;
122
85
  }
123
86
  }
87
+ exports.Miss = Miss;
124
88
  /**
125
89
  * Indicates that an error occurred during the dictionary get field request.
126
90
  *
@@ -131,10 +95,10 @@ class _Error extends Response {
131
95
  * - `message()` - a human-readable description of the error
132
96
  * - `innerException()` - the original error that caused the failure; can be re-thrown.
133
97
  */
134
- class Error extends (0, response_base_1.ResponseError)(_Error) {
98
+ class Error extends response_base_1.BaseResponseError {
135
99
  constructor(_innerException, field) {
136
100
  super(_innerException);
137
- this._innerException = _innerException;
101
+ this.type = enums_1.DictionaryGetFieldResponse.Error;
138
102
  this.field = field;
139
103
  }
140
104
  /**
@@ -151,6 +115,9 @@ class Error extends (0, response_base_1.ResponseError)(_Error) {
151
115
  fieldUint8Array() {
152
116
  return this.field;
153
117
  }
118
+ value() {
119
+ return undefined;
120
+ }
154
121
  }
155
122
  exports.Error = Error;
156
- //# 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,gDAAoD;AAEpD,MAAM,YAAY,GAAG,IAAI,WAAW,EAAE,CAAC;AAEvC;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAsB,QAAS,SAAQ,4BAAY;IAC1C,KAAK;QACV,IAAI,IAAI,YAAY,GAAG,EAAE;YACvB,OAAQ,IAAY,CAAC,KAAK,EAAE,CAAC;SAC9B;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;CACF;AAPD,4BAOC;AAED,MAAM,IAAK,SAAQ,QAAQ;IAEzB,YAAY,IAAgB;QAC1B,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED;;;OAGG;IACI,KAAK;QACV,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;IAC5B,CAAC;IAED;;;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,sBAAc,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';\nimport {\n  ResponseBase,\n  ResponseError,\n  ResponseHit,\n  ResponseMiss,\n} from './response-base';\nimport {truncateString} from '../../internal/utils';\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  public value(): string | undefined {\n    if (this instanceof Hit) {\n      return (this as Hit).value();\n    }\n    return undefined;\n  }\n}\n\nclass _Hit extends Response {\n  private readonly body: Uint8Array;\n  constructor(body: Uint8Array) {\n    super();\n    this.body = body;\n  }\n\n  /**\n   * Returns the data as a utf-8 string, decoded from the underlying byte array.\n   * @returns string\n   */\n  public value(): string {\n    return this.valueString();\n  }\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"]}
123
+ //# 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,mDAIyB;AACzB,gDAAoD;AACpD,mCAAmD;AAEnD,MAAM,YAAY,GAAG,IAAI,WAAW,EAAE,CAAC;AAOvC;;;GAGG;AACH,MAAa,GAAI,SAAQ,4BAAY;IAMnC,YAAY,IAAgB,EAAE,KAAiB;QAC7C,KAAK,EAAE,CAAC;QAJD,SAAI,GACX,kCAA0B,CAAC,GAAG,CAAC;QAI/B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED;;;OAGG;IACI,KAAK;QACV,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;IAC5B,CAAC;IAED;;;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,sBAAc,EAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACnD,OAAO,GAAG,KAAK,CAAC,QAAQ,EAAE,KAAK,OAAO,EAAE,CAAC;IAC3C,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;AAxDD,kBAwDC;AAED;;GAEG;AACH,MAAa,IAAK,SAAQ,gCAAgB;IAKxC,YAAY,KAAiB;QAC3B,KAAK,EAAE,CAAC;QAJD,SAAI,GACX,kCAA0B,CAAC,IAAI,CAAC;QAIhC,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;IAED,KAAK;QACH,OAAO,SAAS,CAAC;IACnB,CAAC;CACF;AA7BD,oBA6BC;AAED;;;;;;;;;GASG;AACH,MAAa,KAAM,SAAQ,iCAAiB;IAK1C,YAAY,eAAyB,EAAE,KAAiB;QACtD,KAAK,CAAC,eAAe,CAAC,CAAC;QAJhB,SAAI,GACX,kCAA0B,CAAC,KAAK,CAAC;QAIjC,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;IAED,KAAK;QACH,OAAO,SAAS,CAAC;IACnB,CAAC;CACF;AA7BD,sBA6BC","sourcesContent":["import {SdkError} from '../../errors';\nimport {\n  BaseResponseError,\n  BaseResponseMiss,\n  ResponseBase,\n} from './response-base';\nimport {truncateString} from '../../internal/utils';\nimport {DictionaryGetFieldResponse} from './enums';\n\nconst TEXT_DECODER = new TextDecoder();\n\ninterface IResponse {\n  value(): string | undefined;\n  type: DictionaryGetFieldResponse;\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 ResponseBase implements IResponse {\n  private readonly body: Uint8Array;\n  private readonly field: Uint8Array;\n  readonly type: DictionaryGetFieldResponse.Hit =\n    DictionaryGetFieldResponse.Hit;\n\n  constructor(body: Uint8Array, field: Uint8Array) {\n    super();\n    this.body = body;\n    this.field = field;\n  }\n\n  /**\n   * Returns the data as a utf-8 string, decoded from the underlying byte array.\n   * @returns string\n   */\n  public value(): string {\n    return this.valueString();\n  }\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   * 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\n/**\n * Indicates that the requested data was not available in the cache.\n */\nexport class Miss extends BaseResponseMiss implements IResponse {\n  private readonly field: Uint8Array;\n  readonly type: DictionaryGetFieldResponse.Miss =\n    DictionaryGetFieldResponse.Miss;\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  value(): string | undefined {\n    return undefined;\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 BaseResponseError implements IResponse {\n  private readonly field: Uint8Array;\n  readonly type: DictionaryGetFieldResponse.Error =\n    DictionaryGetFieldResponse.Error;\n\n  constructor(_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  value(): string | undefined {\n    return undefined;\n  }\n}\n\nexport type Response = Hit | Miss | Error;\n"]}