package.dist.src.cache-client.js Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sdk Show documentation
Show all versions of sdk Show documentation
Client SDK for Momento services
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"]}