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

package.dist.src.batchutils.batch-functions.js Maven / Gradle / Ivy

The newest version!
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.batchDelete = exports.batchSet = exports.batchGet = exports.defaultTtlSeconds = exports.defaultMaxConcurrentRequests = void 0;
const batch_props_1 = require("./batch-props");
Object.defineProperty(exports, "defaultMaxConcurrentRequests", { enumerable: true, get: function () { return batch_props_1.defaultMaxConcurrentRequests; } });
Object.defineProperty(exports, "defaultTtlSeconds", { enumerable: true, get: function () { return batch_props_1.defaultTtlSeconds; } });
const utils_1 = require("@gomomento/sdk-core/dist/src/internal/utils");
// Note: all promises in batch request workers have a client-side timeout deadline
// because grpc request timeouts are baked into the cache client. The timeout can be
// overridden using the `withClientTimeoutMillis` function.
async function batchGet(cacheClient, cacheName, keys, options) {
    const maxConcurrentGets = (options === null || options === void 0 ? void 0 : options.maxConcurrentRequests)
        ? options.maxConcurrentRequests
        : Math.min(batch_props_1.defaultMaxConcurrentRequests, keys.length);
    const batchGetResults = (0, utils_1.range)(maxConcurrentGets).map((workerId) => getWorker(workerId, cacheClient, cacheName, keys));
    const awaitAll = await Promise.all(batchGetResults);
    const batchGetResponse = {};
    awaitAll.forEach(responses => {
        Object.assign(batchGetResponse, responses);
    });
    return batchGetResponse;
}
exports.batchGet = batchGet;
async function getWorker(workerId, cacheClient, cacheName, keys) {
    const responses = {};
    while (keys.length) {
        const cacheKey = keys.pop();
        if (cacheKey !== undefined) {
            responses[String(cacheKey)] = await cacheClient.get(cacheName, cacheKey);
        }
    }
    return Promise.resolve(responses);
}
async function batchSet(cacheClient, cacheName, items, options) {
    const maxConcurrentSets = (options === null || options === void 0 ? void 0 : options.maxConcurrentRequests)
        ? options.maxConcurrentRequests
        : Math.min(batch_props_1.defaultMaxConcurrentRequests, items.length);
    const batchSetResults = (0, utils_1.range)(maxConcurrentSets).map((workerId) => setWorker(workerId, cacheClient, cacheName, items));
    const awaitAll = await Promise.all(batchSetResults);
    const batchSetResponse = {};
    awaitAll.forEach(responses => {
        Object.assign(batchSetResponse, responses);
    });
    return batchSetResponse;
}
exports.batchSet = batchSet;
async function setWorker(workerId, cacheClient, cacheName, items) {
    const responses = {};
    while (items.length) {
        const item = items.pop();
        if (item !== undefined) {
            responses[String(item.key)] = await cacheClient.set(cacheName, item.key, item.value, { ttl: item.ttl ? item.ttl : batch_props_1.defaultTtlSeconds });
        }
    }
    return Promise.resolve(responses);
}
async function batchDelete(cacheClient, cacheName, keys, options) {
    const maxConcurrentDeletes = (options === null || options === void 0 ? void 0 : options.maxConcurrentRequests)
        ? options.maxConcurrentRequests
        : Math.min(batch_props_1.defaultMaxConcurrentRequests, keys.length);
    const batchDeleteResults = (0, utils_1.range)(maxConcurrentDeletes).map((workerId) => deleteWorker(workerId, cacheClient, cacheName, keys));
    const awaitAll = await Promise.all(batchDeleteResults);
    const batchDeleteResponse = {};
    awaitAll.forEach(responses => {
        Object.assign(batchDeleteResponse, responses);
    });
    return batchDeleteResponse;
}
exports.batchDelete = batchDelete;
async function deleteWorker(workerId, cacheClient, cacheName, keys) {
    const responses = {};
    while (keys.length) {
        const cacheKey = keys.pop();
        if (cacheKey !== undefined) {
            responses[String(cacheKey)] = await cacheClient.delete(cacheName, cacheKey);
        }
    }
    return Promise.resolve(responses);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"batch-functions.js","sourceRoot":"","sources":["../../../src/batchutils/batch-functions.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CacheDelete,\n  CacheGet,\n  CacheSet,\n  ICacheClient,\n} from '@gomomento/sdk-core';\nimport {\n  BatchDeleteOptions,\n  BatchDeleteResponse,\n  BatchGetOptions,\n  BatchGetResponse,\n  BatchSetOptions,\n  BatchSetResponse,\n  BatchSetItem,\n  defaultMaxConcurrentRequests,\n  defaultTtlSeconds,\n} from './batch-props';\nimport {range} from '@gomomento/sdk-core/dist/src/internal/utils';\n\nexport {\n  BatchDeleteOptions,\n  BatchDeleteResponse,\n  BatchGetOptions,\n  BatchGetResponse,\n  BatchSetOptions,\n  BatchSetResponse,\n  BatchSetItem,\n  defaultMaxConcurrentRequests,\n  defaultTtlSeconds,\n};\n\n// Note: all promises in batch request workers have a client-side timeout deadline\n// because grpc request timeouts are baked into the cache client. The timeout can be\n// overridden using the `withClientTimeoutMillis` function.\n\nexport async function batchGet(\n  cacheClient: ICacheClient,\n  cacheName: string,\n  keys: Array<string | Uint8Array>,\n  options?: BatchGetOptions\n): Promise<BatchGetResponse> {\n  const maxConcurrentGets = options?.maxConcurrentRequests\n    ? options.maxConcurrentRequests\n    : Math.min(defaultMaxConcurrentRequests, keys.length);\n\n  const batchGetResults = range(maxConcurrentGets).map((workerId: number) =>\n    getWorker(workerId, cacheClient, cacheName, keys)\n  );\n  const awaitAll = await Promise.all(batchGetResults);\n\n  const batchGetResponse: BatchGetResponse = {};\n  awaitAll.forEach(responses => {\n    Object.assign(batchGetResponse, responses);\n  });\n  return batchGetResponse;\n}\n\nasync function getWorker(\n  workerId: number,\n  cacheClient: ICacheClient,\n  cacheName: string,\n  keys: Array<string | Uint8Array>\n): Promise<Record<string, CacheGet.Response>> {\n  const responses: Record<string, CacheGet.Response> = {};\n  while (keys.length) {\n    const cacheKey = keys.pop();\n    if (cacheKey !== undefined) {\n      responses[String(cacheKey)] = await cacheClient.get(cacheName, cacheKey);\n    }\n  }\n  return Promise.resolve(responses);\n}\n\nexport async function batchSet(\n  cacheClient: ICacheClient,\n  cacheName: string,\n  items: Array<BatchSetItem>,\n  options?: BatchSetOptions\n): Promise<BatchSetResponse> {\n  const maxConcurrentSets = options?.maxConcurrentRequests\n    ? options.maxConcurrentRequests\n    : Math.min(defaultMaxConcurrentRequests, items.length);\n\n  const batchSetResults = range(maxConcurrentSets).map((workerId: number) =>\n    setWorker(workerId, cacheClient, cacheName, items)\n  );\n  const awaitAll = await Promise.all(batchSetResults);\n\n  const batchSetResponse: BatchSetResponse = {};\n  awaitAll.forEach(responses => {\n    Object.assign(batchSetResponse, responses);\n  });\n  return batchSetResponse;\n}\n\nasync function setWorker(\n  workerId: number,\n  cacheClient: ICacheClient,\n  cacheName: string,\n  items: Array<BatchSetItem>\n): Promise<Record<string, CacheSet.Response>> {\n  const responses: Record<string, CacheSet.Response> = {};\n  while (items.length) {\n    const item = items.pop();\n    if (item !== undefined) {\n      responses[String(item.key)] = await cacheClient.set(\n        cacheName,\n        item.key,\n        item.value,\n        {ttl: item.ttl ? item.ttl : defaultTtlSeconds}\n      );\n    }\n  }\n  return Promise.resolve(responses);\n}\n\nexport async function batchDelete(\n  cacheClient: ICacheClient,\n  cacheName: string,\n  keys: Array<string | Uint8Array>,\n  options?: BatchDeleteOptions\n): Promise<BatchDeleteResponse> {\n  const maxConcurrentDeletes = options?.maxConcurrentRequests\n    ? options.maxConcurrentRequests\n    : Math.min(defaultMaxConcurrentRequests, keys.length);\n\n  const batchDeleteResults = range(maxConcurrentDeletes).map(\n    (workerId: number) => deleteWorker(workerId, cacheClient, cacheName, keys)\n  );\n  const awaitAll = await Promise.all(batchDeleteResults);\n\n  const batchDeleteResponse: BatchDeleteResponse = {};\n  awaitAll.forEach(responses => {\n    Object.assign(batchDeleteResponse, responses);\n  });\n  return batchDeleteResponse;\n}\n\nasync function deleteWorker(\n  workerId: number,\n  cacheClient: ICacheClient,\n  cacheName: string,\n  keys: Array<string | Uint8Array>\n): Promise<Record<string, CacheDelete.Response>> {\n  const responses: Record<string, CacheDelete.Response> = {};\n  while (keys.length) {\n    const cacheKey = keys.pop();\n    if (cacheKey !== undefined) {\n      responses[String(cacheKey)] = await cacheClient.delete(\n        cacheName,\n        cacheKey\n      );\n    }\n  }\n  return Promise.resolve(responses);\n}\n"]}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy