@gomomento/sdk
Advanced tools
Comparing version 0.13.0 to 0.13.1
@@ -16,2 +16,3 @@ { | ||
"scripts": { | ||
"prebuild": "eslint . --ext .ts", | ||
"test": "jest", | ||
@@ -18,0 +19,0 @@ "integration": "jest --config jest-integration.config.js", |
@@ -6,6 +6,7 @@ import { Interceptor } from '@grpc/grpc-js'; | ||
} | ||
export declare function createRetryInterceptorIfEnabled(options: RetryInterceptorOptions): Array<Interceptor>; | ||
export declare class RetryInterceptor { | ||
private readonly logger; | ||
constructor(options?: RetryInterceptorOptions); | ||
addRetryInterceptor(): Interceptor; | ||
createRetryInterceptor(): Interceptor; | ||
} |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.RetryInterceptor = void 0; | ||
exports.RetryInterceptor = exports.createRetryInterceptorIfEnabled = void 0; | ||
// This is temporary work around defining our own interceptor to power re-try's | ||
@@ -36,8 +36,20 @@ // Longer term with this proposal re-try's should be added to grpc core, and we | ||
]; | ||
// TODO: Retry interceptor behavior should be configurable, but we need to | ||
// align on basic API design first: https://github.com/momentohq/client-sdk-javascript/issues/79 . | ||
// For now, for convenience during development, you can toggle this hard-coded | ||
// variable to enable/disable it. | ||
const RETRIES_ENABLED = true; | ||
function createRetryInterceptorIfEnabled(options) { | ||
if (RETRIES_ENABLED) { | ||
return [new RetryInterceptor(options).createRetryInterceptor()]; | ||
} | ||
else { | ||
return []; | ||
} | ||
} | ||
exports.createRetryInterceptorIfEnabled = createRetryInterceptorIfEnabled; | ||
class RetryInterceptor { | ||
constructor(options) { | ||
this.logger = (0, logging_1.getLogger)(this.constructor.name, options === null || options === void 0 ? void 0 : options.loggerOptions); | ||
this.logger = (0, logging_1.getLogger)(this, options === null || options === void 0 ? void 0 : options.loggerOptions); | ||
} | ||
// TODO: Retry interceptor behavior should be configurable, but we need to | ||
// align on basic API design first: https://github.com/momentohq/client-sdk-javascript/issues/79 | ||
// TODO: We need to send retry count information to the server so that we | ||
@@ -48,3 +60,3 @@ // will have some visibility into how often this is happening to customers: | ||
// https://github.com/momentohq/client-sdk-javascript/issues/81 | ||
addRetryInterceptor() { | ||
createRetryInterceptor() { | ||
const logger = this.logger; | ||
@@ -96,7 +108,7 @@ return (options, nextCall) => { | ||
if (retryableGrpcStatusCodes.includes(status.code)) { | ||
logger.debug(`Request path: ${options.method_definition.path}; response status code: ${status.code}; eligible for retry.`); | ||
logger.debug(`Request path: ${options.method_definition.path}; response status code: ${status.code}; number of retries (${retries}) is less than max (${maxRetry}), retrying.`); | ||
retry(savedSendMessage, savedMetadata); | ||
} | ||
else { | ||
logger.debug(`Request path: ${options.method_definition.path}; response status code: ${status.code}; not eligible for retry.`); | ||
logger.trace(`Request path: ${options.method_definition.path}; response status code: ${status.code}; not eligible for retry.`); | ||
savedMessageNext(savedReceiveMessage); | ||
@@ -114,2 +126,2 @@ next(status); | ||
exports.RetryInterceptor = RetryInterceptor; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RetryInterceptor.js","sourceRoot":"","sources":["../../../src/grpc/RetryInterceptor.ts"],"names":[],"mappings":"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","sourcesContent":["// This is temporary work around defining our own interceptor to power re-try's\n// Longer term with this proposal re-try's should be added to grpc core, and we\n// can leverage by defining a retry policy.\n// https://github.com/grpc/proposal/blob/master/A6-client-retries.md#grpc-retry-design\n// For now we use re-try interceptor inspired by example here in interceptor proposal for nodejs grpc core\n// https://github.com/grpc/proposal/blob/master/L5-node-client-interceptors.md#advanced-examples\n// Main difference is that we maintain a allow list of retryable status codes vs trying all.\nimport {\n  InterceptingCall,\n  Interceptor,\n  Listener,\n  Metadata,\n  StatusObject,\n} from '@grpc/grpc-js';\nimport {Status} from '@grpc/grpc-js/build/src/constants';\nimport {getLogger, Logger, LoggerOptions} from '../utils/logging';\n\nconst maxRetry = 3;\n\nconst retryableGrpcStatusCodes: Array<Status> = [\n  // including all the status codes for reference, but\n  // commenting out the ones we don't want to retry on for now.\n\n  // Status.OK,\n  // Status.CANCELLED,\n  // Status.UNKNOWN,\n  // Status.INVALID_ARGUMENT,\n  // Status.DEADLINE_EXCEEDED,\n  // Status.NOT_FOUND,\n  // Status.ALREADY_EXISTS,\n  // Status.PERMISSION_DENIED,\n  // Status.RESOURCE_EXHAUSTED,\n  // Status.FAILED_PRECONDITION,\n  // Status.ABORTED,\n  // Status.OUT_OF_RANGE,\n  // Status.UNIMPLEMENTED,\n  Status.INTERNAL,\n  Status.UNAVAILABLE,\n  // Status.DATA_LOSS,\n  // Status.UNAUTHENTICATED\n];\n\nexport interface RetryInterceptorOptions {\n  loggerOptions?: LoggerOptions;\n}\n\nexport class RetryInterceptor {\n  private readonly logger: Logger;\n\n  constructor(options?: RetryInterceptorOptions) {\n    this.logger = getLogger(this.constructor.name, options?.loggerOptions);\n  }\n\n  // TODO: Retry interceptor behavior should be configurable, but we need to\n  // align on basic API design first: https://github.com/momentohq/client-sdk-javascript/issues/79\n  // TODO: We need to send retry count information to the server so that we\n  // will have some visibility into how often this is happening to customers:\n  // https://github.com/momentohq/client-sdk-javascript/issues/80\n  // TODO: we need to add backoff/jitter for the retries:\n  // https://github.com/momentohq/client-sdk-javascript/issues/81\n  public addRetryInterceptor(): Interceptor {\n    const logger = this.logger;\n\n    return (options, nextCall) => {\n      let savedMetadata: Metadata;\n      let savedSendMessage: any;\n      let savedReceiveMessage: any;\n      let savedMessageNext: (arg0: any) => void;\n      return new InterceptingCall(nextCall(options), {\n        start: function (metadata, listener, next) {\n          savedMetadata = metadata;\n          const newListener: Listener = {\n            onReceiveMessage: function (\n              message: any,\n              next: (arg0: any) => void\n            ) {\n              // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n              savedReceiveMessage = message;\n              savedMessageNext = next;\n            },\n            onReceiveStatus: function (\n              status: StatusObject,\n              next: (arg0: any) => void\n            ) {\n              let retries = 0;\n              const retry = function (message: any, metadata: Metadata) {\n                retries++;\n                const newCall = nextCall(options);\n                // eslint-disable-next-line @typescript-eslint/no-unsafe-argument\n                newCall.start(metadata, {\n                  onReceiveMessage: function (message) {\n                    // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n                    savedReceiveMessage = message;\n                  },\n                  onReceiveStatus: function (status) {\n                    if (retryableGrpcStatusCodes.includes(status.code)) {\n                      if (retries <= maxRetry) {\n                        logger.debug(\n                          `Request path: ${options.method_definition.path}; retryable status code: ${status.code}; number of retries (${retries}) is less than max (${maxRetry}), retrying.`\n                        );\n                        retry(message, metadata);\n                      } else {\n                        logger.debug(\n                          `Request path: ${options.method_definition.path}; retryable status code: ${status.code}; number of retries (${retries}) has exceeded max (${maxRetry}), not retrying.`\n                        );\n                        savedMessageNext(savedReceiveMessage);\n                        next(status);\n                      }\n                    } else {\n                      savedMessageNext(savedReceiveMessage);\n                      next({code: status.code});\n                    }\n                  },\n                });\n              };\n              if (retryableGrpcStatusCodes.includes(status.code)) {\n                logger.debug(\n                  `Request path: ${options.method_definition.path}; response status code: ${status.code}; eligible for retry.`\n                );\n                retry(savedSendMessage, savedMetadata);\n              } else {\n                logger.debug(\n                  `Request path: ${options.method_definition.path}; response status code: ${status.code}; not eligible for retry.`\n                );\n                savedMessageNext(savedReceiveMessage);\n                next(status);\n              }\n            },\n          };\n          next(metadata, newListener);\n        },\n      });\n    };\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RetryInterceptor.js","sourceRoot":"","sources":["../../../src/grpc/RetryInterceptor.ts"],"names":[],"mappings":";;;AAAA,+EAA+E;AAC/E,+EAA+E;AAC/E,2CAA2C;AAC3C,sFAAsF;AACtF,0GAA0G;AAC1G,gGAAgG;AAChG,4FAA4F;AAC5F,2CAMuB;AACvB,iEAAyD;AACzD,8CAAkE;AAElE,MAAM,QAAQ,GAAG,CAAC,CAAC;AAEnB,MAAM,wBAAwB,GAAkB;IAC9C,oDAAoD;IACpD,6DAA6D;IAE7D,aAAa;IACb,oBAAoB;IACpB,kBAAkB;IAClB,2BAA2B;IAC3B,4BAA4B;IAC5B,oBAAoB;IACpB,yBAAyB;IACzB,4BAA4B;IAC5B,6BAA6B;IAC7B,8BAA8B;IAC9B,kBAAkB;IAClB,uBAAuB;IACvB,wBAAwB;IACxB,kBAAM,CAAC,QAAQ;IACf,kBAAM,CAAC,WAAW;IAClB,oBAAoB;IACpB,yBAAyB;CAC1B,CAAC;AAMF,0EAA0E;AAC1E,kGAAkG;AAClG,8EAA8E;AAC9E,iCAAiC;AACjC,MAAM,eAAe,GAAG,IAAI,CAAC;AAE7B,SAAgB,+BAA+B,CAC7C,OAAgC;IAEhC,IAAI,eAAe,EAAE;QACnB,OAAO,CAAC,IAAI,gBAAgB,CAAC,OAAO,CAAC,CAAC,sBAAsB,EAAE,CAAC,CAAC;KACjE;SAAM;QACL,OAAO,EAAE,CAAC;KACX;AACH,CAAC;AARD,0EAQC;AAED,MAAa,gBAAgB;IAG3B,YAAY,OAAiC;QAC3C,IAAI,CAAC,MAAM,GAAG,IAAA,mBAAS,EAAC,IAAI,EAAE,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,aAAa,CAAC,CAAC;IACxD,CAAC;IAED,yEAAyE;IACzE,2EAA2E;IAC3E,+DAA+D;IAC/D,uDAAuD;IACvD,+DAA+D;IACxD,sBAAsB;QAC3B,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAE3B,OAAO,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE;YAC3B,IAAI,aAAuB,CAAC;YAC5B,IAAI,gBAAqB,CAAC;YAC1B,IAAI,mBAAwB,CAAC;YAC7B,IAAI,gBAAqC,CAAC;YAC1C,OAAO,IAAI,0BAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;gBAC7C,KAAK,EAAE,UAAU,QAAQ,EAAE,QAAQ,EAAE,IAAI;oBACvC,aAAa,GAAG,QAAQ,CAAC;oBACzB,MAAM,WAAW,GAAa;wBAC5B,gBAAgB,EAAE,UAChB,OAAY,EACZ,IAAyB;4BAEzB,mEAAmE;4BACnE,mBAAmB,GAAG,OAAO,CAAC;4BAC9B,gBAAgB,GAAG,IAAI,CAAC;wBAC1B,CAAC;wBACD,eAAe,EAAE,UACf,MAAoB,EACpB,IAAyB;4BAEzB,IAAI,OAAO,GAAG,CAAC,CAAC;4BAChB,MAAM,KAAK,GAAG,UAAU,OAAY,EAAE,QAAkB;gCACtD,OAAO,EAAE,CAAC;gCACV,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC;gCAClC,iEAAiE;gCACjE,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE;oCACtB,gBAAgB,EAAE,UAAU,OAAO;wCACjC,mEAAmE;wCACnE,mBAAmB,GAAG,OAAO,CAAC;oCAChC,CAAC;oCACD,eAAe,EAAE,UAAU,MAAM;wCAC/B,IAAI,wBAAwB,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;4CAClD,IAAI,OAAO,IAAI,QAAQ,EAAE;gDACvB,MAAM,CAAC,KAAK,CACV,iBAAiB,OAAO,CAAC,iBAAiB,CAAC,IAAI,4BAA4B,MAAM,CAAC,IAAI,wBAAwB,OAAO,uBAAuB,QAAQ,cAAc,CACnK,CAAC;gDACF,KAAK,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;6CAC1B;iDAAM;gDACL,MAAM,CAAC,KAAK,CACV,iBAAiB,OAAO,CAAC,iBAAiB,CAAC,IAAI,4BAA4B,MAAM,CAAC,IAAI,wBAAwB,OAAO,uBAAuB,QAAQ,kBAAkB,CACvK,CAAC;gDACF,gBAAgB,CAAC,mBAAmB,CAAC,CAAC;gDACtC,IAAI,CAAC,MAAM,CAAC,CAAC;6CACd;yCACF;6CAAM;4CACL,gBAAgB,CAAC,mBAAmB,CAAC,CAAC;4CACtC,IAAI,CAAC,EAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAC,CAAC,CAAC;yCAC3B;oCACH,CAAC;iCACF,CAAC,CAAC;4BACL,CAAC,CAAC;4BACF,IAAI,wBAAwB,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;gCAClD,MAAM,CAAC,KAAK,CACV,iBAAiB,OAAO,CAAC,iBAAiB,CAAC,IAAI,2BAA2B,MAAM,CAAC,IAAI,wBAAwB,OAAO,uBAAuB,QAAQ,cAAc,CAClK,CAAC;gCACF,KAAK,CAAC,gBAAgB,EAAE,aAAa,CAAC,CAAC;6BACxC;iCAAM;gCACL,MAAM,CAAC,KAAK,CACV,iBAAiB,OAAO,CAAC,iBAAiB,CAAC,IAAI,2BAA2B,MAAM,CAAC,IAAI,2BAA2B,CACjH,CAAC;gCACF,gBAAgB,CAAC,mBAAmB,CAAC,CAAC;gCACtC,IAAI,CAAC,MAAM,CAAC,CAAC;6BACd;wBACH,CAAC;qBACF,CAAC;oBACF,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;gBAC9B,CAAC;aACF,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC;CACF;AAtFD,4CAsFC","sourcesContent":["// This is temporary work around defining our own interceptor to power re-try's\n// Longer term with this proposal re-try's should be added to grpc core, and we\n// can leverage by defining a retry policy.\n// https://github.com/grpc/proposal/blob/master/A6-client-retries.md#grpc-retry-design\n// For now we use re-try interceptor inspired by example here in interceptor proposal for nodejs grpc core\n// https://github.com/grpc/proposal/blob/master/L5-node-client-interceptors.md#advanced-examples\n// Main difference is that we maintain a allow list of retryable status codes vs trying all.\nimport {\n  InterceptingCall,\n  Interceptor,\n  Listener,\n  Metadata,\n  StatusObject,\n} from '@grpc/grpc-js';\nimport {Status} from '@grpc/grpc-js/build/src/constants';\nimport {getLogger, Logger, LoggerOptions} from '../utils/logging';\n\nconst maxRetry = 3;\n\nconst retryableGrpcStatusCodes: Array<Status> = [\n  // including all the status codes for reference, but\n  // commenting out the ones we don't want to retry on for now.\n\n  // Status.OK,\n  // Status.CANCELLED,\n  // Status.UNKNOWN,\n  // Status.INVALID_ARGUMENT,\n  // Status.DEADLINE_EXCEEDED,\n  // Status.NOT_FOUND,\n  // Status.ALREADY_EXISTS,\n  // Status.PERMISSION_DENIED,\n  // Status.RESOURCE_EXHAUSTED,\n  // Status.FAILED_PRECONDITION,\n  // Status.ABORTED,\n  // Status.OUT_OF_RANGE,\n  // Status.UNIMPLEMENTED,\n  Status.INTERNAL,\n  Status.UNAVAILABLE,\n  // Status.DATA_LOSS,\n  // Status.UNAUTHENTICATED\n];\n\nexport interface RetryInterceptorOptions {\n  loggerOptions?: LoggerOptions;\n}\n\n// TODO: Retry interceptor behavior should be configurable, but we need to\n// align on basic API design first: https://github.com/momentohq/client-sdk-javascript/issues/79 .\n// For now, for convenience during development, you can toggle this hard-coded\n// variable to enable/disable it.\nconst RETRIES_ENABLED = true;\n\nexport function createRetryInterceptorIfEnabled(\n  options: RetryInterceptorOptions\n): Array<Interceptor> {\n  if (RETRIES_ENABLED) {\n    return [new RetryInterceptor(options).createRetryInterceptor()];\n  } else {\n    return [];\n  }\n}\n\nexport class RetryInterceptor {\n  private readonly logger: Logger;\n\n  constructor(options?: RetryInterceptorOptions) {\n    this.logger = getLogger(this, options?.loggerOptions);\n  }\n\n  // TODO: We need to send retry count information to the server so that we\n  // will have some visibility into how often this is happening to customers:\n  // https://github.com/momentohq/client-sdk-javascript/issues/80\n  // TODO: we need to add backoff/jitter for the retries:\n  // https://github.com/momentohq/client-sdk-javascript/issues/81\n  public createRetryInterceptor(): Interceptor {\n    const logger = this.logger;\n\n    return (options, nextCall) => {\n      let savedMetadata: Metadata;\n      let savedSendMessage: any;\n      let savedReceiveMessage: any;\n      let savedMessageNext: (arg0: any) => void;\n      return new InterceptingCall(nextCall(options), {\n        start: function (metadata, listener, next) {\n          savedMetadata = metadata;\n          const newListener: Listener = {\n            onReceiveMessage: function (\n              message: any,\n              next: (arg0: any) => void\n            ) {\n              // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n              savedReceiveMessage = message;\n              savedMessageNext = next;\n            },\n            onReceiveStatus: function (\n              status: StatusObject,\n              next: (arg0: any) => void\n            ) {\n              let retries = 0;\n              const retry = function (message: any, metadata: Metadata) {\n                retries++;\n                const newCall = nextCall(options);\n                // eslint-disable-next-line @typescript-eslint/no-unsafe-argument\n                newCall.start(metadata, {\n                  onReceiveMessage: function (message) {\n                    // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n                    savedReceiveMessage = message;\n                  },\n                  onReceiveStatus: function (status) {\n                    if (retryableGrpcStatusCodes.includes(status.code)) {\n                      if (retries <= maxRetry) {\n                        logger.debug(\n                          `Request path: ${options.method_definition.path}; retryable status code: ${status.code}; number of retries (${retries}) is less than max (${maxRetry}), retrying.`\n                        );\n                        retry(message, metadata);\n                      } else {\n                        logger.debug(\n                          `Request path: ${options.method_definition.path}; retryable status code: ${status.code}; number of retries (${retries}) has exceeded max (${maxRetry}), not retrying.`\n                        );\n                        savedMessageNext(savedReceiveMessage);\n                        next(status);\n                      }\n                    } else {\n                      savedMessageNext(savedReceiveMessage);\n                      next({code: status.code});\n                    }\n                  },\n                });\n              };\n              if (retryableGrpcStatusCodes.includes(status.code)) {\n                logger.debug(\n                  `Request path: ${options.method_definition.path}; response status code: ${status.code}; number of retries (${retries}) is less than max (${maxRetry}), retrying.`\n                );\n                retry(savedSendMessage, savedMetadata);\n              } else {\n                logger.trace(\n                  `Request path: ${options.method_definition.path}; response status code: ${status.code}; not eligible for retry.`\n                );\n                savedMessageNext(savedReceiveMessage);\n                next(status);\n              }\n            },\n          };\n          next(metadata, newListener);\n        },\n      });\n    };\n  }\n}\n"]} |
@@ -5,4 +5,5 @@ import { SimpleCacheClient } from './SimpleCacheClient'; | ||
import { CacheGetStatus } from './messages/Result'; | ||
import { CacheInfo } from './messages/CacheInfo'; | ||
import { AlreadyExistsError, AuthenticationError, CancelledError, CacheServiceError, LimitExceededError, ServiceValidationError, InternalServerError, InvalidArgumentError, UnknownServiceError, TimeoutError, BadRequestError, PermissionError, NotFoundError } from './Errors'; | ||
export { LogLevel, LogFormat } from './utils/logging'; | ||
export { SimpleCacheClient, GetResponse, SetResponse, CacheGetStatus, AlreadyExistsError, AuthenticationError, CancelledError, CacheServiceError, LimitExceededError, ServiceValidationError, InternalServerError, InvalidArgumentError, UnknownServiceError, TimeoutError, BadRequestError, PermissionError, NotFoundError, }; | ||
export { Logger, LoggerOptions, LogLevel, LogFormat, getLogger, } from './utils/logging'; | ||
export { SimpleCacheClient, GetResponse, SetResponse, CacheGetStatus, CacheInfo, AlreadyExistsError, AuthenticationError, CancelledError, CacheServiceError, LimitExceededError, ServiceValidationError, InternalServerError, InvalidArgumentError, UnknownServiceError, TimeoutError, BadRequestError, PermissionError, NotFoundError, }; |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.NotFoundError = exports.PermissionError = exports.BadRequestError = exports.TimeoutError = exports.UnknownServiceError = exports.InvalidArgumentError = exports.InternalServerError = exports.ServiceValidationError = exports.LimitExceededError = exports.CacheServiceError = exports.CancelledError = exports.AuthenticationError = exports.AlreadyExistsError = exports.CacheGetStatus = exports.SetResponse = exports.GetResponse = exports.SimpleCacheClient = exports.LogFormat = exports.LogLevel = void 0; | ||
exports.NotFoundError = exports.PermissionError = exports.BadRequestError = exports.TimeoutError = exports.UnknownServiceError = exports.InvalidArgumentError = exports.InternalServerError = exports.ServiceValidationError = exports.LimitExceededError = exports.CacheServiceError = exports.CancelledError = exports.AuthenticationError = exports.AlreadyExistsError = exports.CacheInfo = exports.CacheGetStatus = exports.SetResponse = exports.GetResponse = exports.SimpleCacheClient = exports.getLogger = exports.LogFormat = exports.LogLevel = void 0; | ||
const SimpleCacheClient_1 = require("./SimpleCacheClient"); | ||
@@ -12,2 +12,4 @@ Object.defineProperty(exports, "SimpleCacheClient", { enumerable: true, get: function () { return SimpleCacheClient_1.SimpleCacheClient; } }); | ||
Object.defineProperty(exports, "CacheGetStatus", { enumerable: true, get: function () { return Result_1.CacheGetStatus; } }); | ||
const CacheInfo_1 = require("./messages/CacheInfo"); | ||
Object.defineProperty(exports, "CacheInfo", { enumerable: true, get: function () { return CacheInfo_1.CacheInfo; } }); | ||
const Errors_1 = require("./Errors"); | ||
@@ -30,2 +32,3 @@ Object.defineProperty(exports, "AlreadyExistsError", { enumerable: true, get: function () { return Errors_1.AlreadyExistsError; } }); | ||
Object.defineProperty(exports, "LogFormat", { enumerable: true, get: function () { return logging_1.LogFormat; } }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsMkRBQXNEO0FBdUJwRCxrR0F2Qk0scUNBQWlCLE9BdUJOO0FBdEJuQix3REFBbUQ7QUF1QmpELDRGQXZCTSx5QkFBVyxPQXVCTjtBQXRCYix3REFBbUQ7QUF1QmpELDRGQXZCTSx5QkFBVyxPQXVCTjtBQXRCYiw4Q0FBaUQ7QUF1Qi9DLCtGQXZCTSx1QkFBYyxPQXVCTjtBQXRCaEIscUNBY2tCO0FBU2hCLG1HQXRCQSwyQkFBa0IsT0FzQkE7QUFDbEIsb0dBdEJBLDRCQUFtQixPQXNCQTtBQUNuQiwrRkF0QkEsdUJBQWMsT0FzQkE7QUFDZCxrR0F0QkEsMEJBQWlCLE9Bc0JBO0FBQ2pCLG1HQXRCQSwyQkFBa0IsT0FzQkE7QUFDbEIsdUdBdEJBLCtCQUFzQixPQXNCQTtBQUN0QixvR0F0QkEsNEJBQW1CLE9Bc0JBO0FBQ25CLHFHQXRCQSw2QkFBb0IsT0FzQkE7QUFDcEIsb0dBdEJBLDRCQUFtQixPQXNCQTtBQUNuQiw2RkF0QkEscUJBQVksT0FzQkE7QUFDWixnR0F0QkEsd0JBQWUsT0FzQkE7QUFDZixnR0F0QkEsd0JBQWUsT0FzQkE7QUFDZiw4RkF0QkEsc0JBQWEsT0FzQkE7QUFuQmYsMkNBQW9EO0FBQTVDLG1HQUFBLFFBQVEsT0FBQTtBQUFFLG9HQUFBLFNBQVMsT0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7U2ltcGxlQ2FjaGVDbGllbnR9IGZyb20gJy4vU2ltcGxlQ2FjaGVDbGllbnQnO1xuaW1wb3J0IHtHZXRSZXNwb25zZX0gZnJvbSAnLi9tZXNzYWdlcy9HZXRSZXNwb25zZSc7XG5pbXBvcnQge1NldFJlc3BvbnNlfSBmcm9tICcuL21lc3NhZ2VzL1NldFJlc3BvbnNlJztcbmltcG9ydCB7Q2FjaGVHZXRTdGF0dXN9IGZyb20gJy4vbWVzc2FnZXMvUmVzdWx0JztcbmltcG9ydCB7XG4gIEFscmVhZHlFeGlzdHNFcnJvcixcbiAgQXV0aGVudGljYXRpb25FcnJvcixcbiAgQ2FuY2VsbGVkRXJyb3IsXG4gIENhY2hlU2VydmljZUVycm9yLFxuICBMaW1pdEV4Y2VlZGVkRXJyb3IsXG4gIFNlcnZpY2VWYWxpZGF0aW9uRXJyb3IsXG4gIEludGVybmFsU2VydmVyRXJyb3IsXG4gIEludmFsaWRBcmd1bWVudEVycm9yLFxuICBVbmtub3duU2VydmljZUVycm9yLFxuICBUaW1lb3V0RXJyb3IsXG4gIEJhZFJlcXVlc3RFcnJvcixcbiAgUGVybWlzc2lvbkVycm9yLFxuICBOb3RGb3VuZEVycm9yLFxufSBmcm9tICcuL0Vycm9ycyc7XG5cbmV4cG9ydCB7TG9nTGV2ZWwsIExvZ0Zvcm1hdH0gZnJvbSAnLi91dGlscy9sb2dnaW5nJztcblxuZXhwb3J0IHtcbiAgU2ltcGxlQ2FjaGVDbGllbnQsXG4gIEdldFJlc3BvbnNlLFxuICBTZXRSZXNwb25zZSxcbiAgQ2FjaGVHZXRTdGF0dXMsXG4gIEFscmVhZHlFeGlzdHNFcnJvcixcbiAgQXV0aGVudGljYXRpb25FcnJvcixcbiAgQ2FuY2VsbGVkRXJyb3IsXG4gIENhY2hlU2VydmljZUVycm9yLFxuICBMaW1pdEV4Y2VlZGVkRXJyb3IsXG4gIFNlcnZpY2VWYWxpZGF0aW9uRXJyb3IsXG4gIEludGVybmFsU2VydmVyRXJyb3IsXG4gIEludmFsaWRBcmd1bWVudEVycm9yLFxuICBVbmtub3duU2VydmljZUVycm9yLFxuICBUaW1lb3V0RXJyb3IsXG4gIEJhZFJlcXVlc3RFcnJvcixcbiAgUGVybWlzc2lvbkVycm9yLFxuICBOb3RGb3VuZEVycm9yLFxufTtcbiJdfQ== | ||
Object.defineProperty(exports, "getLogger", { enumerable: true, get: function () { return logging_1.getLogger; } }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsMkRBQXNEO0FBOEJwRCxrR0E5Qk0scUNBQWlCLE9BOEJOO0FBN0JuQix3REFBbUQ7QUE4QmpELDRGQTlCTSx5QkFBVyxPQThCTjtBQTdCYix3REFBbUQ7QUE4QmpELDRGQTlCTSx5QkFBVyxPQThCTjtBQTdCYiw4Q0FBaUQ7QUE4Qi9DLCtGQTlCTSx1QkFBYyxPQThCTjtBQTdCaEIsb0RBQStDO0FBOEI3QywwRkE5Qk0scUJBQVMsT0E4Qk47QUE3QlgscUNBY2tCO0FBZ0JoQixtR0E3QkEsMkJBQWtCLE9BNkJBO0FBQ2xCLG9HQTdCQSw0QkFBbUIsT0E2QkE7QUFDbkIsK0ZBN0JBLHVCQUFjLE9BNkJBO0FBQ2Qsa0dBN0JBLDBCQUFpQixPQTZCQTtBQUNqQixtR0E3QkEsMkJBQWtCLE9BNkJBO0FBQ2xCLHVHQTdCQSwrQkFBc0IsT0E2QkE7QUFDdEIsb0dBN0JBLDRCQUFtQixPQTZCQTtBQUNuQixxR0E3QkEsNkJBQW9CLE9BNkJBO0FBQ3BCLG9HQTdCQSw0QkFBbUIsT0E2QkE7QUFDbkIsNkZBN0JBLHFCQUFZLE9BNkJBO0FBQ1osZ0dBN0JBLHdCQUFlLE9BNkJBO0FBQ2YsZ0dBN0JBLHdCQUFlLE9BNkJBO0FBQ2YsOEZBN0JBLHNCQUFhLE9BNkJBO0FBMUJmLDJDQU15QjtBQUh2QixtR0FBQSxRQUFRLE9BQUE7QUFDUixvR0FBQSxTQUFTLE9BQUE7QUFDVCxvR0FBQSxTQUFTLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1NpbXBsZUNhY2hlQ2xpZW50fSBmcm9tICcuL1NpbXBsZUNhY2hlQ2xpZW50JztcbmltcG9ydCB7R2V0UmVzcG9uc2V9IGZyb20gJy4vbWVzc2FnZXMvR2V0UmVzcG9uc2UnO1xuaW1wb3J0IHtTZXRSZXNwb25zZX0gZnJvbSAnLi9tZXNzYWdlcy9TZXRSZXNwb25zZSc7XG5pbXBvcnQge0NhY2hlR2V0U3RhdHVzfSBmcm9tICcuL21lc3NhZ2VzL1Jlc3VsdCc7XG5pbXBvcnQge0NhY2hlSW5mb30gZnJvbSAnLi9tZXNzYWdlcy9DYWNoZUluZm8nO1xuaW1wb3J0IHtcbiAgQWxyZWFkeUV4aXN0c0Vycm9yLFxuICBBdXRoZW50aWNhdGlvbkVycm9yLFxuICBDYW5jZWxsZWRFcnJvcixcbiAgQ2FjaGVTZXJ2aWNlRXJyb3IsXG4gIExpbWl0RXhjZWVkZWRFcnJvcixcbiAgU2VydmljZVZhbGlkYXRpb25FcnJvcixcbiAgSW50ZXJuYWxTZXJ2ZXJFcnJvcixcbiAgSW52YWxpZEFyZ3VtZW50RXJyb3IsXG4gIFVua25vd25TZXJ2aWNlRXJyb3IsXG4gIFRpbWVvdXRFcnJvcixcbiAgQmFkUmVxdWVzdEVycm9yLFxuICBQZXJtaXNzaW9uRXJyb3IsXG4gIE5vdEZvdW5kRXJyb3IsXG59IGZyb20gJy4vRXJyb3JzJztcblxuZXhwb3J0IHtcbiAgTG9nZ2VyLFxuICBMb2dnZXJPcHRpb25zLFxuICBMb2dMZXZlbCxcbiAgTG9nRm9ybWF0LFxuICBnZXRMb2dnZXIsXG59IGZyb20gJy4vdXRpbHMvbG9nZ2luZyc7XG5cbmV4cG9ydCB7XG4gIFNpbXBsZUNhY2hlQ2xpZW50LFxuICBHZXRSZXNwb25zZSxcbiAgU2V0UmVzcG9uc2UsXG4gIENhY2hlR2V0U3RhdHVzLFxuICBDYWNoZUluZm8sXG4gIEFscmVhZHlFeGlzdHNFcnJvcixcbiAgQXV0aGVudGljYXRpb25FcnJvcixcbiAgQ2FuY2VsbGVkRXJyb3IsXG4gIENhY2hlU2VydmljZUVycm9yLFxuICBMaW1pdEV4Y2VlZGVkRXJyb3IsXG4gIFNlcnZpY2VWYWxpZGF0aW9uRXJyb3IsXG4gIEludGVybmFsU2VydmVyRXJyb3IsXG4gIEludmFsaWRBcmd1bWVudEVycm9yLFxuICBVbmtub3duU2VydmljZUVycm9yLFxuICBUaW1lb3V0RXJyb3IsXG4gIEJhZFJlcXVlc3RFcnJvcixcbiAgUGVybWlzc2lvbkVycm9yLFxuICBOb3RGb3VuZEVycm9yLFxufTtcbiJdfQ== |
@@ -25,3 +25,3 @@ "use strict"; | ||
constructor(props) { | ||
this.logger = (0, logging_1.getLogger)(this.constructor.name, props.loggerOptions); | ||
this.logger = (0, logging_1.getLogger)(this, props.loggerOptions); | ||
const headers = [ | ||
@@ -34,5 +34,5 @@ new HeadersInterceptor_1.Header('Authorization', props.authToken), | ||
(0, ClientTimeoutInterceptor_1.ClientTimeoutInterceptor)(Momento.REQUEST_TIMEOUT_MS), | ||
new RetryInterceptor_1.RetryInterceptor({ | ||
...(0, RetryInterceptor_1.createRetryInterceptorIfEnabled)({ | ||
loggerOptions: props.loggerOptions, | ||
}).addRetryInterceptor(), | ||
}), | ||
]; | ||
@@ -163,2 +163,2 @@ this.logger.debug(`Creating control client using endpoint: '${props.endpoint}`); | ||
Momento.REQUEST_TIMEOUT_MS = 60 * 1000; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Momento.js","sourceRoot":"","sources":["../../src/Momento.ts"],"names":[],"mappings":"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","sourcesContent":["import {control} from '@gomomento/generated-types';\nimport {Header, HeaderInterceptor} from './grpc/HeadersInterceptor';\nimport {ClientTimeoutInterceptor} from './grpc/ClientTimeoutInterceptor';\nimport {\n  AlreadyExistsError,\n  InvalidArgumentError,\n  NotFoundError,\n} from './Errors';\nimport {Status} from '@grpc/grpc-js/build/src/constants';\nimport {cacheServiceErrorMapper} from './CacheServiceErrorMapper';\nimport {ChannelCredentials, Interceptor} from '@grpc/grpc-js';\nimport {DeleteCacheResponse} from './messages/DeleteCacheResponse';\nimport {CreateCacheResponse} from './messages/CreateCacheResponse';\nimport {ListCachesResponse} from './messages/ListCachesResponse';\nimport {version} from '../package.json';\nimport {CreateSigningKeyResponse} from './messages/CreateSigningKeyResponse';\nimport {RevokeSigningKeyResponse} from './messages/RevokeSigningKeyResponse';\nimport {ListSigningKeysResponse} from './messages/ListSigningKeysResponse';\nimport {RetryInterceptor} from './grpc/RetryInterceptor';\nimport {getLogger, Logger, LoggerOptions} from './utils/logging';\n\nexport interface MomentoProps {\n  authToken: string;\n  endpoint: string;\n  loggerOptions?: LoggerOptions;\n}\n\nexport class Momento {\n  private readonly client: control.control_client.ScsControlClient;\n  private readonly interceptors: Interceptor[];\n  private static readonly REQUEST_TIMEOUT_MS: number = 60 * 1000;\n  private readonly logger: Logger;\n\n  /**\n   * @param {MomentoProps} props\n   */\n  constructor(props: MomentoProps) {\n    this.logger = getLogger(this.constructor.name, props.loggerOptions);\n    const headers = [\n      new Header('Authorization', props.authToken),\n      new Header('Agent', `javascript:${version}`),\n    ];\n    this.interceptors = [\n      new HeaderInterceptor(headers).addHeadersInterceptor(),\n      ClientTimeoutInterceptor(Momento.REQUEST_TIMEOUT_MS),\n      new RetryInterceptor({\n        loggerOptions: props.loggerOptions,\n      }).addRetryInterceptor(),\n    ];\n    this.logger.debug(\n      `Creating control client using endpoint: '${props.endpoint}`\n    );\n    this.client = new control.control_client.ScsControlClient(\n      props.endpoint,\n      ChannelCredentials.createSsl()\n    );\n  }\n\n  public async createCache(name: string): Promise<CreateCacheResponse> {\n    this.validateCacheName(name);\n    this.logger.info(`Creating cache: ${name}`);\n    const request = new control.control_client._CreateCacheRequest({\n      cache_name: name,\n    });\n    return await new Promise<CreateCacheResponse>((resolve, reject) => {\n      this.client.CreateCache(\n        request,\n        {interceptors: this.interceptors},\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        (err, resp) => {\n          if (err) {\n            if (err.code === Status.ALREADY_EXISTS) {\n              reject(\n                new AlreadyExistsError(\n                  `cache with name: ${name} already exists`\n                )\n              );\n            } else {\n              reject(cacheServiceErrorMapper(err));\n            }\n          } else {\n            resolve(new CreateCacheResponse());\n          }\n        }\n      );\n    });\n  }\n\n  public async deleteCache(name: string): Promise<DeleteCacheResponse> {\n    const request = new control.control_client._DeleteCacheRequest({\n      cache_name: name,\n    });\n    this.logger.info(`Deleting cache: ${name}`);\n    return await new Promise<DeleteCacheResponse>((resolve, reject) => {\n      this.client.DeleteCache(\n        request,\n        {interceptors: this.interceptors},\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        (err, resp) => {\n          if (err) {\n            if (err.code === Status.NOT_FOUND) {\n              reject(\n                new NotFoundError(`cache with name: ${name} does not exist`)\n              );\n            } else {\n              reject(cacheServiceErrorMapper(err));\n            }\n          } else {\n            resolve(new DeleteCacheResponse());\n          }\n        }\n      );\n    });\n  }\n\n  public async listCaches(nextToken?: string): Promise<ListCachesResponse> {\n    const request = new control.control_client._ListCachesRequest();\n    request.next_token = nextToken ?? '';\n    this.logger.debug(\"Issuing 'listCaches' request\");\n    return await new Promise<ListCachesResponse>((resolve, reject) => {\n      this.client.ListCaches(\n        request,\n        {interceptors: this.interceptors},\n        (err, resp) => {\n          if (err) {\n            reject(cacheServiceErrorMapper(err));\n          } else {\n            resolve(new ListCachesResponse(resp));\n          }\n        }\n      );\n    });\n  }\n\n  public async createSigningKey(\n    ttlMinutes: number,\n    endpoint: string\n  ): Promise<CreateSigningKeyResponse> {\n    this.validateTtlMinutes(ttlMinutes);\n    this.logger.debug(\"Issuing 'createSigningKey' request\");\n    const request = new control.control_client._CreateSigningKeyRequest();\n    request.ttl_minutes = ttlMinutes;\n    return await new Promise<CreateSigningKeyResponse>((resolve, reject) => {\n      this.client.CreateSigningKey(\n        request,\n        {interceptors: this.interceptors},\n        (err, resp) => {\n          if (err) {\n            reject(cacheServiceErrorMapper(err));\n          } else {\n            resolve(new CreateSigningKeyResponse(endpoint, resp));\n          }\n        }\n      );\n    });\n  }\n\n  public async revokeSigningKey(\n    keyId: string\n  ): Promise<RevokeSigningKeyResponse> {\n    const request = new control.control_client._RevokeSigningKeyRequest();\n    request.key_id = keyId;\n    this.logger.debug(\"Issuing 'revokeSigningKey' request\");\n    return await new Promise<RevokeSigningKeyResponse>((resolve, reject) => {\n      this.client.RevokeSigningKey(\n        request,\n        {interceptors: this.interceptors},\n        err => {\n          if (err) {\n            reject(cacheServiceErrorMapper(err));\n          } else {\n            resolve(new RevokeSigningKeyResponse());\n          }\n        }\n      );\n    });\n  }\n\n  public async listSigningKeys(\n    endpoint: string,\n    nextToken?: string\n  ): Promise<ListSigningKeysResponse> {\n    const request = new control.control_client._ListSigningKeysRequest();\n    request.next_token = nextToken ?? '';\n    this.logger.debug(\"Issuing 'listSigningKeys' request\");\n    return await new Promise<ListSigningKeysResponse>((resolve, reject) => {\n      this.client.ListSigningKeys(\n        request,\n        {interceptors: this.interceptors},\n        (err, resp) => {\n          if (err) {\n            reject(cacheServiceErrorMapper(err));\n          } else {\n            resolve(new ListSigningKeysResponse(endpoint, resp));\n          }\n        }\n      );\n    });\n  }\n\n  private validateCacheName(name: string) {\n    if (!name.trim()) {\n      throw new InvalidArgumentError('cache name must not be empty');\n    }\n  }\n\n  private validateTtlMinutes(ttlMinutes: number) {\n    if (ttlMinutes < 0) {\n      throw new InvalidArgumentError('ttlMinutes must be positive');\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Momento.js","sourceRoot":"","sources":["../../src/Momento.ts"],"names":[],"mappings":"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","sourcesContent":["import {control} from '@gomomento/generated-types';\nimport {Header, HeaderInterceptor} from './grpc/HeadersInterceptor';\nimport {ClientTimeoutInterceptor} from './grpc/ClientTimeoutInterceptor';\nimport {\n  AlreadyExistsError,\n  InvalidArgumentError,\n  NotFoundError,\n} from './Errors';\nimport {Status} from '@grpc/grpc-js/build/src/constants';\nimport {cacheServiceErrorMapper} from './CacheServiceErrorMapper';\nimport {ChannelCredentials, Interceptor} from '@grpc/grpc-js';\nimport {DeleteCacheResponse} from './messages/DeleteCacheResponse';\nimport {CreateCacheResponse} from './messages/CreateCacheResponse';\nimport {ListCachesResponse} from './messages/ListCachesResponse';\nimport {version} from '../package.json';\nimport {CreateSigningKeyResponse} from './messages/CreateSigningKeyResponse';\nimport {RevokeSigningKeyResponse} from './messages/RevokeSigningKeyResponse';\nimport {ListSigningKeysResponse} from './messages/ListSigningKeysResponse';\nimport {\n  createRetryInterceptorIfEnabled,\n  RetryInterceptor,\n} from './grpc/RetryInterceptor';\nimport {getLogger, Logger, LoggerOptions} from './utils/logging';\n\nexport interface MomentoProps {\n  authToken: string;\n  endpoint: string;\n  loggerOptions?: LoggerOptions;\n}\n\nexport class Momento {\n  private readonly client: control.control_client.ScsControlClient;\n  private readonly interceptors: Interceptor[];\n  private static readonly REQUEST_TIMEOUT_MS: number = 60 * 1000;\n  private readonly logger: Logger;\n\n  /**\n   * @param {MomentoProps} props\n   */\n  constructor(props: MomentoProps) {\n    this.logger = getLogger(this, props.loggerOptions);\n    const headers = [\n      new Header('Authorization', props.authToken),\n      new Header('Agent', `javascript:${version}`),\n    ];\n    this.interceptors = [\n      new HeaderInterceptor(headers).addHeadersInterceptor(),\n      ClientTimeoutInterceptor(Momento.REQUEST_TIMEOUT_MS),\n      ...createRetryInterceptorIfEnabled({\n        loggerOptions: props.loggerOptions,\n      }),\n    ];\n    this.logger.debug(\n      `Creating control client using endpoint: '${props.endpoint}`\n    );\n    this.client = new control.control_client.ScsControlClient(\n      props.endpoint,\n      ChannelCredentials.createSsl()\n    );\n  }\n\n  public async createCache(name: string): Promise<CreateCacheResponse> {\n    this.validateCacheName(name);\n    this.logger.info(`Creating cache: ${name}`);\n    const request = new control.control_client._CreateCacheRequest({\n      cache_name: name,\n    });\n    return await new Promise<CreateCacheResponse>((resolve, reject) => {\n      this.client.CreateCache(\n        request,\n        {interceptors: this.interceptors},\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        (err, resp) => {\n          if (err) {\n            if (err.code === Status.ALREADY_EXISTS) {\n              reject(\n                new AlreadyExistsError(\n                  `cache with name: ${name} already exists`\n                )\n              );\n            } else {\n              reject(cacheServiceErrorMapper(err));\n            }\n          } else {\n            resolve(new CreateCacheResponse());\n          }\n        }\n      );\n    });\n  }\n\n  public async deleteCache(name: string): Promise<DeleteCacheResponse> {\n    const request = new control.control_client._DeleteCacheRequest({\n      cache_name: name,\n    });\n    this.logger.info(`Deleting cache: ${name}`);\n    return await new Promise<DeleteCacheResponse>((resolve, reject) => {\n      this.client.DeleteCache(\n        request,\n        {interceptors: this.interceptors},\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        (err, resp) => {\n          if (err) {\n            if (err.code === Status.NOT_FOUND) {\n              reject(\n                new NotFoundError(`cache with name: ${name} does not exist`)\n              );\n            } else {\n              reject(cacheServiceErrorMapper(err));\n            }\n          } else {\n            resolve(new DeleteCacheResponse());\n          }\n        }\n      );\n    });\n  }\n\n  public async listCaches(nextToken?: string): Promise<ListCachesResponse> {\n    const request = new control.control_client._ListCachesRequest();\n    request.next_token = nextToken ?? '';\n    this.logger.debug(\"Issuing 'listCaches' request\");\n    return await new Promise<ListCachesResponse>((resolve, reject) => {\n      this.client.ListCaches(\n        request,\n        {interceptors: this.interceptors},\n        (err, resp) => {\n          if (err) {\n            reject(cacheServiceErrorMapper(err));\n          } else {\n            resolve(new ListCachesResponse(resp));\n          }\n        }\n      );\n    });\n  }\n\n  public async createSigningKey(\n    ttlMinutes: number,\n    endpoint: string\n  ): Promise<CreateSigningKeyResponse> {\n    this.validateTtlMinutes(ttlMinutes);\n    this.logger.debug(\"Issuing 'createSigningKey' request\");\n    const request = new control.control_client._CreateSigningKeyRequest();\n    request.ttl_minutes = ttlMinutes;\n    return await new Promise<CreateSigningKeyResponse>((resolve, reject) => {\n      this.client.CreateSigningKey(\n        request,\n        {interceptors: this.interceptors},\n        (err, resp) => {\n          if (err) {\n            reject(cacheServiceErrorMapper(err));\n          } else {\n            resolve(new CreateSigningKeyResponse(endpoint, resp));\n          }\n        }\n      );\n    });\n  }\n\n  public async revokeSigningKey(\n    keyId: string\n  ): Promise<RevokeSigningKeyResponse> {\n    const request = new control.control_client._RevokeSigningKeyRequest();\n    request.key_id = keyId;\n    this.logger.debug(\"Issuing 'revokeSigningKey' request\");\n    return await new Promise<RevokeSigningKeyResponse>((resolve, reject) => {\n      this.client.RevokeSigningKey(\n        request,\n        {interceptors: this.interceptors},\n        err => {\n          if (err) {\n            reject(cacheServiceErrorMapper(err));\n          } else {\n            resolve(new RevokeSigningKeyResponse());\n          }\n        }\n      );\n    });\n  }\n\n  public async listSigningKeys(\n    endpoint: string,\n    nextToken?: string\n  ): Promise<ListSigningKeysResponse> {\n    const request = new control.control_client._ListSigningKeysRequest();\n    request.next_token = nextToken ?? '';\n    this.logger.debug(\"Issuing 'listSigningKeys' request\");\n    return await new Promise<ListSigningKeysResponse>((resolve, reject) => {\n      this.client.ListSigningKeys(\n        request,\n        {interceptors: this.interceptors},\n        (err, resp) => {\n          if (err) {\n            reject(cacheServiceErrorMapper(err));\n          } else {\n            resolve(new ListSigningKeysResponse(endpoint, resp));\n          }\n        }\n      );\n    });\n  }\n\n  private validateCacheName(name: string) {\n    if (!name.trim()) {\n      throw new InvalidArgumentError('cache name must not be empty');\n    }\n  }\n\n  private validateTtlMinutes(ttlMinutes: number) {\n    if (ttlMinutes < 0) {\n      throw new InvalidArgumentError('ttlMinutes must be positive');\n    }\n  }\n}\n"]} |
@@ -26,5 +26,5 @@ import { GetResponse } from './messages/GetResponse'; | ||
private static readonly DEFAULT_REQUEST_TIMEOUT_MS; | ||
private static isUserAgentSent; | ||
private readonly logger; | ||
private readonly loggerOptions; | ||
private readonly allInterceptorsExceptHeaderInterceptor; | ||
/** | ||
@@ -31,0 +31,0 @@ * @param {MomentoCacheProps} props |
@@ -38,3 +38,3 @@ "use strict"; | ||
this.loggerOptions = props.loggerOptions; | ||
this.logger = (0, logging_1.getLogger)(this.constructor.name, props.loggerOptions); | ||
this.logger = (0, logging_1.getLogger)(this, props.loggerOptions); | ||
this.validateRequestTimeout(props.requestTimeoutMs); | ||
@@ -49,2 +49,16 @@ this.logger.debug(`Creating cache client using endpoint: '${props.endpoint}`); | ||
this.endpoint = props.endpoint; | ||
// The first interceptor in our list is a Header interceptor, which | ||
// includes a header for the cache name. The cache name is part of the | ||
// get/set API calls, so we cannot construct that interceptor here in the | ||
// constructor; we have to construct it for each request. Here, we construct | ||
// all of the other interceptors, which do not vary per request. It is crucial | ||
// that we only construct these once and re-use them, because some of them are | ||
// very heavy-weight (in terms of memory usage, EventEmitter registrations on the | ||
// `process` object, etc.). | ||
this.allInterceptorsExceptHeaderInterceptor = [ | ||
(0, ClientTimeoutInterceptor_1.ClientTimeoutInterceptor)(this.requestTimeoutMs), | ||
...(0, RetryInterceptor_1.createRetryInterceptorIfEnabled)({ | ||
loggerOptions: this.loggerOptions, | ||
}), | ||
]; | ||
} | ||
@@ -64,3 +78,3 @@ getEndpoint() { | ||
this.ensureValidSetRequest(key, value, ttl || this.defaultTtlSeconds); | ||
this.logger.debug(`Issuing 'set' request; key: ${key.toString()}, value: ${value.toString()}, ttl: ${(_a = ttl === null || ttl === void 0 ? void 0 : ttl.toString()) !== null && _a !== void 0 ? _a : 'null'}`); | ||
this.logger.trace(`Issuing 'set' request; key: ${key.toString()}, value length: ${value.length}, ttl: ${(_a = ttl === null || ttl === void 0 ? void 0 : ttl.toString()) !== null && _a !== void 0 ? _a : 'null'}`); | ||
const encodedKey = this.convert(key); | ||
@@ -91,3 +105,3 @@ const encodedValue = this.convert(value); | ||
this.ensureValidKey(key); | ||
this.logger.debug(`Issuing 'delete' request; key: ${key.toString()}`); | ||
this.logger.trace(`Issuing 'delete' request; key: ${key.toString()}`); | ||
return await this.sendDelete(cacheName, this.convert(key)); | ||
@@ -114,5 +128,5 @@ } | ||
this.ensureValidKey(key); | ||
this.logger.debug(`Issuing 'get' request; key: ${key.toString()}`); | ||
this.logger.trace(`Issuing 'get' request; key: ${key.toString()}`); | ||
const result = await this.sendGet(cacheName, this.convert(key)); | ||
this.logger.debug(`'get' request result: ${JSON.stringify(result)}`); | ||
this.logger.trace(`'get' request result: ${result.status}`); | ||
return result; | ||
@@ -150,6 +164,3 @@ } | ||
new HeadersInterceptor_1.HeaderInterceptor(headers).addHeadersInterceptor(), | ||
(0, ClientTimeoutInterceptor_1.ClientTimeoutInterceptor)(this.requestTimeoutMs), | ||
new RetryInterceptor_1.RetryInterceptor({ | ||
loggerOptions: this.loggerOptions, | ||
}).addRetryInterceptor(), | ||
...this.allInterceptorsExceptHeaderInterceptor, | ||
]; | ||
@@ -176,3 +187,2 @@ } | ||
MomentoCache.DEFAULT_REQUEST_TIMEOUT_MS = 5 * 1000; | ||
MomentoCache.isUserAgentSent = false; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MomentoCache.js","sourceRoot":"","sources":["../../src/MomentoCache.ts"],"names":[],"mappings":"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","sourcesContent":["import {cache} from '@gomomento/generated-types';\n// older versions of node don't have the global util variables https://github.com/nodejs/node/issues/20365\nimport {TextEncoder} from 'util';\nimport {Header, HeaderInterceptor} from './grpc/HeadersInterceptor';\nimport {ClientTimeoutInterceptor} from './grpc/ClientTimeoutInterceptor';\nimport {CacheGetStatus, momentoResultConverter} from './messages/Result';\nimport {InvalidArgumentError, UnknownServiceError} from './Errors';\nimport {cacheServiceErrorMapper} from './CacheServiceErrorMapper';\nimport {ChannelCredentials, Interceptor} from '@grpc/grpc-js';\nimport {GetResponse} from './messages/GetResponse';\nimport {SetResponse} from './messages/SetResponse';\nimport {version} from '../package.json';\nimport {DeleteResponse} from './messages/DeleteResponse';\nimport {RetryInterceptor} from './grpc/RetryInterceptor';\nimport {getLogger, Logger, LoggerOptions} from './utils/logging';\n\n/**\n * @property {string} authToken - momento jwt token\n * @property {string} endpoint - endpoint to reach momento cache\n * @property {number} defaultTtlSeconds - the default time to live of object inside of cache, in seconds\n * @property {number} requestTimeoutMs - the amount of time for a request to complete before timing out, in milliseconds\n */\ntype MomentoCacheProps = {\n  authToken: string;\n  endpoint: string;\n  defaultTtlSeconds: number;\n  requestTimeoutMs?: number;\n  loggerOptions?: LoggerOptions;\n};\n\nexport class MomentoCache {\n  private readonly client: cache.cache_client.ScsClient;\n  private readonly textEncoder: TextEncoder;\n  private readonly defaultTtlSeconds: number;\n  private readonly requestTimeoutMs: number;\n  private readonly authToken: string;\n  private readonly endpoint: string;\n  private static readonly DEFAULT_REQUEST_TIMEOUT_MS: number = 5 * 1000;\n  private static isUserAgentSent = false;\n  private readonly logger: Logger;\n  private readonly loggerOptions: LoggerOptions | undefined;\n\n  /**\n   * @param {MomentoCacheProps} props\n   */\n  constructor(props: MomentoCacheProps) {\n    this.loggerOptions = props.loggerOptions;\n    this.logger = getLogger(this.constructor.name, props.loggerOptions);\n    this.validateRequestTimeout(props.requestTimeoutMs);\n    this.logger.debug(\n      `Creating cache client using endpoint: '${props.endpoint}`\n    );\n    this.client = new cache.cache_client.ScsClient(\n      props.endpoint,\n      ChannelCredentials.createSsl()\n    );\n    this.textEncoder = new TextEncoder();\n    this.defaultTtlSeconds = props.defaultTtlSeconds;\n    this.requestTimeoutMs =\n      props.requestTimeoutMs || MomentoCache.DEFAULT_REQUEST_TIMEOUT_MS;\n    this.authToken = props.authToken;\n    this.endpoint = props.endpoint;\n  }\n\n  public getEndpoint(): string {\n    this.logger.debug(`Using cache endpoint: ${this.endpoint}`);\n    return this.endpoint;\n  }\n\n  private validateRequestTimeout(timeout?: number) {\n    this.logger.debug(`Request timeout: ${this.endpoint}`);\n    if (timeout && timeout <= 0) {\n      throw new InvalidArgumentError(\n        'request timeout must be greater than zero.'\n      );\n    }\n  }\n\n  public async set(\n    cacheName: string,\n    key: string | Uint8Array,\n    value: string | Uint8Array,\n    ttl?: number\n  ): Promise<SetResponse> {\n    this.ensureValidSetRequest(key, value, ttl || this.defaultTtlSeconds);\n    this.logger.debug(\n      `Issuing 'set' request; key: ${key.toString()}, value: ${value.toString()}, ttl: ${\n        ttl?.toString() ?? 'null'\n      }`\n    );\n    const encodedKey = this.convert(key);\n    const encodedValue = this.convert(value);\n\n    return await this.sendSet(\n      cacheName,\n      encodedKey,\n      encodedValue,\n      ttl || this.defaultTtlSeconds\n    );\n  }\n\n  private async sendSet(\n    cacheName: string,\n    key: Uint8Array,\n    value: Uint8Array,\n    ttl: number\n  ): Promise<SetResponse> {\n    const request = new cache.cache_client._SetRequest({\n      cache_body: value,\n      cache_key: key,\n      ttl_milliseconds: ttl * 1000,\n    });\n    return await new Promise((resolve, reject) => {\n      this.client.Set(\n        request,\n        {\n          interceptors: this.getInterceptors(cacheName),\n        },\n        (err, resp) => {\n          if (resp) {\n            resolve(this.parseSetResponse(resp, value));\n          } else {\n            reject(cacheServiceErrorMapper(err));\n          }\n        }\n      );\n    });\n  }\n\n  public async delete(\n    cacheName: string,\n    key: string | Uint8Array\n  ): Promise<DeleteResponse> {\n    this.ensureValidKey(key);\n    this.logger.debug(`Issuing 'delete' request; key: ${key.toString()}`);\n    return await this.sendDelete(cacheName, this.convert(key));\n  }\n\n  private async sendDelete(\n    cacheName: string,\n    key: Uint8Array\n  ): Promise<DeleteResponse> {\n    const request = new cache.cache_client._DeleteRequest({\n      cache_key: key,\n    });\n    return await new Promise((resolve, reject) => {\n      this.client.Delete(\n        request,\n        {\n          interceptors: this.getInterceptors(cacheName),\n        },\n        (err, resp) => {\n          if (resp) {\n            resolve(new DeleteResponse());\n          } else {\n            reject(cacheServiceErrorMapper(err));\n          }\n        }\n      );\n    });\n  }\n\n  public async get(\n    cacheName: string,\n    key: string | Uint8Array\n  ): Promise<GetResponse> {\n    this.ensureValidKey(key);\n    this.logger.debug(`Issuing 'get' request; key: ${key.toString()}`);\n    const result = await this.sendGet(cacheName, this.convert(key));\n    this.logger.debug(`'get' request result: ${JSON.stringify(result)}`);\n    return result;\n  }\n\n  private async sendGet(\n    cacheName: string,\n    key: Uint8Array\n  ): Promise<GetResponse> {\n    const request = new cache.cache_client._GetRequest({\n      cache_key: key,\n    });\n\n    return await new Promise((resolve, reject) => {\n      this.client.Get(\n        request,\n        {\n          interceptors: this.getInterceptors(cacheName),\n        },\n        (err, resp) => {\n          if (resp) {\n            const momentoResult = momentoResultConverter(resp.result);\n            if (\n              momentoResult !== CacheGetStatus.Miss &&\n              momentoResult !== CacheGetStatus.Hit\n            ) {\n              reject(new UnknownServiceError(resp.message));\n            }\n            resolve(this.parseGetResponse(resp));\n          } else {\n            reject(cacheServiceErrorMapper(err));\n          }\n        }\n      );\n    });\n  }\n\n  private parseGetResponse = (\n    resp: cache.cache_client._GetResponse\n  ): GetResponse => {\n    const momentoResult = momentoResultConverter(resp.result);\n    return new GetResponse(momentoResult, resp.message, resp.cache_body);\n  };\n\n  private parseSetResponse = (\n    resp: cache.cache_client._SetResponse,\n    value: Uint8Array\n  ): SetResponse => {\n    return new SetResponse(resp.message, value);\n  };\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private ensureValidKey = (key: any) => {\n    if (!key) {\n      throw new InvalidArgumentError('key must not be empty');\n    }\n  };\n\n  private getInterceptors(cacheName: string): Interceptor[] {\n    const headers = [\n      new Header('Authorization', this.authToken),\n      new Header('cache', cacheName),\n      new Header('Agent', `javascript:${version}`),\n    ];\n    return [\n      new HeaderInterceptor(headers).addHeadersInterceptor(),\n      ClientTimeoutInterceptor(this.requestTimeoutMs),\n      new RetryInterceptor({\n        loggerOptions: this.loggerOptions,\n      }).addRetryInterceptor(),\n    ];\n  }\n\n  private convert(v: string | Uint8Array): Uint8Array {\n    if (typeof v === 'string') {\n      return this.textEncoder.encode(v);\n    }\n    return v;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private ensureValidSetRequest(key: any, value: any, ttl: number) {\n    this.ensureValidKey(key);\n\n    if (!value) {\n      throw new InvalidArgumentError('value must not be empty');\n    }\n\n    if (ttl && ttl < 0) {\n      throw new InvalidArgumentError('ttl must be a positive integer');\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MomentoCache.js","sourceRoot":"","sources":["../../src/MomentoCache.ts"],"names":[],"mappings":"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","sourcesContent":["import {cache} from '@gomomento/generated-types';\n// older versions of node don't have the global util variables https://github.com/nodejs/node/issues/20365\nimport {TextEncoder} from 'util';\nimport {Header, HeaderInterceptor} from './grpc/HeadersInterceptor';\nimport {ClientTimeoutInterceptor} from './grpc/ClientTimeoutInterceptor';\nimport {CacheGetStatus, momentoResultConverter} from './messages/Result';\nimport {InvalidArgumentError, UnknownServiceError} from './Errors';\nimport {cacheServiceErrorMapper} from './CacheServiceErrorMapper';\nimport {ChannelCredentials, Interceptor} from '@grpc/grpc-js';\nimport {GetResponse} from './messages/GetResponse';\nimport {SetResponse} from './messages/SetResponse';\nimport {version} from '../package.json';\nimport {DeleteResponse} from './messages/DeleteResponse';\nimport {createRetryInterceptorIfEnabled} from './grpc/RetryInterceptor';\nimport {getLogger, Logger, LoggerOptions} from './utils/logging';\n\n/**\n * @property {string} authToken - momento jwt token\n * @property {string} endpoint - endpoint to reach momento cache\n * @property {number} defaultTtlSeconds - the default time to live of object inside of cache, in seconds\n * @property {number} requestTimeoutMs - the amount of time for a request to complete before timing out, in milliseconds\n */\ntype MomentoCacheProps = {\n  authToken: string;\n  endpoint: string;\n  defaultTtlSeconds: number;\n  requestTimeoutMs?: number;\n  loggerOptions?: LoggerOptions;\n};\n\nexport class MomentoCache {\n  private readonly client: cache.cache_client.ScsClient;\n  private readonly textEncoder: TextEncoder;\n  private readonly defaultTtlSeconds: number;\n  private readonly requestTimeoutMs: number;\n  private readonly authToken: string;\n  private readonly endpoint: string;\n  private static readonly DEFAULT_REQUEST_TIMEOUT_MS: number = 5 * 1000;\n  private readonly logger: Logger;\n  private readonly loggerOptions: LoggerOptions | undefined;\n  private readonly allInterceptorsExceptHeaderInterceptor: Interceptor[];\n\n  /**\n   * @param {MomentoCacheProps} props\n   */\n  constructor(props: MomentoCacheProps) {\n    this.loggerOptions = props.loggerOptions;\n    this.logger = getLogger(this, props.loggerOptions);\n    this.validateRequestTimeout(props.requestTimeoutMs);\n    this.logger.debug(\n      `Creating cache client using endpoint: '${props.endpoint}`\n    );\n    this.client = new cache.cache_client.ScsClient(\n      props.endpoint,\n      ChannelCredentials.createSsl()\n    );\n    this.textEncoder = new TextEncoder();\n    this.defaultTtlSeconds = props.defaultTtlSeconds;\n    this.requestTimeoutMs =\n      props.requestTimeoutMs || MomentoCache.DEFAULT_REQUEST_TIMEOUT_MS;\n    this.authToken = props.authToken;\n    this.endpoint = props.endpoint;\n\n    // The first interceptor in our list is a Header interceptor, which\n    // includes a header for the cache name.  The cache name is part of the\n    // get/set API calls, so we cannot construct that interceptor here in the\n    // constructor; we have to construct it for each request.  Here, we construct\n    // all of the other interceptors, which do not vary per request.  It is crucial\n    // that we only construct these once and re-use them, because some of them are\n    // very heavy-weight (in terms of memory usage, EventEmitter registrations on the\n    // `process` object, etc.).\n    this.allInterceptorsExceptHeaderInterceptor = [\n      ClientTimeoutInterceptor(this.requestTimeoutMs),\n      ...createRetryInterceptorIfEnabled({\n        loggerOptions: this.loggerOptions,\n      }),\n    ];\n  }\n\n  public getEndpoint(): string {\n    this.logger.debug(`Using cache endpoint: ${this.endpoint}`);\n    return this.endpoint;\n  }\n\n  private validateRequestTimeout(timeout?: number) {\n    this.logger.debug(`Request timeout: ${this.endpoint}`);\n    if (timeout && timeout <= 0) {\n      throw new InvalidArgumentError(\n        'request timeout must be greater than zero.'\n      );\n    }\n  }\n\n  public async set(\n    cacheName: string,\n    key: string | Uint8Array,\n    value: string | Uint8Array,\n    ttl?: number\n  ): Promise<SetResponse> {\n    this.ensureValidSetRequest(key, value, ttl || this.defaultTtlSeconds);\n    this.logger.trace(\n      `Issuing 'set' request; key: ${key.toString()}, value length: ${\n        value.length\n      }, ttl: ${ttl?.toString() ?? 'null'}`\n    );\n    const encodedKey = this.convert(key);\n    const encodedValue = this.convert(value);\n\n    return await this.sendSet(\n      cacheName,\n      encodedKey,\n      encodedValue,\n      ttl || this.defaultTtlSeconds\n    );\n  }\n\n  private async sendSet(\n    cacheName: string,\n    key: Uint8Array,\n    value: Uint8Array,\n    ttl: number\n  ): Promise<SetResponse> {\n    const request = new cache.cache_client._SetRequest({\n      cache_body: value,\n      cache_key: key,\n      ttl_milliseconds: ttl * 1000,\n    });\n    return await new Promise((resolve, reject) => {\n      this.client.Set(\n        request,\n        {\n          interceptors: this.getInterceptors(cacheName),\n        },\n        (err, resp) => {\n          if (resp) {\n            resolve(this.parseSetResponse(resp, value));\n          } else {\n            reject(cacheServiceErrorMapper(err));\n          }\n        }\n      );\n    });\n  }\n\n  public async delete(\n    cacheName: string,\n    key: string | Uint8Array\n  ): Promise<DeleteResponse> {\n    this.ensureValidKey(key);\n    this.logger.trace(`Issuing 'delete' request; key: ${key.toString()}`);\n    return await this.sendDelete(cacheName, this.convert(key));\n  }\n\n  private async sendDelete(\n    cacheName: string,\n    key: Uint8Array\n  ): Promise<DeleteResponse> {\n    const request = new cache.cache_client._DeleteRequest({\n      cache_key: key,\n    });\n    return await new Promise((resolve, reject) => {\n      this.client.Delete(\n        request,\n        {\n          interceptors: this.getInterceptors(cacheName),\n        },\n        (err, resp) => {\n          if (resp) {\n            resolve(new DeleteResponse());\n          } else {\n            reject(cacheServiceErrorMapper(err));\n          }\n        }\n      );\n    });\n  }\n\n  public async get(\n    cacheName: string,\n    key: string | Uint8Array\n  ): Promise<GetResponse> {\n    this.ensureValidKey(key);\n    this.logger.trace(`Issuing 'get' request; key: ${key.toString()}`);\n    const result = await this.sendGet(cacheName, this.convert(key));\n    this.logger.trace(`'get' request result: ${result.status}`);\n    return result;\n  }\n\n  private async sendGet(\n    cacheName: string,\n    key: Uint8Array\n  ): Promise<GetResponse> {\n    const request = new cache.cache_client._GetRequest({\n      cache_key: key,\n    });\n\n    return await new Promise((resolve, reject) => {\n      this.client.Get(\n        request,\n        {\n          interceptors: this.getInterceptors(cacheName),\n        },\n        (err, resp) => {\n          if (resp) {\n            const momentoResult = momentoResultConverter(resp.result);\n            if (\n              momentoResult !== CacheGetStatus.Miss &&\n              momentoResult !== CacheGetStatus.Hit\n            ) {\n              reject(new UnknownServiceError(resp.message));\n            }\n            resolve(this.parseGetResponse(resp));\n          } else {\n            reject(cacheServiceErrorMapper(err));\n          }\n        }\n      );\n    });\n  }\n\n  private parseGetResponse = (\n    resp: cache.cache_client._GetResponse\n  ): GetResponse => {\n    const momentoResult = momentoResultConverter(resp.result);\n    return new GetResponse(momentoResult, resp.message, resp.cache_body);\n  };\n\n  private parseSetResponse = (\n    resp: cache.cache_client._SetResponse,\n    value: Uint8Array\n  ): SetResponse => {\n    return new SetResponse(resp.message, value);\n  };\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private ensureValidKey = (key: any) => {\n    if (!key) {\n      throw new InvalidArgumentError('key must not be empty');\n    }\n  };\n\n  private getInterceptors(cacheName: string): Interceptor[] {\n    const headers = [\n      new Header('Authorization', this.authToken),\n      new Header('cache', cacheName),\n      new Header('Agent', `javascript:${version}`),\n    ];\n    return [\n      new HeaderInterceptor(headers).addHeadersInterceptor(),\n      ...this.allInterceptorsExceptHeaderInterceptor,\n    ];\n  }\n\n  private convert(v: string | Uint8Array): Uint8Array {\n    if (typeof v === 'string') {\n      return this.textEncoder.encode(v);\n    }\n    return v;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private ensureValidSetRequest(key: any, value: any, ttl: number) {\n    this.ensureValidKey(key);\n\n    if (!value) {\n      throw new InvalidArgumentError('value must not be empty');\n    }\n\n    if (ttl && ttl < 0) {\n      throw new InvalidArgumentError('ttl must be a positive integer');\n    }\n  }\n}\n"]} |
@@ -28,3 +28,3 @@ "use strict"; | ||
constructor(authToken, defaultTtlSeconds, options) { | ||
this.logger = (0, logging_1.getLogger)(this.constructor.name, options === null || options === void 0 ? void 0 : options.loggerOptions); | ||
this.logger = (0, logging_1.getLogger)(this, options === null || options === void 0 ? void 0 : options.loggerOptions); | ||
const claims = (0, jwt_1.decodeJwt)(authToken); | ||
@@ -144,2 +144,2 @@ const controlEndpoint = claims.cp; | ||
exports.SimpleCacheClient = SimpleCacheClient; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SimpleCacheClient.js","sourceRoot":"","sources":["../../src/SimpleCacheClient.ts"],"names":[],"mappings":"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","sourcesContent":["import {Momento} from './Momento';\nimport {MomentoCache} from './MomentoCache';\nimport {decodeJwt} from './utils/jwt';\nimport {SetResponse} from './messages/SetResponse';\nimport {GetResponse} from './messages/GetResponse';\nimport {CreateCacheResponse} from './messages/CreateCacheResponse';\nimport {DeleteCacheResponse} from './messages/DeleteCacheResponse';\nimport {ListCachesResponse} from './messages/ListCachesResponse';\nimport {DeleteResponse} from './messages/DeleteResponse';\nimport {CreateSigningKeyResponse} from './messages/CreateSigningKeyResponse';\nimport {RevokeSigningKeyResponse} from './messages/RevokeSigningKeyResponse';\nimport {ListSigningKeysResponse} from './messages/ListSigningKeysResponse';\nimport {getLogger, Logger, LoggerOptions} from './utils/logging';\n\nexport interface SimpleCacheClientOptions {\n  /**\n   * @param {number} [requestTimeoutMs] - A timeout in milliseconds for get and set operations\n   * to complete. Defaults to 5 seconds. If the request takes longer than this value, it\n   * will be terminated and throw a TimeoutError.\n   */\n  requestTimeoutMs?: number;\n  /**\n   * @param {LoggerOptions} [loggerOptions] - optional configuration settings to control logging\n   * output.\n   */\n  loggerOptions?: LoggerOptions;\n}\n\n/**\n * Momento Simple Cache Client.\n *\n * Features include:\n * - Get, set, and delete data\n * - Create, delete, and list caches\n * - Create, revoke, and list signing keys\n * @export\n * @class SimpleCacheClient\n */\nexport class SimpleCacheClient {\n  private readonly dataClient: MomentoCache;\n  private readonly controlClient: Momento;\n  private readonly logger: Logger;\n\n  /**\n   * Creates an instance of SimpleCacheClient.\n   * @param {string} authToken - Momento token to authenticate requests with Simple Cache Service.\n   * @param {number} defaultTtlSeconds - A default time to live, in seconds, for cache objects\n   * created by this client.\n   * @param {SimpleCacheClientOptions} options - additional configuration options for the cache client.\n   * @memberof SimpleCacheClient\n   */\n  constructor(\n    authToken: string,\n    defaultTtlSeconds: number,\n    options?: SimpleCacheClientOptions\n  ) {\n    this.logger = getLogger(this.constructor.name, options?.loggerOptions);\n    const claims = decodeJwt(authToken);\n    const controlEndpoint = claims.cp;\n    const dataEndpoint = claims.c;\n    this.dataClient = new MomentoCache({\n      authToken,\n      defaultTtlSeconds,\n      endpoint: dataEndpoint,\n      requestTimeoutMs: options?.requestTimeoutMs,\n      loggerOptions: options?.loggerOptions,\n    });\n\n    this.controlClient = new Momento({\n      endpoint: controlEndpoint,\n      authToken,\n      loggerOptions: options?.loggerOptions,\n    });\n  }\n\n  /**\n   * Get the cache value stored for the given key.\n   * @param {string} cacheName - Name of the cache to perform the lookup in.\n   * @param {(string | Uint8Array)} key - The key to lookup.\n   * @returns {Promise<GetResponse>} - Promise containing the status\n   * of the get operation (hit or miss) and the associated value.\n   * @memberof SimpleCacheClient\n   */\n  public async get(\n    cacheName: string,\n    key: string | Uint8Array\n  ): Promise<GetResponse> {\n    return await this.dataClient.get(cacheName, key);\n  }\n\n  /**\n   * Sets the value in cache with a given time to live (TTL) seconds.\n   * If a value for this key is already present it will be replaced by the new value.\n   * @param {string} cacheName - Name of the cache to store the item in.\n   * @param {(string | Uint8Array)} key - The key to set.\n   * @param {(string | Uint8Array)} value - The value to be stored.\n   * @param {number} [ttl] - Time to live (TTL) for the item in Cache.\n   * This TTL takes precedence over the TTL used when initializing a cache client.\n   * @returns {Promise<SetResponse>} - Result of the set operation.\n   * @memberof SimpleCacheClient\n   */\n  public async set(\n    cacheName: string,\n    key: string | Uint8Array,\n    value: string | Uint8Array,\n    ttl?: number\n  ): Promise<SetResponse> {\n    return await this.dataClient.set(cacheName, key, value, ttl);\n  }\n\n  /**\n   * Remove the key from the cache.\n   * @param {string} cacheName - Name of the cache to delete the key from.\n   * @param {(string | Uint8Array)} key - The key to delete.\n   * @returns {Promise<DeleteResponse>} - Promise containing the result of the\n   * delete operation.\n   * @memberof SimpleCacheClient\n   */\n  public async delete(\n    cacheName: string,\n    key: string | Uint8Array\n  ): Promise<DeleteResponse> {\n    return await this.dataClient.delete(cacheName, key);\n  }\n\n  /**\n   * Create a cache if it does not exist.\n   * @param {string} cacheName - Name of the cache to be created.\n   * @returns {Promise<CreateCacheResponse>} - Promise of the create cache result.\n   * @memberof SimpleCacheClient\n   */\n  public async createCache(cacheName: string): Promise<CreateCacheResponse> {\n    return await this.controlClient.createCache(cacheName);\n  }\n\n  /**\n   * Delete a cache and all items stored in it.\n   * @param {string} cacheName - Name of the cache to delete.\n   * @returns {Promise<DeleteCacheResponse>} - Promise of the delete cache result.\n   * @memberof SimpleCacheClient\n   */\n  public async deleteCache(cacheName: string): Promise<DeleteCacheResponse> {\n    return await this.controlClient.deleteCache(cacheName);\n  }\n\n  /**\n   * List all caches.\n   * @param {string} [nextToken] - A token to specify where to start paginating.\n   * This is the NextToken from a previous response.\n   * @returns {Promise<ListCacheResponse>} - Promise of the list cache response.\n   * Contains the listed caches and a next token to continue listing.\n   * @memberof SimpleCacheClient\n   */\n  public async listCaches(nextToken?: string): Promise<ListCachesResponse> {\n    return await this.controlClient.listCaches(nextToken);\n  }\n\n  /**\n   * Create a Momento signing key.\n   * @param {number} ttlMinutes - The time to live in minutes until the Momento signing key expires.\n   * @returns {Promise<CreateSigningKeyResponse>} - Promise of create signing key\n   * response. Contains endpoint and expiration.\n   * @memberof SimpleCacheClient\n   */\n  public async createSigningKey(\n    ttlMinutes: number\n  ): Promise<CreateSigningKeyResponse> {\n    return await this.controlClient.createSigningKey(\n      ttlMinutes,\n      this.dataClient.getEndpoint()\n    );\n  }\n\n  /**\n   * Revokes a Momento signing key.\n   *\n   * All tokens signed by this key will be invalid.\n   * @param {string} keyId  - The ID of the Momento signing key to revoke.\n   * @returns {Promise<RevokeSigningKeyResponse>} - Revocation response (empty)\n   * @memberof SimpleCacheClient\n   */\n  public async revokeSigningKey(\n    keyId: string\n  ): Promise<RevokeSigningKeyResponse> {\n    return await this.controlClient.revokeSigningKey(keyId);\n  }\n\n  /**\n   * Lists all Momento signing keys for the provided auth token.\n   * @param {string} [nextToken] - Token to continue paginating through the list.\n   * @returns {Promise<ListSigningKeysResponse>} - Promise of the list signing keys response.\n   * Contains the retrieved signing keys and a next token to continue listing.\n   * @memberof SimpleCacheClient\n   */\n  public async listSigningKeys(\n    nextToken?: string\n  ): Promise<ListSigningKeysResponse> {\n    return await this.controlClient.listSigningKeys(\n      this.dataClient.getEndpoint(),\n      nextToken\n    );\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SimpleCacheClient.js","sourceRoot":"","sources":["../../src/SimpleCacheClient.ts"],"names":[],"mappings":"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","sourcesContent":["import {Momento} from './Momento';\nimport {MomentoCache} from './MomentoCache';\nimport {decodeJwt} from './utils/jwt';\nimport {SetResponse} from './messages/SetResponse';\nimport {GetResponse} from './messages/GetResponse';\nimport {CreateCacheResponse} from './messages/CreateCacheResponse';\nimport {DeleteCacheResponse} from './messages/DeleteCacheResponse';\nimport {ListCachesResponse} from './messages/ListCachesResponse';\nimport {DeleteResponse} from './messages/DeleteResponse';\nimport {CreateSigningKeyResponse} from './messages/CreateSigningKeyResponse';\nimport {RevokeSigningKeyResponse} from './messages/RevokeSigningKeyResponse';\nimport {ListSigningKeysResponse} from './messages/ListSigningKeysResponse';\nimport {getLogger, Logger, LoggerOptions} from './utils/logging';\n\nexport interface SimpleCacheClientOptions {\n  /**\n   * @param {number} [requestTimeoutMs] - A timeout in milliseconds for get and set operations\n   * to complete. Defaults to 5 seconds. If the request takes longer than this value, it\n   * will be terminated and throw a TimeoutError.\n   */\n  requestTimeoutMs?: number;\n  /**\n   * @param {LoggerOptions} [loggerOptions] - optional configuration settings to control logging\n   * output.\n   */\n  loggerOptions?: LoggerOptions;\n}\n\n/**\n * Momento Simple Cache Client.\n *\n * Features include:\n * - Get, set, and delete data\n * - Create, delete, and list caches\n * - Create, revoke, and list signing keys\n * @export\n * @class SimpleCacheClient\n */\nexport class SimpleCacheClient {\n  private readonly dataClient: MomentoCache;\n  private readonly controlClient: Momento;\n  private readonly logger: Logger;\n\n  /**\n   * Creates an instance of SimpleCacheClient.\n   * @param {string} authToken - Momento token to authenticate requests with Simple Cache Service.\n   * @param {number} defaultTtlSeconds - A default time to live, in seconds, for cache objects\n   * created by this client.\n   * @param {SimpleCacheClientOptions} options - additional configuration options for the cache client.\n   * @memberof SimpleCacheClient\n   */\n  constructor(\n    authToken: string,\n    defaultTtlSeconds: number,\n    options?: SimpleCacheClientOptions\n  ) {\n    this.logger = getLogger(this, options?.loggerOptions);\n    const claims = decodeJwt(authToken);\n    const controlEndpoint = claims.cp;\n    const dataEndpoint = claims.c;\n    this.dataClient = new MomentoCache({\n      authToken,\n      defaultTtlSeconds,\n      endpoint: dataEndpoint,\n      requestTimeoutMs: options?.requestTimeoutMs,\n      loggerOptions: options?.loggerOptions,\n    });\n\n    this.controlClient = new Momento({\n      endpoint: controlEndpoint,\n      authToken,\n      loggerOptions: options?.loggerOptions,\n    });\n  }\n\n  /**\n   * Get the cache value stored for the given key.\n   * @param {string} cacheName - Name of the cache to perform the lookup in.\n   * @param {(string | Uint8Array)} key - The key to lookup.\n   * @returns {Promise<GetResponse>} - Promise containing the status\n   * of the get operation (hit or miss) and the associated value.\n   * @memberof SimpleCacheClient\n   */\n  public async get(\n    cacheName: string,\n    key: string | Uint8Array\n  ): Promise<GetResponse> {\n    return await this.dataClient.get(cacheName, key);\n  }\n\n  /**\n   * Sets the value in cache with a given time to live (TTL) seconds.\n   * If a value for this key is already present it will be replaced by the new value.\n   * @param {string} cacheName - Name of the cache to store the item in.\n   * @param {(string | Uint8Array)} key - The key to set.\n   * @param {(string | Uint8Array)} value - The value to be stored.\n   * @param {number} [ttl] - Time to live (TTL) for the item in Cache.\n   * This TTL takes precedence over the TTL used when initializing a cache client.\n   * @returns {Promise<SetResponse>} - Result of the set operation.\n   * @memberof SimpleCacheClient\n   */\n  public async set(\n    cacheName: string,\n    key: string | Uint8Array,\n    value: string | Uint8Array,\n    ttl?: number\n  ): Promise<SetResponse> {\n    return await this.dataClient.set(cacheName, key, value, ttl);\n  }\n\n  /**\n   * Remove the key from the cache.\n   * @param {string} cacheName - Name of the cache to delete the key from.\n   * @param {(string | Uint8Array)} key - The key to delete.\n   * @returns {Promise<DeleteResponse>} - Promise containing the result of the\n   * delete operation.\n   * @memberof SimpleCacheClient\n   */\n  public async delete(\n    cacheName: string,\n    key: string | Uint8Array\n  ): Promise<DeleteResponse> {\n    return await this.dataClient.delete(cacheName, key);\n  }\n\n  /**\n   * Create a cache if it does not exist.\n   * @param {string} cacheName - Name of the cache to be created.\n   * @returns {Promise<CreateCacheResponse>} - Promise of the create cache result.\n   * @memberof SimpleCacheClient\n   */\n  public async createCache(cacheName: string): Promise<CreateCacheResponse> {\n    return await this.controlClient.createCache(cacheName);\n  }\n\n  /**\n   * Delete a cache and all items stored in it.\n   * @param {string} cacheName - Name of the cache to delete.\n   * @returns {Promise<DeleteCacheResponse>} - Promise of the delete cache result.\n   * @memberof SimpleCacheClient\n   */\n  public async deleteCache(cacheName: string): Promise<DeleteCacheResponse> {\n    return await this.controlClient.deleteCache(cacheName);\n  }\n\n  /**\n   * List all caches.\n   * @param {string} [nextToken] - A token to specify where to start paginating.\n   * This is the NextToken from a previous response.\n   * @returns {Promise<ListCacheResponse>} - Promise of the list cache response.\n   * Contains the listed caches and a next token to continue listing.\n   * @memberof SimpleCacheClient\n   */\n  public async listCaches(nextToken?: string): Promise<ListCachesResponse> {\n    return await this.controlClient.listCaches(nextToken);\n  }\n\n  /**\n   * Create a Momento signing key.\n   * @param {number} ttlMinutes - The time to live in minutes until the Momento signing key expires.\n   * @returns {Promise<CreateSigningKeyResponse>} - Promise of create signing key\n   * response. Contains endpoint and expiration.\n   * @memberof SimpleCacheClient\n   */\n  public async createSigningKey(\n    ttlMinutes: number\n  ): Promise<CreateSigningKeyResponse> {\n    return await this.controlClient.createSigningKey(\n      ttlMinutes,\n      this.dataClient.getEndpoint()\n    );\n  }\n\n  /**\n   * Revokes a Momento signing key.\n   *\n   * All tokens signed by this key will be invalid.\n   * @param {string} keyId  - The ID of the Momento signing key to revoke.\n   * @returns {Promise<RevokeSigningKeyResponse>} - Revocation response (empty)\n   * @memberof SimpleCacheClient\n   */\n  public async revokeSigningKey(\n    keyId: string\n  ): Promise<RevokeSigningKeyResponse> {\n    return await this.controlClient.revokeSigningKey(keyId);\n  }\n\n  /**\n   * Lists all Momento signing keys for the provided auth token.\n   * @param {string} [nextToken] - Token to continue paginating through the list.\n   * @returns {Promise<ListSigningKeysResponse>} - Promise of the list signing keys response.\n   * Contains the retrieved signing keys and a next token to continue listing.\n   * @memberof SimpleCacheClient\n   */\n  public async listSigningKeys(\n    nextToken?: string\n  ): Promise<ListSigningKeysResponse> {\n    return await this.controlClient.listSigningKeys(\n      this.dataClient.getEndpoint(),\n      nextToken\n    );\n  }\n}\n"]} |
export interface Logger { | ||
error(msg: string): void; | ||
warn(msg: string): void; | ||
info(msg: string): void; | ||
debug(msg: string): void; | ||
trace(msg: string): void; | ||
} | ||
export declare enum LogLevel { | ||
TRACE = "trace", | ||
DEBUG = "debug", | ||
INFO = "info" | ||
INFO = "info", | ||
WARN = "warn", | ||
ERROR = "error" | ||
} | ||
@@ -17,2 +23,2 @@ export declare enum LogFormat { | ||
} | ||
export declare function getLogger(name: string, options?: LoggerOptions): Logger; | ||
export declare function getLogger(caller: string | any, options?: LoggerOptions): Logger; |
@@ -7,4 +7,7 @@ "use strict"; | ||
(function (LogLevel) { | ||
LogLevel["TRACE"] = "trace"; | ||
LogLevel["DEBUG"] = "debug"; | ||
LogLevel["INFO"] = "info"; | ||
LogLevel["WARN"] = "warn"; | ||
LogLevel["ERROR"] = "error"; | ||
})(LogLevel = exports.LogLevel || (exports.LogLevel = {})); | ||
@@ -16,5 +19,10 @@ var LogFormat; | ||
})(LogFormat = exports.LogFormat || (exports.LogFormat = {})); | ||
function getLogger(name, options) { | ||
function getLogger(caller, options) { | ||
const loggerOptions = options !== null && options !== void 0 ? options : defaultLoggerOptions(); | ||
return new PinoLogger(name, loggerOptions); | ||
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment | ||
const loggerName = typeof caller === 'string' || caller instanceof String | ||
? caller | ||
: // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access | ||
caller.constructor.name; | ||
return new PinoLogger(loggerName, loggerOptions); | ||
} | ||
@@ -33,2 +41,8 @@ exports.getLogger = getLogger; | ||
} | ||
error(msg) { | ||
this._logger.error(msg); | ||
} | ||
warn(msg) { | ||
this._logger.warn(msg); | ||
} | ||
info(msg) { | ||
@@ -40,2 +54,5 @@ this._logger.info(msg); | ||
} | ||
trace(msg) { | ||
this._logger.trace(msg); | ||
} | ||
} | ||
@@ -49,2 +66,4 @@ function defaultLoggerOptions() { | ||
switch (level) { | ||
case LogLevel.TRACE: | ||
return 'trace'; | ||
case LogLevel.DEBUG: | ||
@@ -54,2 +73,6 @@ return 'debug'; | ||
return 'info'; | ||
case LogLevel.WARN: | ||
return 'warn'; | ||
case LogLevel.ERROR: | ||
return 'error'; | ||
default: | ||
@@ -74,2 +97,2 @@ throw new Error(`Unsupported log level: ${String(level)}`); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9sb2dnaW5nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZCQUE2QjtBQVk3QixJQUFZLFFBR1g7QUFIRCxXQUFZLFFBQVE7SUFDbEIsMkJBQWUsQ0FBQTtJQUNmLHlCQUFhLENBQUE7QUFDZixDQUFDLEVBSFcsUUFBUSxHQUFSLGdCQUFRLEtBQVIsZ0JBQVEsUUFHbkI7QUFFRCxJQUFZLFNBR1g7QUFIRCxXQUFZLFNBQVM7SUFDbkIsZ0NBQW1CLENBQUE7SUFDbkIsMEJBQWEsQ0FBQTtBQUNmLENBQUMsRUFIVyxTQUFTLEdBQVQsaUJBQVMsS0FBVCxpQkFBUyxRQUdwQjtBQU9ELFNBQWdCLFNBQVMsQ0FBQyxJQUFZLEVBQUUsT0FBdUI7SUFDN0QsTUFBTSxhQUFhLEdBQUcsT0FBTyxhQUFQLE9BQU8sY0FBUCxPQUFPLEdBQUksb0JBQW9CLEVBQUUsQ0FBQztJQUN4RCxPQUFPLElBQUksVUFBVSxDQUFDLElBQUksRUFBRSxhQUFhLENBQUMsQ0FBQztBQUM3QyxDQUFDO0FBSEQsOEJBR0M7QUFFRCxNQUFNLFVBQVU7SUFHZCxZQUFZLElBQVksRUFBRSxPQUFzQjs7UUFDOUMsTUFBTSxTQUFTLEdBQXlCLHdCQUF3QixDQUM5RCxNQUFBLE9BQU8sQ0FBQyxLQUFLLG1DQUFJLFFBQVEsQ0FBQyxJQUFJLENBQy9CLENBQUM7UUFFRixNQUFNLFNBQVMsR0FBRywwQkFBMEIsQ0FDMUMsTUFBQSxPQUFPLENBQUMsTUFBTSxtQ0FBSSxTQUFTLENBQUMsT0FBTyxDQUNwQyxDQUFDO1FBRUYsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO1lBQ3ZCLElBQUksRUFBRSxJQUFJO1lBQ1YsS0FBSyxFQUFFLFNBQVM7WUFDaEIsU0FBUyxFQUFFLFNBQVM7U0FDckIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELElBQUksQ0FBQyxHQUFXO1FBQ2QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDekIsQ0FBQztJQUVELEtBQUssQ0FBQyxHQUFXO1FBQ2YsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDMUIsQ0FBQztDQUNGO0FBRUQsU0FBUyxvQkFBb0I7SUFDM0IsT0FBTztRQUNMLEtBQUssRUFBRSxRQUFRLENBQUMsSUFBSTtLQUNyQixDQUFDO0FBQ0osQ0FBQztBQUVELFNBQVMsd0JBQXdCLENBQUMsS0FBZTtJQUMvQyxRQUFRLEtBQUssRUFBRTtRQUNiLEtBQUssUUFBUSxDQUFDLEtBQUs7WUFDakIsT0FBTyxPQUFPLENBQUM7UUFDakIsS0FBSyxRQUFRLENBQUMsSUFBSTtZQUNoQixPQUFPLE1BQU0sQ0FBQztRQUNoQjtZQUNFLE1BQU0sSUFBSSxLQUFLLENBQUMsMEJBQTBCLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUM7S0FDOUQ7QUFDSCxDQUFDO0FBRUQsU0FBUywwQkFBMEIsQ0FDakMsTUFBaUI7SUFNakIsUUFBUSxNQUFNLEVBQUU7UUFDZCxLQUFLLFNBQVMsQ0FBQyxPQUFPO1lBQ3BCLE9BQU87Z0JBQ0wsTUFBTSxFQUFFLGFBQWE7Z0JBQ3JCLE9BQU8sRUFBRTtvQkFDUCxRQUFRLEVBQUUsSUFBSTtpQkFDZjthQUNGLENBQUM7UUFDSixLQUFLLFNBQVMsQ0FBQyxJQUFJO1lBQ2pCLE9BQU8sU0FBUyxDQUFDO1FBQ25CO1lBQ0UsTUFBTSxJQUFJLEtBQUssQ0FBQywyQkFBMkIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQztLQUNoRTtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBwaW5vIGZyb20gJ3Bpbm8nO1xuaW1wb3J0IHtcbiAgVHJhbnNwb3J0TXVsdGlPcHRpb25zLFxuICBUcmFuc3BvcnRQaXBlbGluZU9wdGlvbnMsXG4gIFRyYW5zcG9ydFNpbmdsZU9wdGlvbnMsXG59IGZyb20gJ3Bpbm8nO1xuXG5leHBvcnQgaW50ZXJmYWNlIExvZ2dlciB7XG4gIGluZm8obXNnOiBzdHJpbmcpOiB2b2lkO1xuICBkZWJ1Zyhtc2c6IHN0cmluZyk6IHZvaWQ7XG59XG5cbmV4cG9ydCBlbnVtIExvZ0xldmVsIHtcbiAgREVCVUcgPSAnZGVidWcnLFxuICBJTkZPID0gJ2luZm8nLFxufVxuXG5leHBvcnQgZW51bSBMb2dGb3JtYXQge1xuICBDT05TT0xFID0gJ2NvbnNvbGUnLFxuICBKU09OID0gJ2pzb24nLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIExvZ2dlck9wdGlvbnMge1xuICBsZXZlbD86IExvZ0xldmVsO1xuICBmb3JtYXQ/OiBMb2dGb3JtYXQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRMb2dnZXIobmFtZTogc3RyaW5nLCBvcHRpb25zPzogTG9nZ2VyT3B0aW9ucyk6IExvZ2dlciB7XG4gIGNvbnN0IGxvZ2dlck9wdGlvbnMgPSBvcHRpb25zID8/IGRlZmF1bHRMb2dnZXJPcHRpb25zKCk7XG4gIHJldHVybiBuZXcgUGlub0xvZ2dlcihuYW1lLCBsb2dnZXJPcHRpb25zKTtcbn1cblxuY2xhc3MgUGlub0xvZ2dlciBpbXBsZW1lbnRzIExvZ2dlciB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2xvZ2dlcjogcGluby5Mb2dnZXI7XG5cbiAgY29uc3RydWN0b3IobmFtZTogc3RyaW5nLCBvcHRpb25zOiBMb2dnZXJPcHRpb25zKSB7XG4gICAgY29uc3QgcGlub0xldmVsOiBwaW5vLkxldmVsV2l0aFNpbGVudCA9IHBpbm9Mb2dMZXZlbEZyb21Mb2dMZXZlbChcbiAgICAgIG9wdGlvbnMubGV2ZWwgPz8gTG9nTGV2ZWwuSU5GT1xuICAgICk7XG5cbiAgICBjb25zdCB0cmFuc3BvcnQgPSBwaW5vVHJhbnNwb3J0RnJvbUxvZ0Zvcm1hdChcbiAgICAgIG9wdGlvbnMuZm9ybWF0ID8/IExvZ0Zvcm1hdC5DT05TT0xFXG4gICAgKTtcblxuICAgIHRoaXMuX2xvZ2dlciA9IHBpbm8ucGlubyh7XG4gICAgICBuYW1lOiBuYW1lLFxuICAgICAgbGV2ZWw6IHBpbm9MZXZlbCxcbiAgICAgIHRyYW5zcG9ydDogdHJhbnNwb3J0LFxuICAgIH0pO1xuICB9XG5cbiAgaW5mbyhtc2c6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMuX2xvZ2dlci5pbmZvKG1zZyk7XG4gIH1cblxuICBkZWJ1Zyhtc2c6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMuX2xvZ2dlci5kZWJ1Zyhtc2cpO1xuICB9XG59XG5cbmZ1bmN0aW9uIGRlZmF1bHRMb2dnZXJPcHRpb25zKCk6IExvZ2dlck9wdGlvbnMge1xuICByZXR1cm4ge1xuICAgIGxldmVsOiBMb2dMZXZlbC5JTkZPLFxuICB9O1xufVxuXG5mdW5jdGlvbiBwaW5vTG9nTGV2ZWxGcm9tTG9nTGV2ZWwobGV2ZWw6IExvZ0xldmVsKTogcGluby5MZXZlbFdpdGhTaWxlbnQge1xuICBzd2l0Y2ggKGxldmVsKSB7XG4gICAgY2FzZSBMb2dMZXZlbC5ERUJVRzpcbiAgICAgIHJldHVybiAnZGVidWcnO1xuICAgIGNhc2UgTG9nTGV2ZWwuSU5GTzpcbiAgICAgIHJldHVybiAnaW5mbyc7XG4gICAgZGVmYXVsdDpcbiAgICAgIHRocm93IG5ldyBFcnJvcihgVW5zdXBwb3J0ZWQgbG9nIGxldmVsOiAke1N0cmluZyhsZXZlbCl9YCk7XG4gIH1cbn1cblxuZnVuY3Rpb24gcGlub1RyYW5zcG9ydEZyb21Mb2dGb3JtYXQoXG4gIGZvcm1hdDogTG9nRm9ybWF0XG4pOlxuICB8IHVuZGVmaW5lZFxuICB8IFRyYW5zcG9ydFNpbmdsZU9wdGlvbnNcbiAgfCBUcmFuc3BvcnRNdWx0aU9wdGlvbnNcbiAgfCBUcmFuc3BvcnRQaXBlbGluZU9wdGlvbnMge1xuICBzd2l0Y2ggKGZvcm1hdCkge1xuICAgIGNhc2UgTG9nRm9ybWF0LkNPTlNPTEU6XG4gICAgICByZXR1cm4ge1xuICAgICAgICB0YXJnZXQ6ICdwaW5vLXByZXR0eScsXG4gICAgICAgIG9wdGlvbnM6IHtcbiAgICAgICAgICBjb2xvcml6ZTogdHJ1ZSxcbiAgICAgICAgfSxcbiAgICAgIH07XG4gICAgY2FzZSBMb2dGb3JtYXQuSlNPTjpcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgZGVmYXVsdDpcbiAgICAgIHRocm93IG5ldyBFcnJvcihgVW5zdXBwb3J0ZWQgbG9nIGZvcm1hdDogJHtTdHJpbmcoZm9ybWF0KX1gKTtcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9sb2dnaW5nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZCQUE2QjtBQWU3QixJQUFZLFFBTVg7QUFORCxXQUFZLFFBQVE7SUFDbEIsMkJBQWUsQ0FBQTtJQUNmLDJCQUFlLENBQUE7SUFDZix5QkFBYSxDQUFBO0lBQ2IseUJBQWEsQ0FBQTtJQUNiLDJCQUFlLENBQUE7QUFDakIsQ0FBQyxFQU5XLFFBQVEsR0FBUixnQkFBUSxLQUFSLGdCQUFRLFFBTW5CO0FBRUQsSUFBWSxTQUdYO0FBSEQsV0FBWSxTQUFTO0lBQ25CLGdDQUFtQixDQUFBO0lBQ25CLDBCQUFhLENBQUE7QUFDZixDQUFDLEVBSFcsU0FBUyxHQUFULGlCQUFTLEtBQVQsaUJBQVMsUUFHcEI7QUFPRCxTQUFnQixTQUFTLENBQ3ZCLE1BQW9CLEVBQ3BCLE9BQXVCO0lBRXZCLE1BQU0sYUFBYSxHQUFHLE9BQU8sYUFBUCxPQUFPLGNBQVAsT0FBTyxHQUFJLG9CQUFvQixFQUFFLENBQUM7SUFDeEQsbUVBQW1FO0lBQ25FLE1BQU0sVUFBVSxHQUNkLE9BQU8sTUFBTSxLQUFLLFFBQVEsSUFBSSxNQUFNLFlBQVksTUFBTTtRQUNwRCxDQUFDLENBQUMsTUFBTTtRQUNSLENBQUMsQ0FBQyxzRUFBc0U7WUFDdEUsTUFBTSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUM7SUFDOUIsT0FBTyxJQUFJLFVBQVUsQ0FBQyxVQUFVLEVBQUUsYUFBYSxDQUFDLENBQUM7QUFDbkQsQ0FBQztBQVpELDhCQVlDO0FBRUQsTUFBTSxVQUFVO0lBR2QsWUFBWSxJQUFZLEVBQUUsT0FBc0I7O1FBQzlDLE1BQU0sU0FBUyxHQUF5Qix3QkFBd0IsQ0FDOUQsTUFBQSxPQUFPLENBQUMsS0FBSyxtQ0FBSSxRQUFRLENBQUMsSUFBSSxDQUMvQixDQUFDO1FBRUYsTUFBTSxTQUFTLEdBQUcsMEJBQTBCLENBQzFDLE1BQUEsT0FBTyxDQUFDLE1BQU0sbUNBQUksU0FBUyxDQUFDLE9BQU8sQ0FDcEMsQ0FBQztRQUVGLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQztZQUN2QixJQUFJLEVBQUUsSUFBSTtZQUNWLEtBQUssRUFBRSxTQUFTO1lBQ2hCLFNBQVMsRUFBRSxTQUFTO1NBQ3JCLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxLQUFLLENBQUMsR0FBVztRQUNmLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzFCLENBQUM7SUFFRCxJQUFJLENBQUMsR0FBVztRQUNkLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3pCLENBQUM7SUFFRCxJQUFJLENBQUMsR0FBVztRQUNkLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3pCLENBQUM7SUFFRCxLQUFLLENBQUMsR0FBVztRQUNmLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzFCLENBQUM7SUFFRCxLQUFLLENBQUMsR0FBVztRQUNmLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzFCLENBQUM7Q0FDRjtBQUVELFNBQVMsb0JBQW9CO0lBQzNCLE9BQU87UUFDTCxLQUFLLEVBQUUsUUFBUSxDQUFDLElBQUk7S0FDckIsQ0FBQztBQUNKLENBQUM7QUFFRCxTQUFTLHdCQUF3QixDQUFDLEtBQWU7SUFDL0MsUUFBUSxLQUFLLEVBQUU7UUFDYixLQUFLLFFBQVEsQ0FBQyxLQUFLO1lBQ2pCLE9BQU8sT0FBTyxDQUFDO1FBQ2pCLEtBQUssUUFBUSxDQUFDLEtBQUs7WUFDakIsT0FBTyxPQUFPLENBQUM7UUFDakIsS0FBSyxRQUFRLENBQUMsSUFBSTtZQUNoQixPQUFPLE1BQU0sQ0FBQztRQUNoQixLQUFLLFFBQVEsQ0FBQyxJQUFJO1lBQ2hCLE9BQU8sTUFBTSxDQUFDO1FBQ2hCLEtBQUssUUFBUSxDQUFDLEtBQUs7WUFDakIsT0FBTyxPQUFPLENBQUM7UUFFakI7WUFDRSxNQUFNLElBQUksS0FBSyxDQUFDLDBCQUEwQixNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0tBQzlEO0FBQ0gsQ0FBQztBQUVELFNBQVMsMEJBQTBCLENBQ2pDLE1BQWlCO0lBTWpCLFFBQVEsTUFBTSxFQUFFO1FBQ2QsS0FBSyxTQUFTLENBQUMsT0FBTztZQUNwQixPQUFPO2dCQUNMLE1BQU0sRUFBRSxhQUFhO2dCQUNyQixPQUFPLEVBQUU7b0JBQ1AsUUFBUSxFQUFFLElBQUk7aUJBQ2Y7YUFDRixDQUFDO1FBQ0osS0FBSyxTQUFTLENBQUMsSUFBSTtZQUNqQixPQUFPLFNBQVMsQ0FBQztRQUNuQjtZQUNFLE1BQU0sSUFBSSxLQUFLLENBQUMsMkJBQTJCLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLENBQUM7S0FDaEU7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgcGlubyBmcm9tICdwaW5vJztcbmltcG9ydCB7XG4gIFRyYW5zcG9ydE11bHRpT3B0aW9ucyxcbiAgVHJhbnNwb3J0UGlwZWxpbmVPcHRpb25zLFxuICBUcmFuc3BvcnRTaW5nbGVPcHRpb25zLFxufSBmcm9tICdwaW5vJztcblxuZXhwb3J0IGludGVyZmFjZSBMb2dnZXIge1xuICBlcnJvcihtc2c6IHN0cmluZyk6IHZvaWQ7XG4gIHdhcm4obXNnOiBzdHJpbmcpOiB2b2lkO1xuICBpbmZvKG1zZzogc3RyaW5nKTogdm9pZDtcbiAgZGVidWcobXNnOiBzdHJpbmcpOiB2b2lkO1xuICB0cmFjZShtc2c6IHN0cmluZyk6IHZvaWQ7XG59XG5cbmV4cG9ydCBlbnVtIExvZ0xldmVsIHtcbiAgVFJBQ0UgPSAndHJhY2UnLFxuICBERUJVRyA9ICdkZWJ1ZycsXG4gIElORk8gPSAnaW5mbycsXG4gIFdBUk4gPSAnd2FybicsXG4gIEVSUk9SID0gJ2Vycm9yJyxcbn1cblxuZXhwb3J0IGVudW0gTG9nRm9ybWF0IHtcbiAgQ09OU09MRSA9ICdjb25zb2xlJyxcbiAgSlNPTiA9ICdqc29uJyxcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMb2dnZXJPcHRpb25zIHtcbiAgbGV2ZWw/OiBMb2dMZXZlbDtcbiAgZm9ybWF0PzogTG9nRm9ybWF0O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0TG9nZ2VyKFxuICBjYWxsZXI6IHN0cmluZyB8IGFueSxcbiAgb3B0aW9ucz86IExvZ2dlck9wdGlvbnNcbik6IExvZ2dlciB7XG4gIGNvbnN0IGxvZ2dlck9wdGlvbnMgPSBvcHRpb25zID8/IGRlZmF1bHRMb2dnZXJPcHRpb25zKCk7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW5zYWZlLWFzc2lnbm1lbnRcbiAgY29uc3QgbG9nZ2VyTmFtZTogc3RyaW5nID1cbiAgICB0eXBlb2YgY2FsbGVyID09PSAnc3RyaW5nJyB8fCBjYWxsZXIgaW5zdGFuY2VvZiBTdHJpbmdcbiAgICAgID8gY2FsbGVyXG4gICAgICA6IC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW5zYWZlLW1lbWJlci1hY2Nlc3NcbiAgICAgICAgY2FsbGVyLmNvbnN0cnVjdG9yLm5hbWU7XG4gIHJldHVybiBuZXcgUGlub0xvZ2dlcihsb2dnZXJOYW1lLCBsb2dnZXJPcHRpb25zKTtcbn1cblxuY2xhc3MgUGlub0xvZ2dlciBpbXBsZW1lbnRzIExvZ2dlciB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2xvZ2dlcjogcGluby5Mb2dnZXI7XG5cbiAgY29uc3RydWN0b3IobmFtZTogc3RyaW5nLCBvcHRpb25zOiBMb2dnZXJPcHRpb25zKSB7XG4gICAgY29uc3QgcGlub0xldmVsOiBwaW5vLkxldmVsV2l0aFNpbGVudCA9IHBpbm9Mb2dMZXZlbEZyb21Mb2dMZXZlbChcbiAgICAgIG9wdGlvbnMubGV2ZWwgPz8gTG9nTGV2ZWwuSU5GT1xuICAgICk7XG5cbiAgICBjb25zdCB0cmFuc3BvcnQgPSBwaW5vVHJhbnNwb3J0RnJvbUxvZ0Zvcm1hdChcbiAgICAgIG9wdGlvbnMuZm9ybWF0ID8/IExvZ0Zvcm1hdC5DT05TT0xFXG4gICAgKTtcblxuICAgIHRoaXMuX2xvZ2dlciA9IHBpbm8ucGlubyh7XG4gICAgICBuYW1lOiBuYW1lLFxuICAgICAgbGV2ZWw6IHBpbm9MZXZlbCxcbiAgICAgIHRyYW5zcG9ydDogdHJhbnNwb3J0LFxuICAgIH0pO1xuICB9XG5cbiAgZXJyb3IobXNnOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLl9sb2dnZXIuZXJyb3IobXNnKTtcbiAgfVxuXG4gIHdhcm4obXNnOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLl9sb2dnZXIud2Fybihtc2cpO1xuICB9XG5cbiAgaW5mbyhtc2c6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMuX2xvZ2dlci5pbmZvKG1zZyk7XG4gIH1cblxuICBkZWJ1Zyhtc2c6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMuX2xvZ2dlci5kZWJ1Zyhtc2cpO1xuICB9XG5cbiAgdHJhY2UobXNnOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLl9sb2dnZXIudHJhY2UobXNnKTtcbiAgfVxufVxuXG5mdW5jdGlvbiBkZWZhdWx0TG9nZ2VyT3B0aW9ucygpOiBMb2dnZXJPcHRpb25zIHtcbiAgcmV0dXJuIHtcbiAgICBsZXZlbDogTG9nTGV2ZWwuSU5GTyxcbiAgfTtcbn1cblxuZnVuY3Rpb24gcGlub0xvZ0xldmVsRnJvbUxvZ0xldmVsKGxldmVsOiBMb2dMZXZlbCk6IHBpbm8uTGV2ZWxXaXRoU2lsZW50IHtcbiAgc3dpdGNoIChsZXZlbCkge1xuICAgIGNhc2UgTG9nTGV2ZWwuVFJBQ0U6XG4gICAgICByZXR1cm4gJ3RyYWNlJztcbiAgICBjYXNlIExvZ0xldmVsLkRFQlVHOlxuICAgICAgcmV0dXJuICdkZWJ1Zyc7XG4gICAgY2FzZSBMb2dMZXZlbC5JTkZPOlxuICAgICAgcmV0dXJuICdpbmZvJztcbiAgICBjYXNlIExvZ0xldmVsLldBUk46XG4gICAgICByZXR1cm4gJ3dhcm4nO1xuICAgIGNhc2UgTG9nTGV2ZWwuRVJST1I6XG4gICAgICByZXR1cm4gJ2Vycm9yJztcblxuICAgIGRlZmF1bHQ6XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFVuc3VwcG9ydGVkIGxvZyBsZXZlbDogJHtTdHJpbmcobGV2ZWwpfWApO1xuICB9XG59XG5cbmZ1bmN0aW9uIHBpbm9UcmFuc3BvcnRGcm9tTG9nRm9ybWF0KFxuICBmb3JtYXQ6IExvZ0Zvcm1hdFxuKTpcbiAgfCB1bmRlZmluZWRcbiAgfCBUcmFuc3BvcnRTaW5nbGVPcHRpb25zXG4gIHwgVHJhbnNwb3J0TXVsdGlPcHRpb25zXG4gIHwgVHJhbnNwb3J0UGlwZWxpbmVPcHRpb25zIHtcbiAgc3dpdGNoIChmb3JtYXQpIHtcbiAgICBjYXNlIExvZ0Zvcm1hdC5DT05TT0xFOlxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgdGFyZ2V0OiAncGluby1wcmV0dHknLFxuICAgICAgICBvcHRpb25zOiB7XG4gICAgICAgICAgY29sb3JpemU6IHRydWUsXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgIGNhc2UgTG9nRm9ybWF0LkpTT046XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIGRlZmF1bHQ6XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFVuc3VwcG9ydGVkIGxvZyBmb3JtYXQ6ICR7U3RyaW5nKGZvcm1hdCl9YCk7XG4gIH1cbn1cbiJdfQ== |
{ | ||
"name": "@gomomento/sdk", | ||
"version": "0.13.0", | ||
"version": "0.13.1", | ||
"description": "Client SDK for Momento services", | ||
@@ -16,2 +16,3 @@ "main": "dist/src/index.js", | ||
"scripts": { | ||
"prebuild": "eslint . --ext .ts", | ||
"test": "jest", | ||
@@ -18,0 +19,0 @@ "integration": "jest --config jest-integration.config.js", |
194740
1693