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

package.dist.src.cache-client.js Maven / Gradle / Ivy

The newest version!
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.SimpleCacheClient = exports.CacheClient = void 0;
const cache_control_client_1 = require("./internal/cache-control-client");
const cache_data_client_1 = require("./internal/cache-data-client");
const _1 = require(".");
const utils_1 = require("@gomomento/sdk-core/dist/src/internal/utils");
const AbstractCacheClient_1 = require("@gomomento/sdk-core/dist/src/internal/clients/cache/AbstractCacheClient");
const sdk_core_1 = require("@gomomento/sdk-core");
const EAGER_CONNECTION_DEFAULT_TIMEOUT_SECONDS = 30;
/**
 * Momento Cache Client.
 *
 * Features include:
 * - Get, set, and delete data
 * - Create, delete, and list caches
 * - Create, revoke, and list signing keys
 */
class CacheClient extends AbstractCacheClient_1.AbstractCacheClient {
    /**
     * Creates an instance of CacheClient.
     * @param {CacheClientProps} props configuration and credentials for creating a CacheClient.
     */
    constructor(props) {
        var _a, _b;
        (0, utils_1.validateTtlSeconds)(props.defaultTtlSeconds);
        const configuration = (_a = props.configuration) !== null && _a !== void 0 ? _a : getDefaultCacheClientConfiguration();
        const credentialProvider = (_b = props.credentialProvider) !== null && _b !== void 0 ? _b : (0, sdk_core_1.getDefaultCredentialProvider)();
        const allProps = {
            ...props,
            configuration: configuration,
            credentialProvider: credentialProvider,
        };
        let semaphore = undefined;
        const numConcurrentRequests = configuration
            .getTransportStrategy()
            .getGrpcConfig()
            .getMaxConcurrentRequests();
        if (numConcurrentRequests !== null && numConcurrentRequests !== undefined) {
            (0, utils_1.validateMaxConcurrentRequests)(numConcurrentRequests);
            semaphore = new utils_1.Semaphore(numConcurrentRequests);
        }
        const controlClient = new cache_control_client_1.CacheControlClient({
            configuration: configuration,
            credentialProvider: credentialProvider,
        });
        const numClients = configuration
            .getTransportStrategy()
            .getGrpcConfig()
            .getNumClients();
        const dataClients = (0, utils_1.range)(numClients).map((_, id) => new cache_data_client_1.CacheDataClient(allProps, String(id), semaphore));
        super(controlClient, dataClients);
        this.dataRequestConcurrencySemaphore = undefined;
        this._configuration = configuration;
        this.notYetAbstractedControlClient = controlClient;
        this.dataRequestConcurrencySemaphore = semaphore;
        this.logger = configuration.getLoggerFactory().getLogger(this);
        this.logger.debug('Creating Momento CacheClient');
        // Initialize middlewares that have init methods. These currently start
        // background tasks for logging that will execute until they are explicitly
        // stopped. This is usually handled by the client's close method, but if
        // there is ever a chance that this client constructor may fail after these
        // methods are called, it is up to you to catch the exception and call close
        // on each of these manually.
        this._configuration.getMiddlewares().forEach(m => {
            if (m.init) {
                m.init();
            }
        });
    }
    close() {
        if (this.dataRequestConcurrencySemaphore !== undefined) {
            this.dataRequestConcurrencySemaphore.purge();
        }
        this.controlClient.close();
        this.dataClients.map(dc => dc.close());
        this._configuration.getMiddlewares().forEach(m => {
            if (m.close) {
                m.close();
            }
        });
    }
    /**
     * Creates a new instance of CacheClient. If eagerConnectTimeout is present in the given props, the client will
     * eagerly create its connection to Momento. It will wait until the connection is established, or until the timout
     * runs out. It the timeout runs out, the client will be valid to use, but it may still be connecting in the background.
     * @param {EagerCacheClientProps} props configuration and credentials for creating a CacheClient.
     */
    static async create(props) {
        const client = new CacheClient(props);
        try {
            const timeout = props.eagerConnectTimeout !== undefined
                ? props.eagerConnectTimeout
                : EAGER_CONNECTION_DEFAULT_TIMEOUT_SECONDS;
            // eslint-disable-next-line @typescript-eslint/no-unsafe-call
            (0, utils_1.validateTimeout)(timeout);
            // client need to explicitly set the value as 0 to disable eager connection.
            if (props.eagerConnectTimeout !== 0) {
                await Promise.all(client.dataClients.map(dc => dc.connect(timeout)));
            }
            return client;
        }
        catch (e) {
            client.close();
            throw e;
        }
    }
    /**
     * Returns the configuration used to create the CacheClient.
     *
     * @readonly
     * @type {Configuration} - The configuration used to create the CacheClient.
     * @memberof CacheClient
     */
    get configuration() {
        return this._configuration;
    }
    /**
     * Flushes / clears all the items of the given cache
     *
     * @param {string} cacheName - The cache to be flushed.
     * @returns {Promise} -
     * {@link CacheFlush.Success} on success.
     * {@link CacheFlush.Error} on failure.
     */
    async flushCache(cacheName) {
        return await this.notYetAbstractedControlClient.flushCache(cacheName);
    }
}
exports.CacheClient = CacheClient;
function getDefaultCacheClientConfiguration() {
    const config = _1.Configurations.Laptop.latest();
    const logger = config.getLoggerFactory().getLogger('CacheClient');
    logger.info('No configuration provided to CacheClient. Using default "Laptop" configuration, suitable for development. For production use, consider specifying an explicit configuration.');
    return config;
}
/**
 * @deprecated use {CacheClient} instead
 */
class SimpleCacheClient extends CacheClient {
}
exports.SimpleCacheClient = SimpleCacheClient;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cache-client.js","sourceRoot":"","sources":["../../src/cache-client.ts"],"names":[],"mappings":"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","sourcesContent":["import {CacheControlClient} from './internal/cache-control-client';\nimport {CacheDataClient} from './internal/cache-data-client';\nimport {CacheFlush, MomentoLogger, Configuration, Configurations} from '.';\nimport {CacheClientProps, EagerCacheClientProps} from './cache-client-props';\nimport {\n  range,\n  Semaphore,\n  validateMaxConcurrentRequests,\n  validateTimeout,\n  validateTtlSeconds,\n} from '@gomomento/sdk-core/dist/src/internal/utils';\nimport {ICacheClient} from '@gomomento/sdk-core/dist/src/clients/ICacheClient';\nimport {AbstractCacheClient} from '@gomomento/sdk-core/dist/src/internal/clients/cache/AbstractCacheClient';\nimport {CacheClientAllProps} from './internal/cache-client-all-props';\nimport {getDefaultCredentialProvider} from '@gomomento/sdk-core';\n\nconst EAGER_CONNECTION_DEFAULT_TIMEOUT_SECONDS = 30;\n\n/**\n * Momento 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 */\nexport class CacheClient extends AbstractCacheClient implements ICacheClient {\n  private readonly logger: MomentoLogger;\n  private readonly notYetAbstractedControlClient: CacheControlClient;\n  private readonly _configuration: Configuration;\n  private dataRequestConcurrencySemaphore: Semaphore | undefined = undefined;\n\n  /**\n   * Creates an instance of CacheClient.\n   * @param {CacheClientProps} props configuration and credentials for creating a CacheClient.\n   */\n  constructor(props: CacheClientProps) {\n    validateTtlSeconds(props.defaultTtlSeconds);\n    const configuration: Configuration =\n      props.configuration ?? getDefaultCacheClientConfiguration();\n    const credentialProvider =\n      props.credentialProvider ?? getDefaultCredentialProvider();\n\n    const allProps: CacheClientAllProps = {\n      ...props,\n      configuration: configuration,\n      credentialProvider: credentialProvider,\n    };\n\n    let semaphore: Semaphore | undefined = undefined;\n    const numConcurrentRequests = configuration\n      .getTransportStrategy()\n      .getGrpcConfig()\n      .getMaxConcurrentRequests();\n    if (numConcurrentRequests !== null && numConcurrentRequests !== undefined) {\n      validateMaxConcurrentRequests(numConcurrentRequests);\n      semaphore = new Semaphore(numConcurrentRequests);\n    }\n\n    const controlClient = new CacheControlClient({\n      configuration: configuration,\n      credentialProvider: credentialProvider,\n    });\n\n    const numClients = configuration\n      .getTransportStrategy()\n      .getGrpcConfig()\n      .getNumClients();\n    const dataClients = range(numClients).map(\n      (_, id) => new CacheDataClient(allProps, String(id), semaphore)\n    );\n    super(controlClient, dataClients);\n    this._configuration = configuration;\n    this.notYetAbstractedControlClient = controlClient;\n    this.dataRequestConcurrencySemaphore = semaphore;\n\n    this.logger = configuration.getLoggerFactory().getLogger(this);\n    this.logger.debug('Creating Momento CacheClient');\n\n    // Initialize middlewares that have init methods. These currently start\n    // background tasks for logging that will execute until they are explicitly\n    // stopped. This is usually handled by the client's close method, but if\n    // there is ever a chance that this client constructor may fail after these\n    // methods are called, it is up to you to catch the exception and call close\n    // on each of these manually.\n    this._configuration.getMiddlewares().forEach(m => {\n      if (m.init) {\n        m.init();\n      }\n    });\n  }\n\n  public close() {\n    if (this.dataRequestConcurrencySemaphore !== undefined) {\n      this.dataRequestConcurrencySemaphore.purge();\n    }\n    this.controlClient.close();\n    this.dataClients.map(dc => dc.close());\n    this._configuration.getMiddlewares().forEach(m => {\n      if (m.close) {\n        m.close();\n      }\n    });\n  }\n\n  /**\n   * Creates a new instance of CacheClient. If eagerConnectTimeout is present in the given props, the client will\n   * eagerly create its connection to Momento. It will wait until the connection is established, or until the timout\n   * runs out. It the timeout runs out, the client will be valid to use, but it may still be connecting in the background.\n   * @param {EagerCacheClientProps} props configuration and credentials for creating a CacheClient.\n   */\n  static async create(props: EagerCacheClientProps): Promise<CacheClient> {\n    const client = new CacheClient(props);\n    try {\n      const timeout =\n        props.eagerConnectTimeout !== undefined\n          ? props.eagerConnectTimeout\n          : EAGER_CONNECTION_DEFAULT_TIMEOUT_SECONDS;\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n      validateTimeout(timeout);\n      // client need to explicitly set the value as 0 to disable eager connection.\n      if (props.eagerConnectTimeout !== 0) {\n        await Promise.all(\n          client.dataClients.map(dc => (dc as CacheDataClient).connect(timeout))\n        );\n      }\n      return client;\n    } catch (e) {\n      client.close();\n      throw e;\n    }\n  }\n\n  /**\n   * Returns the configuration used to create the CacheClient.\n   *\n   * @readonly\n   * @type {Configuration} - The configuration used to create the CacheClient.\n   * @memberof CacheClient\n   */\n  public get configuration(): Configuration {\n    return this._configuration;\n  }\n\n  /**\n   * Flushes / clears all the items of the given cache\n   *\n   * @param {string} cacheName - The cache to be flushed.\n   * @returns {Promise<CacheFlush.Response>} -\n   * {@link CacheFlush.Success} on success.\n   * {@link CacheFlush.Error} on failure.\n   */\n  public override async flushCache(\n    cacheName: string\n  ): Promise<CacheFlush.Response> {\n    return await this.notYetAbstractedControlClient.flushCache(cacheName);\n  }\n}\n\nfunction getDefaultCacheClientConfiguration(): Configuration {\n  const config = Configurations.Laptop.latest();\n  const logger = config.getLoggerFactory().getLogger('CacheClient');\n  logger.info(\n    'No configuration provided to CacheClient. Using default \"Laptop\" configuration, suitable for development. For production use, consider specifying an explicit configuration.'\n  );\n  return config;\n}\n\n/**\n * @deprecated use {CacheClient} instead\n */\nexport class SimpleCacheClient extends CacheClient {}\n"]}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy