All Downloads are FREE. Search and download functionalities are using the official Maven repository.

package.dist.src.config.configuration.js Maven / Gradle / Ivy

The newest version!
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.CacheConfiguration = void 0;
class CacheConfiguration {
    constructor(props) {
        this.loggerFactory = props.loggerFactory;
        this.retryStrategy = props.retryStrategy;
        this.transportStrategy = props.transportStrategy;
        this.middlewares = props.middlewares;
        this.throwOnErrors = props.throwOnErrors;
        this.readConcern = props.readConcern;
        this.compression = props.compression;
    }
    getLoggerFactory() {
        return this.loggerFactory;
    }
    getRetryStrategy() {
        return this.retryStrategy;
    }
    withRetryStrategy(retryStrategy) {
        return new CacheConfiguration({
            loggerFactory: this.loggerFactory,
            retryStrategy: retryStrategy,
            transportStrategy: this.transportStrategy,
            middlewares: this.middlewares,
            throwOnErrors: this.throwOnErrors,
            readConcern: this.readConcern,
            compression: this.compression,
        });
    }
    getTransportStrategy() {
        return this.transportStrategy;
    }
    withTransportStrategy(transportStrategy) {
        return new CacheConfiguration({
            loggerFactory: this.loggerFactory,
            retryStrategy: this.retryStrategy,
            transportStrategy: transportStrategy,
            middlewares: this.middlewares,
            throwOnErrors: this.throwOnErrors,
            readConcern: this.readConcern,
            compression: this.compression,
        });
    }
    withNumConnections(numConnections) {
        return this.withTransportStrategy(this.getTransportStrategy().withGrpcConfig(this.getTransportStrategy()
            .getGrpcConfig()
            .withNumClients(numConnections)));
    }
    getMiddlewares() {
        return this.middlewares;
    }
    withMiddlewares(middlewares) {
        return new CacheConfiguration({
            loggerFactory: this.loggerFactory,
            retryStrategy: this.retryStrategy,
            transportStrategy: this.transportStrategy,
            middlewares: middlewares,
            throwOnErrors: this.throwOnErrors,
            readConcern: this.readConcern,
            compression: this.compression,
        });
    }
    addMiddleware(middleware) {
        return new CacheConfiguration({
            loggerFactory: this.loggerFactory,
            retryStrategy: this.retryStrategy,
            transportStrategy: this.transportStrategy,
            middlewares: [middleware, ...this.middlewares],
            throwOnErrors: this.throwOnErrors,
            readConcern: this.readConcern,
            compression: this.compression,
        });
    }
    withClientTimeoutMillis(clientTimeout) {
        return new CacheConfiguration({
            loggerFactory: this.loggerFactory,
            retryStrategy: this.retryStrategy,
            transportStrategy: this.transportStrategy.withClientTimeoutMillis(clientTimeout),
            middlewares: this.middlewares,
            throwOnErrors: this.throwOnErrors,
            readConcern: this.readConcern,
            compression: this.compression,
        });
    }
    getThrowOnErrors() {
        return this.throwOnErrors;
    }
    withThrowOnErrors(throwOnErrors) {
        return new CacheConfiguration({
            loggerFactory: this.loggerFactory,
            retryStrategy: this.retryStrategy,
            transportStrategy: this.transportStrategy,
            middlewares: this.middlewares,
            throwOnErrors: throwOnErrors,
            readConcern: this.readConcern,
            compression: this.compression,
        });
    }
    getReadConcern() {
        return this.readConcern;
    }
    withReadConcern(readConcern) {
        return new CacheConfiguration({
            loggerFactory: this.loggerFactory,
            retryStrategy: this.retryStrategy,
            transportStrategy: this.transportStrategy,
            middlewares: this.middlewares,
            throwOnErrors: this.throwOnErrors,
            readConcern: readConcern,
            compression: this.compression,
        });
    }
    getCompressionStrategy() {
        return this.compression;
    }
    withCompressionStrategy(compressionStrategy) {
        return new CacheConfiguration({
            loggerFactory: this.loggerFactory,
            retryStrategy: this.retryStrategy,
            transportStrategy: this.transportStrategy,
            middlewares: this.middlewares,
            throwOnErrors: this.throwOnErrors,
            readConcern: this.readConcern,
            compression: compressionStrategy,
        });
    }
    hasCompressionStrategy() {
        return this.compression !== undefined;
    }
}
exports.CacheConfiguration = CacheConfiguration;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"configuration.js","sourceRoot":"","sources":["../../../src/config/configuration.ts"],"names":[],"mappings":";;;AA4JA,MAAa,kBAAkB;IAS7B,YAAY,KAAyB;QACnC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;QACzC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;QACzC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,iBAAiB,CAAC;QACjD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;QACzC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;IACvC,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,aAA4B;QAC5C,OAAO,IAAI,kBAAkB,CAAC;YAC5B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,aAAa,EAAE,aAAa;YAC5B,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,WAAW,EAAE,IAAI,CAAC,WAAW;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,oBAAoB;QAClB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAED,qBAAqB,CAAC,iBAAoC;QACxD,OAAO,IAAI,kBAAkB,CAAC;YAC5B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,iBAAiB,EAAE,iBAAiB;YACpC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,WAAW,EAAE,IAAI,CAAC,WAAW;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,kBAAkB,CAAC,cAAsB;QACvC,OAAO,IAAI,CAAC,qBAAqB,CAC/B,IAAI,CAAC,oBAAoB,EAAE,CAAC,cAAc,CACxC,IAAI,CAAC,oBAAoB,EAAE;aACxB,aAAa,EAAE;aACf,cAAc,CAAC,cAAc,CAAC,CAClC,CACF,CAAC;IACJ,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,eAAe,CAAC,WAAyB;QACvC,OAAO,IAAI,kBAAkB,CAAC;YAC5B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,WAAW,EAAE,WAAW;YACxB,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,WAAW,EAAE,IAAI,CAAC,WAAW;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,UAAsB;QAClC,OAAO,IAAI,kBAAkB,CAAC;YAC5B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,WAAW,EAAE,CAAC,UAAU,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC;YAC9C,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,WAAW,EAAE,IAAI,CAAC,WAAW;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,uBAAuB,CAAC,aAAqB;QAC3C,OAAO,IAAI,kBAAkB,CAAC;YAC5B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,iBAAiB,EACf,IAAI,CAAC,iBAAiB,CAAC,uBAAuB,CAAC,aAAa,CAAC;YAC/D,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,WAAW,EAAE,IAAI,CAAC,WAAW;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,aAAsB;QACtC,OAAO,IAAI,kBAAkB,CAAC;YAC5B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,aAAa,EAAE,aAAa;YAC5B,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,WAAW,EAAE,IAAI,CAAC,WAAW;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,eAAe,CAAC,WAAwB;QACtC,OAAO,IAAI,kBAAkB,CAAC;YAC5B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,WAAW,EAAE,WAAW;YACxB,WAAW,EAAE,IAAI,CAAC,WAAW;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB;QACpB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,uBAAuB,CACrB,mBAAwC;QAExC,OAAO,IAAI,kBAAkB,CAAC;YAC5B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,WAAW,EAAE,mBAAmB;SACjC,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB;QACpB,OAAO,IAAI,CAAC,WAAW,KAAK,SAAS,CAAC;IACxC,CAAC;CACF;AA/JD,gDA+JC","sourcesContent":["import {RetryStrategy} from './retry/retry-strategy';\nimport {Middleware} from './middleware/middleware';\nimport {MomentoLoggerFactory, TransportStrategy} from '../';\nimport {ReadConcern} from '@gomomento/sdk-core';\nimport {CompressionStrategy} from './compression/compression';\n\nexport interface ConfigurationProps {\n  /**\n   * Configures logging verbosity and format\n   */\n  loggerFactory: MomentoLoggerFactory;\n  /**\n   * Configures how and when failed requests will be retried\n   */\n  retryStrategy: RetryStrategy;\n  /**\n   * Configures low-level options for network interactions with the Momento service\n   */\n  transportStrategy: TransportStrategy;\n  /**\n   * Configures middleware functions that will wrap each request\n   */\n  middlewares: Middleware[];\n  /**\n   * Configures whether the client should return a Momento Error object or throw an exception when an error occurs.\n   */\n  throwOnErrors: boolean;\n  /**\n   * Configures the read concern for the client.\n   */\n  readConcern: ReadConcern;\n  /**\n   * Configures compression capabilities for the client.\n   */\n  compression: CompressionStrategy | undefined;\n}\n\n/**\n * Configuration options for Momento CacheClient.\n *\n * @export\n * @interface Configuration\n */\nexport interface Configuration {\n  /**\n   * @returns {MomentoLoggerFactory} the current configuration options for logging verbosity and format\n   */\n  getLoggerFactory(): MomentoLoggerFactory;\n\n  /**\n   * @returns {RetryStrategy} the current configuration options for how and when failed requests will be retried\n   */\n  getRetryStrategy(): RetryStrategy;\n\n  /**\n   * Copy constructor for overriding RetryStrategy\n   * @param {RetryStrategy} retryStrategy\n   * @returns {Configuration} a new Configuration object with the specified RetryStrategy\n   */\n  withRetryStrategy(retryStrategy: RetryStrategy): Configuration;\n\n  /**\n   * @returns {TransportStrategy} the current configuration options for wire interactions with the Momento service\n   */\n  getTransportStrategy(): TransportStrategy;\n\n  /**\n   * Copy constructor for overriding TransportStrategy\n   * @param {TransportStrategy} transportStrategy\n   * @returns {Configuration} a new Configuration object with the specified TransportStrategy\n   */\n  withTransportStrategy(transportStrategy: TransportStrategy): Configuration;\n\n  /**\n   * Shorthand copy constructor for overriding TransportStrategy.GrpcStrategy.NumClients. This will\n   * allow you to control the number of TCP connections that the client will open to the server. Usually\n   * you should stick with the default value from your pre-built configuration, but it can be valuable\n   * to increase this value in order to ensure more evenly distributed load on Momento servers.\n   *\n   * @param {number} numConnections\n   * @returns {Configuration} a new Configuration object with the updated TransportStrategy\n   */\n  withNumConnections(numConnections: number): Configuration;\n\n  /**\n   * @returns {Middleware[]} the middleware functions that will wrap each request\n   */\n  getMiddlewares(): Middleware[];\n\n  /**\n   * Copy constructor for overriding Middlewares\n   * @param {Middleware[]} middlewares\n   * @returns {Configuration} a new Configuration object with the specified Middlewares\n   */\n  withMiddlewares(middlewares: Middleware[]): Configuration;\n\n  /**\n   * Copy constructor that adds a single middleware to the existing middlewares\n   * @param {Middleware} middleware\n   * @returns {Configuration} a new Configuration object with the specified Middleware appended to the list of existing Middlewares\n   */\n  addMiddleware(middleware: Middleware): Configuration;\n\n  /**\n   * Convenience copy constructor that updates the client-side timeout setting in the TransportStrategy\n   * @param {number} clientTimeoutMillis\n   * @returns {Configuration} a new Configuration object with its TransportStrategy updated to use the specified client timeout\n   */\n  withClientTimeoutMillis(clientTimeoutMillis: number): Configuration;\n\n  /**\n   * @returns {boolean} Configures whether the client should return a Momento Error object or throw an exception when an\n   * error occurs. By default, this is set to false, and the client will return a Momento Error object on errors. Set it\n   * to true if you prefer for exceptions to be thrown.\n   */\n  getThrowOnErrors(): boolean;\n\n  /**\n   * Copy constructor for configuring whether the client should return a Momento Error object or throw an exception when an\n   * error occurs. By default, this is set to false, and the client will return a Momento Error object on errors. Set it\n   * to true if you prefer for exceptions to be thrown.\n   * @param {boolean} throwOnErrors\n   * @returns {Configuration} a new Configuration object with the specified throwOnErrors setting\n   */\n  withThrowOnErrors(throwOnErrors: boolean): Configuration;\n\n  /**\n   * @returns {ReadConcern} the current configuration option for read consistency\n   */\n  getReadConcern(): ReadConcern;\n\n  /**\n   * Copy constructor for overriding ReadConcern\n   * @param {ReadConcern} readConcern\n   * @returns {Configuration} a new Configuration object with the specified ReadConcern\n   */\n  withReadConcern(readConcern: ReadConcern): Configuration;\n\n  /**\n   * @returns {ICompression} the current configuration settings for compression\n   */\n  getCompressionStrategy(): CompressionStrategy | undefined;\n\n  /**\n   * Copy constructor for overriding compression settings\n   * @param {ICompression} compression\n   * @returns {Configuration} a new Configuration object with the specified compression settings\n   */\n  withCompressionStrategy(compression: CompressionStrategy): Configuration;\n\n  /**\n   * @returns {boolean} whether the client has a compression strategy configured.\n   */\n  hasCompressionStrategy(): boolean;\n}\n\nexport class CacheConfiguration implements Configuration {\n  private readonly loggerFactory: MomentoLoggerFactory;\n  private readonly retryStrategy: RetryStrategy;\n  private readonly transportStrategy: TransportStrategy;\n  private readonly middlewares: Middleware[];\n  private readonly throwOnErrors: boolean;\n  private readonly readConcern: ReadConcern;\n  private readonly compression: CompressionStrategy | undefined;\n\n  constructor(props: ConfigurationProps) {\n    this.loggerFactory = props.loggerFactory;\n    this.retryStrategy = props.retryStrategy;\n    this.transportStrategy = props.transportStrategy;\n    this.middlewares = props.middlewares;\n    this.throwOnErrors = props.throwOnErrors;\n    this.readConcern = props.readConcern;\n    this.compression = props.compression;\n  }\n\n  getLoggerFactory(): MomentoLoggerFactory {\n    return this.loggerFactory;\n  }\n\n  getRetryStrategy(): RetryStrategy {\n    return this.retryStrategy;\n  }\n\n  withRetryStrategy(retryStrategy: RetryStrategy): Configuration {\n    return new CacheConfiguration({\n      loggerFactory: this.loggerFactory,\n      retryStrategy: retryStrategy,\n      transportStrategy: this.transportStrategy,\n      middlewares: this.middlewares,\n      throwOnErrors: this.throwOnErrors,\n      readConcern: this.readConcern,\n      compression: this.compression,\n    });\n  }\n\n  getTransportStrategy(): TransportStrategy {\n    return this.transportStrategy;\n  }\n\n  withTransportStrategy(transportStrategy: TransportStrategy): Configuration {\n    return new CacheConfiguration({\n      loggerFactory: this.loggerFactory,\n      retryStrategy: this.retryStrategy,\n      transportStrategy: transportStrategy,\n      middlewares: this.middlewares,\n      throwOnErrors: this.throwOnErrors,\n      readConcern: this.readConcern,\n      compression: this.compression,\n    });\n  }\n\n  withNumConnections(numConnections: number): Configuration {\n    return this.withTransportStrategy(\n      this.getTransportStrategy().withGrpcConfig(\n        this.getTransportStrategy()\n          .getGrpcConfig()\n          .withNumClients(numConnections)\n      )\n    );\n  }\n\n  getMiddlewares(): Middleware[] {\n    return this.middlewares;\n  }\n\n  withMiddlewares(middlewares: Middleware[]): Configuration {\n    return new CacheConfiguration({\n      loggerFactory: this.loggerFactory,\n      retryStrategy: this.retryStrategy,\n      transportStrategy: this.transportStrategy,\n      middlewares: middlewares,\n      throwOnErrors: this.throwOnErrors,\n      readConcern: this.readConcern,\n      compression: this.compression,\n    });\n  }\n\n  addMiddleware(middleware: Middleware): Configuration {\n    return new CacheConfiguration({\n      loggerFactory: this.loggerFactory,\n      retryStrategy: this.retryStrategy,\n      transportStrategy: this.transportStrategy,\n      middlewares: [middleware, ...this.middlewares],\n      throwOnErrors: this.throwOnErrors,\n      readConcern: this.readConcern,\n      compression: this.compression,\n    });\n  }\n\n  withClientTimeoutMillis(clientTimeout: number): Configuration {\n    return new CacheConfiguration({\n      loggerFactory: this.loggerFactory,\n      retryStrategy: this.retryStrategy,\n      transportStrategy:\n        this.transportStrategy.withClientTimeoutMillis(clientTimeout),\n      middlewares: this.middlewares,\n      throwOnErrors: this.throwOnErrors,\n      readConcern: this.readConcern,\n      compression: this.compression,\n    });\n  }\n\n  getThrowOnErrors(): boolean {\n    return this.throwOnErrors;\n  }\n\n  withThrowOnErrors(throwOnErrors: boolean): Configuration {\n    return new CacheConfiguration({\n      loggerFactory: this.loggerFactory,\n      retryStrategy: this.retryStrategy,\n      transportStrategy: this.transportStrategy,\n      middlewares: this.middlewares,\n      throwOnErrors: throwOnErrors,\n      readConcern: this.readConcern,\n      compression: this.compression,\n    });\n  }\n\n  getReadConcern(): ReadConcern {\n    return this.readConcern;\n  }\n\n  withReadConcern(readConcern: ReadConcern): Configuration {\n    return new CacheConfiguration({\n      loggerFactory: this.loggerFactory,\n      retryStrategy: this.retryStrategy,\n      transportStrategy: this.transportStrategy,\n      middlewares: this.middlewares,\n      throwOnErrors: this.throwOnErrors,\n      readConcern: readConcern,\n      compression: this.compression,\n    });\n  }\n\n  getCompressionStrategy(): CompressionStrategy | undefined {\n    return this.compression;\n  }\n\n  withCompressionStrategy(\n    compressionStrategy: CompressionStrategy\n  ): Configuration {\n    return new CacheConfiguration({\n      loggerFactory: this.loggerFactory,\n      retryStrategy: this.retryStrategy,\n      transportStrategy: this.transportStrategy,\n      middlewares: this.middlewares,\n      throwOnErrors: this.throwOnErrors,\n      readConcern: this.readConcern,\n      compression: compressionStrategy,\n    });\n  }\n\n  hasCompressionStrategy(): boolean {\n    return this.compression !== undefined;\n  }\n}\n"]}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy