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

package.dist.src.errors.cache-service-error-mapper.js Maven / Gradle / Ivy

The newest version!
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.CacheServiceErrorMapper = void 0;
const constants_1 = require("@grpc/grpc-js/build/src/constants");
const src_1 = require("../../src");
const errors_1 = require("@gomomento/sdk-core/dist/src/errors");
const sdk_core_1 = require("@gomomento/sdk-core");
class CacheServiceErrorMapper {
    constructor(throwOnError) {
        this.throwOnErrors = throwOnError;
    }
    returnOrThrowError(err, errorResponseFactoryFn) {
        const sdkError = normalizeSdkError(err);
        if (this.throwOnErrors) {
            throw sdkError;
        }
        else {
            return errorResponseFactoryFn(sdkError);
        }
    }
    resolveOrRejectError(opts) {
        const error = this.convertError(opts.err);
        if (this.throwOnErrors) {
            opts.rejectFn(error);
        }
        else {
            opts.resolveFn(opts.errorResponseFactoryFn(error));
        }
    }
    convertError(err) {
        var _a, _b, _c, _d, _e, _f, _g, _h, _j;
        const errParams = [
            (err === null || err === void 0 ? void 0 : err.message) || 'Unable to process request',
            err === null || err === void 0 ? void 0 : err.code,
            err === null || err === void 0 ? void 0 : err.metadata,
            err === null || err === void 0 ? void 0 : err.stack,
        ];
        switch (err === null || err === void 0 ? void 0 : err.code) {
            case constants_1.Status.PERMISSION_DENIED:
                return new src_1.PermissionError(...errParams);
            case constants_1.Status.DATA_LOSS:
            case constants_1.Status.INTERNAL:
            case constants_1.Status.ABORTED:
                return new src_1.InternalServerError(...errParams);
            case constants_1.Status.UNKNOWN:
                return new src_1.UnknownServiceError(...errParams);
            case constants_1.Status.UNAVAILABLE:
                return new src_1.ServerUnavailableError(...errParams);
            case constants_1.Status.NOT_FOUND: {
                let errCause = (_b = (_a = errParams[2]) === null || _a === void 0 ? void 0 : _a.get('err')) === null || _b === void 0 ? void 0 : _b[0];
                // TODO: Remove this once the error message is standardized on the server side
                const errorMessage = (_c = errParams[0]) === null || _c === void 0 ? void 0 : _c.toString();
                const isStoreNotFound = (errorMessage === null || errorMessage === void 0 ? void 0 : errorMessage.includes('Store with name:')) &&
                    (errorMessage === null || errorMessage === void 0 ? void 0 : errorMessage.includes("doesn't exist"));
                // If errCause is not already set to 'store_not_found', check for store_not_found error
                if (!errCause && isStoreNotFound) {
                    errCause = 'store_not_found';
                }
                switch (errCause) {
                    case 'item_not_found':
                        return new errors_1.StoreItemNotFoundError(...errParams);
                    case 'store_not_found':
                        return new errors_1.StoreNotFoundError(...errParams);
                    default:
                        return new errors_1.CacheNotFoundError(...errParams);
                }
            }
            case constants_1.Status.OUT_OF_RANGE:
            case constants_1.Status.UNIMPLEMENTED:
                return new src_1.BadRequestError(...errParams);
            case constants_1.Status.FAILED_PRECONDITION:
                return new src_1.FailedPreconditionError(...errParams);
            case constants_1.Status.INVALID_ARGUMENT:
                return new src_1.InvalidArgumentError(...errParams);
            case constants_1.Status.CANCELLED:
                return new src_1.CancelledError(...errParams);
            case constants_1.Status.DEADLINE_EXCEEDED:
                return new src_1.TimeoutError(...errParams);
            case constants_1.Status.UNAUTHENTICATED:
                return new src_1.AuthenticationError(...errParams);
            case constants_1.Status.RESOURCE_EXHAUSTED: {
                const errCause = (_f = (_e = (_d = errParams[2]) === null || _d === void 0 ? void 0 : _d.get('err')) === null || _e === void 0 ? void 0 : _e[0]) === null || _f === void 0 ? void 0 : _f.toString();
                return new src_1.LimitExceededError(...errParams, errCause);
            }
            case constants_1.Status.ALREADY_EXISTS: {
                let errCause = (_h = (_g = errParams[2]) === null || _g === void 0 ? void 0 : _g.get('err')) === null || _h === void 0 ? void 0 : _h[0];
                // TODO: Remove this once the error message is standardized on the server side
                const errorMessage = (_j = errParams[0]) === null || _j === void 0 ? void 0 : _j.toString();
                const isStoreAlreadyExists = (errorMessage === null || errorMessage === void 0 ? void 0 : errorMessage.includes('Store with name:')) &&
                    (errorMessage === null || errorMessage === void 0 ? void 0 : errorMessage.includes('already exists'));
                // If errCause is not already set to 'store_already_exists', check for store_already_exists error
                if (!errCause && isStoreAlreadyExists) {
                    errCause = 'store_already_exists';
                }
                switch (errCause) {
                    case 'store_already_exists':
                        return new sdk_core_1.StoreAlreadyExistsError(...errParams);
                    default:
                        return new sdk_core_1.CacheAlreadyExistsError(...errParams);
                }
            }
            default:
                return new src_1.UnknownError(...errParams);
        }
    }
}
exports.CacheServiceErrorMapper = CacheServiceErrorMapper;
function normalizeSdkError(error) {
    if (error instanceof src_1.SdkError) {
        return error;
    }
    return new src_1.UnknownError(error.message);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cache-service-error-mapper.js","sourceRoot":"","sources":["../../../src/errors/cache-service-error-mapper.ts"],"names":[],"mappings":"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","sourcesContent":["import {Status} from '@grpc/grpc-js/build/src/constants';\nimport {Metadata, ServiceError} from '@grpc/grpc-js';\nimport {\n  InternalServerError,\n  InvalidArgumentError,\n  PermissionError,\n  BadRequestError,\n  CancelledError,\n  TimeoutError,\n  AuthenticationError,\n  LimitExceededError,\n  SdkError,\n  UnknownServiceError,\n  ServerUnavailableError,\n  UnknownError,\n  FailedPreconditionError,\n} from '../../src';\nimport {\n  CacheNotFoundError,\n  StoreItemNotFoundError,\n  StoreNotFoundError,\n} from '@gomomento/sdk-core/dist/src/errors';\nimport {\n  ICacheServiceErrorMapper,\n  ResolveOrRejectErrorOptions,\n} from '@gomomento/sdk-core/dist/src/errors/ICacheServiceErrorMapper';\nimport {\n  CacheAlreadyExistsError,\n  StoreAlreadyExistsError,\n} from '@gomomento/sdk-core';\n\nexport class CacheServiceErrorMapper\n  implements ICacheServiceErrorMapper<ServiceError>\n{\n  private readonly throwOnErrors: boolean;\n\n  constructor(throwOnError: boolean) {\n    this.throwOnErrors = throwOnError;\n  }\n\n  returnOrThrowError<TErrorResponse>(\n    err: Error,\n    errorResponseFactoryFn: (err: SdkError) => TErrorResponse\n  ): TErrorResponse {\n    const sdkError = normalizeSdkError(err);\n    if (this.throwOnErrors) {\n      throw sdkError;\n    } else {\n      return errorResponseFactoryFn(sdkError);\n    }\n  }\n\n  resolveOrRejectError(opts: ResolveOrRejectErrorOptions<ServiceError>): void {\n    const error = this.convertError(opts.err);\n\n    if (this.throwOnErrors) {\n      opts.rejectFn(error);\n    } else {\n      opts.resolveFn(opts.errorResponseFactoryFn(error));\n    }\n  }\n\n  convertError(err: ServiceError | null): SdkError {\n    const errParams: [\n      string,\n      number | undefined,\n      Metadata | undefined,\n      string | undefined\n    ] = [\n      err?.message || 'Unable to process request',\n      err?.code,\n      err?.metadata,\n      err?.stack,\n    ];\n    switch (err?.code) {\n      case Status.PERMISSION_DENIED:\n        return new PermissionError(...errParams);\n      case Status.DATA_LOSS:\n      case Status.INTERNAL:\n      case Status.ABORTED:\n        return new InternalServerError(...errParams);\n      case Status.UNKNOWN:\n        return new UnknownServiceError(...errParams);\n      case Status.UNAVAILABLE:\n        return new ServerUnavailableError(...errParams);\n      case Status.NOT_FOUND: {\n        let errCause = errParams[2]?.get('err')?.[0];\n        // TODO: Remove this once the error message is standardized on the server side\n        const errorMessage = errParams[0]?.toString();\n        const isStoreNotFound =\n          errorMessage?.includes('Store with name:') &&\n          errorMessage?.includes(\"doesn't exist\");\n        // If errCause is not already set to 'store_not_found', check for store_not_found error\n        if (!errCause && isStoreNotFound) {\n          errCause = 'store_not_found';\n        }\n        switch (errCause) {\n          case 'item_not_found':\n            return new StoreItemNotFoundError(...errParams);\n          case 'store_not_found':\n            return new StoreNotFoundError(...errParams);\n          default:\n            return new CacheNotFoundError(...errParams);\n        }\n      }\n      case Status.OUT_OF_RANGE:\n      case Status.UNIMPLEMENTED:\n        return new BadRequestError(...errParams);\n      case Status.FAILED_PRECONDITION:\n        return new FailedPreconditionError(...errParams);\n      case Status.INVALID_ARGUMENT:\n        return new InvalidArgumentError(...errParams);\n      case Status.CANCELLED:\n        return new CancelledError(...errParams);\n      case Status.DEADLINE_EXCEEDED:\n        return new TimeoutError(...errParams);\n      case Status.UNAUTHENTICATED:\n        return new AuthenticationError(...errParams);\n      case Status.RESOURCE_EXHAUSTED: {\n        const errCause = errParams[2]?.get('err')?.[0]?.toString();\n        return new LimitExceededError(...errParams, errCause);\n      }\n      case Status.ALREADY_EXISTS: {\n        let errCause = errParams[2]?.get('err')?.[0];\n        // TODO: Remove this once the error message is standardized on the server side\n        const errorMessage = errParams[0]?.toString();\n        const isStoreAlreadyExists =\n          errorMessage?.includes('Store with name:') &&\n          errorMessage?.includes('already exists');\n        // If errCause is not already set to 'store_already_exists', check for store_already_exists error\n        if (!errCause && isStoreAlreadyExists) {\n          errCause = 'store_already_exists';\n        }\n        switch (errCause) {\n          case 'store_already_exists':\n            return new StoreAlreadyExistsError(...errParams);\n          default:\n            return new CacheAlreadyExistsError(...errParams);\n        }\n      }\n      default:\n        return new UnknownError(...errParams);\n    }\n  }\n}\n\nfunction normalizeSdkError(error: Error): SdkError {\n  if (error instanceof SdkError) {\n    return error;\n  }\n  return new UnknownError(error.message);\n}\n"]}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy