@lokalise/node-core 12.5.0 → 13.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +985 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +404 -0
- package/dist/index.d.ts +404 -29
- package/dist/index.js +893 -77
- package/dist/index.js.map +1 -1
- package/package.json +13 -7
- package/dist/src/common/commonTypes.d.ts +0 -1
- package/dist/src/common/commonTypes.js +0 -3
- package/dist/src/common/commonTypes.js.map +0 -1
- package/dist/src/common/may-omit.d.ts +0 -1
- package/dist/src/common/may-omit.js +0 -3
- package/dist/src/common/may-omit.js.map +0 -1
- package/dist/src/config/ConfigScope.d.ts +0 -34
- package/dist/src/config/ConfigScope.js +0 -173
- package/dist/src/config/ConfigScope.js.map +0 -1
- package/dist/src/config/configTransformers.d.ts +0 -2
- package/dist/src/config/configTransformers.js +0 -15
- package/dist/src/config/configTransformers.js.map +0 -1
- package/dist/src/config/configTypes.d.ts +0 -30
- package/dist/src/config/configTypes.js +0 -3
- package/dist/src/config/configTypes.js.map +0 -1
- package/dist/src/config/configValidators.d.ts +0 -2
- package/dist/src/config/configValidators.js +0 -10
- package/dist/src/config/configValidators.js.map +0 -1
- package/dist/src/errors/InternalError.d.ts +0 -16
- package/dist/src/errors/InternalError.js +0 -29
- package/dist/src/errors/InternalError.js.map +0 -1
- package/dist/src/errors/PublicNonRecoverableError.d.ts +0 -21
- package/dist/src/errors/PublicNonRecoverableError.js +0 -34
- package/dist/src/errors/PublicNonRecoverableError.js.map +0 -1
- package/dist/src/errors/either.d.ts +0 -28
- package/dist/src/errors/either.js +0 -16
- package/dist/src/errors/either.js.map +0 -1
- package/dist/src/errors/errorReporterTypes.d.ts +0 -14
- package/dist/src/errors/errorReporterTypes.js +0 -3
- package/dist/src/errors/errorReporterTypes.js.map +0 -1
- package/dist/src/errors/errorTypeGuards.d.ts +0 -2
- package/dist/src/errors/errorTypeGuards.js +0 -8
- package/dist/src/errors/errorTypeGuards.js.map +0 -1
- package/dist/src/errors/globalErrorHandler.d.ts +0 -13
- package/dist/src/errors/globalErrorHandler.js +0 -77
- package/dist/src/errors/globalErrorHandler.js.map +0 -1
- package/dist/src/errors/publicErrors.d.ts +0 -27
- package/dist/src/errors/publicErrors.js +0 -66
- package/dist/src/errors/publicErrors.js.map +0 -1
- package/dist/src/errors/types.d.ts +0 -1
- package/dist/src/errors/types.js +0 -3
- package/dist/src/errors/types.js.map +0 -1
- package/dist/src/logging/commonLogger.d.ts +0 -17
- package/dist/src/logging/commonLogger.js +0 -3
- package/dist/src/logging/commonLogger.js.map +0 -1
- package/dist/src/logging/loggerConfigResolver.d.ts +0 -15
- package/dist/src/logging/loggerConfigResolver.js +0 -70
- package/dist/src/logging/loggerConfigResolver.js.map +0 -1
- package/dist/src/observability/MultiTransactionObservabilityManager.d.ts +0 -12
- package/dist/src/observability/MultiTransactionObservabilityManager.js +0 -30
- package/dist/src/observability/MultiTransactionObservabilityManager.js.map +0 -1
- package/dist/src/observability/observabilityTypes.d.ts +0 -23
- package/dist/src/observability/observabilityTypes.js +0 -3
- package/dist/src/observability/observabilityTypes.js.map +0 -1
- package/dist/src/utils/arrayUtils.d.ts +0 -14
- package/dist/src/utils/arrayUtils.js +0 -47
- package/dist/src/utils/arrayUtils.js.map +0 -1
- package/dist/src/utils/checksumUtils.d.ts +0 -5
- package/dist/src/utils/checksumUtils.js +0 -37
- package/dist/src/utils/checksumUtils.js.map +0 -1
- package/dist/src/utils/encryptionUtility.d.ts +0 -20
- package/dist/src/utils/encryptionUtility.js +0 -58
- package/dist/src/utils/encryptionUtility.js.map +0 -1
- package/dist/src/utils/hashUtils.d.ts +0 -9
- package/dist/src/utils/hashUtils.js +0 -19
- package/dist/src/utils/hashUtils.js.map +0 -1
- package/dist/src/utils/objectUtils.d.ts +0 -55
- package/dist/src/utils/objectUtils.js +0 -195
- package/dist/src/utils/objectUtils.js.map +0 -1
- package/dist/src/utils/streamUtils.d.ts +0 -37
- package/dist/src/utils/streamUtils.js +0 -85
- package/dist/src/utils/streamUtils.js.map +0 -1
- package/dist/src/utils/typeUtils.d.ts +0 -10
- package/dist/src/utils/typeUtils.js +0 -19
- package/dist/src/utils/typeUtils.js.map +0 -1
- package/dist/src/utils/waitUtils.d.ts +0 -1
- package/dist/src/utils/waitUtils.js +0 -34
- package/dist/src/utils/waitUtils.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/utils/typeUtils.ts","../src/errors/PublicNonRecoverableError.ts","../src/errors/InternalError.ts","../src/errors/errorTypeGuards.ts","../src/config/ConfigScope.ts","../src/config/configTransformers.ts","../src/config/configValidators.ts","../src/errors/either.ts","../src/utils/encryptionUtility.ts","../src/utils/arrayUtils.ts","../src/utils/objectUtils.ts","../src/utils/hashUtils.ts","../src/logging/loggerConfigResolver.ts","../src/errors/globalErrorHandler.ts","../src/errors/publicErrors.ts","../src/utils/waitUtils.ts","../src/observability/MultiTransactionObservabilityManager.ts","../src/utils/checksumUtils.ts","../src/utils/streamUtils.ts"],"sourcesContent":["export type { ErrorDetails } from './errors/types'\n\nexport {\n PublicNonRecoverableError,\n isPublicNonRecoverableError,\n type PublicNonRecoverableErrorParams,\n} from './errors/PublicNonRecoverableError'\n\nexport {\n InternalError,\n isInternalError,\n type InternalErrorParams,\n} from './errors/InternalError'\nexport { isEntityGoneError } from './errors/errorTypeGuards'\n\nexport { ConfigScope } from './config/ConfigScope'\nexport { ensureClosingSlashTransformer } from './config/configTransformers'\nexport { createRangeValidator } from './config/configValidators'\nexport {\n type EnvValueValidator,\n type EnvValueTransformer,\n type AppConfig,\n type RedisConfig,\n} from './config/configTypes'\n\nexport {\n type Either,\n type DefiniteEither,\n success,\n failure,\n isSuccess,\n isFailure,\n} from './errors/either'\n\nexport { EncryptionUtility } from './utils/encryptionUtility'\n\nexport {\n chunk,\n callChunked,\n removeFalsy,\n removeNullish,\n removeDuplicates,\n} from './utils/arrayUtils'\nexport {\n groupBy,\n groupByPath,\n groupByUnique,\n pick,\n pickWithoutUndefined,\n copyWithoutUndefined,\n copyWithoutEmpty,\n isEmptyObject,\n convertDateFieldsToIsoString,\n deepClone,\n} from './utils/objectUtils'\n\nexport {\n isError,\n isStandardizedError,\n isObject,\n hasMessage,\n} from './utils/typeUtils'\nexport { type StandardizedError } from './utils/typeUtils'\n\nexport { generateHash, HashAlgorithm, HashEncoding } from './utils/hashUtils'\n\nexport {\n resolveLoggerConfiguration,\n resolveMonorepoLoggerConfiguration,\n resolveLogger,\n resolveMonorepoLogger,\n} from './logging/loggerConfigResolver'\nexport type { AppLoggerConfig, MonorepoAppLoggerConfig } from './logging/loggerConfigResolver'\nexport type { CommonLogger } from './logging/commonLogger'\n\nexport {\n type ErrorReport,\n type ErrorReporter,\n type ErrorResolver,\n} from './errors/errorReporterTypes'\nexport {\n executeAsyncAndHandleGlobalErrors,\n executeAndHandleGlobalErrors,\n executeSettleAllAndHandleGlobalErrors,\n globalLogger,\n resolveGlobalErrorLogObject,\n} from './errors/globalErrorHandler'\n\nexport { type MayOmit } from './common/may-omit'\nexport { type FreeformRecord } from './common/commonTypes'\nexport {\n type ValidationError,\n type CommonErrorParams,\n type OptionalMessageErrorParams,\n RequestValidationError,\n AccessDeniedError,\n EntityNotFoundError,\n EntityGoneError,\n AuthFailedError,\n} from './errors/publicErrors'\n\nexport { waitAndRetry } from './utils/waitUtils'\n\nexport type { TransactionObservabilityManager } from './observability/observabilityTypes'\nexport { MultiTransactionObservabilityManager } from './observability/MultiTransactionObservabilityManager'\n\nexport {\n generateChecksumForReadable,\n generateChecksumForObject,\n generateChecksumForBufferOrString,\n} from './utils/checksumUtils'\nexport { FsReadableProvider } from './utils/streamUtils'\nexport type {\n PersistToFsOptions,\n ReadableProvider,\n FsReadableProviderOptions,\n} from './utils/streamUtils'\n","// Error structure commonly used in libraries, e. g. fastify\nexport type StandardizedError = {\n code: string\n message: string\n}\n\nexport function hasMessage(maybe: unknown): maybe is { message: string } {\n return isObject(maybe) && typeof maybe.message === 'string'\n}\n\nexport function isObject(maybeObject: unknown): maybeObject is Record<PropertyKey, unknown> {\n return typeof maybeObject === 'object' && maybeObject !== null\n}\n\nexport function isStandardizedError(error: unknown): error is StandardizedError {\n return isObject(error) && typeof error.code === 'string' && typeof error.message === 'string'\n}\n\nexport function isError(maybeError: unknown): maybeError is Error {\n return (\n maybeError instanceof Error || Object.prototype.toString.call(maybeError) === '[object Error]'\n )\n}\n","import { isError } from '../utils/typeUtils'\nimport type { ErrorDetails } from './types'\n\nexport type PublicNonRecoverableErrorParams<T = ErrorDetails> = {\n message: string\n errorCode: string\n details?: T\n httpStatusCode?: number\n cause?: unknown\n}\n\nconst PUBLIC_NON_RECOVERABLE_ERROR_SYMBOL_KEY = 'PUBLIC_NON_RECOVERABLE_ERROR_KEY'\nconst publicNonRecoverableErrorSymbol = Symbol.for(PUBLIC_NON_RECOVERABLE_ERROR_SYMBOL_KEY)\n\n/**\n * This error is returned to the consumer of API\n */\nexport class PublicNonRecoverableError<T = ErrorDetails> extends Error {\n readonly [publicNonRecoverableErrorSymbol] = true\n public readonly details?: T\n public readonly errorCode: string\n public readonly httpStatusCode: number\n\n constructor(params: PublicNonRecoverableErrorParams<T>) {\n super(params.message, {\n cause: params.cause,\n })\n // set the name as the class name for every class that extends PublicNonRecoverableError\n this.name = this.constructor.name\n this.details = params.details\n this.errorCode = params.errorCode\n this.httpStatusCode = params.httpStatusCode ?? 500\n }\n}\n\nexport function isPublicNonRecoverableError(error: unknown): error is PublicNonRecoverableError {\n return (\n isError(error) &&\n // biome-ignore lint/suspicious/noExplicitAny: checking for existence of prop outside or Error interface\n ((error as any)[Symbol.for(PUBLIC_NON_RECOVERABLE_ERROR_SYMBOL_KEY)] === true ||\n error.name === 'PublicNonRecoverableError')\n )\n}\n","import { isError } from '../utils/typeUtils'\nimport type { ErrorDetails } from './types'\n\nexport type InternalErrorParams<T = ErrorDetails> = {\n message: string\n errorCode: string\n details?: T\n cause?: unknown\n}\n\nconst INTERNAL_ERROR_SYMBOL_KEY = 'INTERNAL_ERROR_KEY'\nconst internalErrorSymbol = Symbol.for(INTERNAL_ERROR_SYMBOL_KEY)\n\nexport class InternalError<T = ErrorDetails> extends Error {\n readonly [internalErrorSymbol] = true\n public readonly details?: T\n public readonly errorCode: string\n\n constructor(params: InternalErrorParams<T>) {\n super(params.message, {\n cause: params.cause,\n })\n // set the name as the class name for every class that extends InternalError\n this.name = this.constructor.name\n this.details = params.details\n this.errorCode = params.errorCode\n }\n}\n\nexport function isInternalError(error: unknown): error is InternalError {\n return (\n isError(error) &&\n // biome-ignore lint/suspicious/noExplicitAny: checking for existence of prop outside or Error interface\n ((error as any)[Symbol.for(INTERNAL_ERROR_SYMBOL_KEY)] === true ||\n error.name === 'InternalError')\n )\n}\n","import { isPublicNonRecoverableError } from '../errors/PublicNonRecoverableError'\n\nimport type { EntityGoneError } from './publicErrors'\n\nexport function isEntityGoneError(entity: unknown): entity is EntityGoneError {\n return isPublicNonRecoverableError(entity) && entity.httpStatusCode === 410\n}\n","import type { ZodSchema } from 'zod'\n\nimport { InternalError } from '../errors/InternalError'\n\nimport type { EnvValueValidator } from './configTypes'\n\nexport type EnvType = {\n [key: string]: string | undefined\n}\n\nexport class ConfigScope {\n private env: EnvType\n\n constructor(envOverride?: EnvType) {\n this.env = envOverride ?? { ...process.env }\n }\n\n updateEnv() {\n // Accessing process.env values is slow, so we cache them\n this.env = { ...process.env }\n }\n\n getMandatoryInteger(param: string): number {\n const rawValue = this.env[param]\n if (!rawValue) {\n throw new InternalError({\n message: `Missing mandatory configuration parameter: ${param}`,\n errorCode: 'CONFIGURATION_ERROR',\n })\n }\n return validateNumber(\n Number.parseInt(rawValue),\n `Configuration parameter ${param}\\` must be a number, but was ${rawValue}`,\n )\n }\n\n getMandatory(param: string): string {\n const result = this.env[param]\n if (!result) {\n throw new InternalError({\n message: `Missing mandatory configuration parameter: ${param}`,\n errorCode: 'CONFIGURATION_ERROR',\n })\n }\n return result\n }\n\n getMandatoryOneOf<const T>(param: string, supportedValues: T[]): T {\n const result = this.getMandatory(param)\n return validateOneOf(\n result,\n supportedValues,\n `Unsupported ${param}: ${result}. Supported values: ${supportedValues.toString()}`,\n )\n }\n\n getMandatoryValidatedInteger(param: string, validator: EnvValueValidator<number>): number {\n const value = this.getMandatoryInteger(param)\n if (!validator(value)) {\n throw new InternalError({\n message: `Value ${value} is invalid for parameter ${param}`,\n errorCode: 'CONFIGURATION_ERROR',\n })\n }\n return value\n }\n\n getOptionalNullable<T extends string | null | undefined>(\n param: string,\n defaultValue: T,\n ): T | string {\n return this.env[param] || defaultValue\n }\n\n getOptional(param: string, defaultValue: string): string {\n // Using the `||` operator instead of `??`, since '' is not a valid value, and 0 (number) is not expected here\n return this.env[param] || defaultValue\n }\n\n getOptionalInteger(param: string, defaultValue: number): number {\n const rawValue = this.env[param]\n if (!rawValue) {\n return defaultValue\n }\n return validateNumber(\n Number.parseInt(rawValue),\n `Configuration parameter ${param}\\` must be a number, but was ${rawValue}`,\n )\n }\n\n getOptionalNullableInteger<T extends number | null | undefined>(\n param: string,\n defaultValue: T,\n ): T | number {\n const rawValue = this.env[param]\n if (!rawValue) {\n return defaultValue\n }\n return validateNumber(\n Number.parseInt(rawValue),\n `Configuration parameter ${param}\\` must be a number, but was ${rawValue}`,\n )\n }\n\n getOptionalOneOf<const T extends string>(\n param: string,\n defaultValue: T,\n supportedValues: T[],\n ): T {\n const result = this.getOptional(param, defaultValue)\n return validateOneOf(\n result,\n supportedValues,\n `Unsupported ${param}: ${result}. Supported values: ${supportedValues.toString()}`,\n )\n }\n\n getOptionalValidated(\n param: string,\n defaultValue: string,\n validator: EnvValueValidator<string>,\n ): string {\n const value = this.env[param] || defaultValue\n if (!validator(value)) {\n throw new InternalError({\n message: `Value ${value} is invalid for parameter ${param}`,\n errorCode: 'CONFIGURATION_ERROR',\n })\n }\n return value\n }\n\n getOptionalValidatedInteger(\n param: string,\n defaultValue: number,\n validator: EnvValueValidator<number>,\n ): number {\n const value = this.getOptionalInteger(param, defaultValue)\n\n if (!validator(value)) {\n throw new InternalError({\n message: `Value ${value} is invalid for parameter ${param}`,\n errorCode: 'CONFIGURATION_ERROR',\n })\n }\n\n return value\n }\n\n getOptionalTransformed(\n param: string,\n defaultValue: string,\n transformer: (value: string) => string,\n ): string {\n const value = this.env[param] || defaultValue\n return transformer(value)\n }\n\n getOptionalNullableTransformed<T extends string | undefined>(\n param: string,\n defaultValue: T,\n transformer: (value: T | string) => T | string,\n ): T | string {\n const value = this.env[param] || defaultValue\n return transformer(value as T)\n }\n\n getMandatoryTransformed(param: string, transformer: (value: string) => string) {\n const value = this.getMandatory(param)\n\n return transformer(value)\n }\n\n getOptionalBoolean(param: string, defaultValue: boolean): boolean {\n const rawValue = this.env[param]?.toLowerCase()\n if (rawValue === undefined || rawValue === '') {\n return defaultValue\n }\n\n validateOneOf(rawValue, ['true', 'false'])\n\n return rawValue === 'true'\n }\n\n getMandatoryJsonObject<T extends object>(param: string, schema: ZodSchema<T>): T {\n const rawValue = this.getMandatory(param)\n return this.validateSchema(\n JSON.parse(rawValue),\n schema,\n `Configuration parameter ${param} must be a valid JSON meeting the given schema, but was ${rawValue}`,\n )\n }\n\n getOptionalNullableJsonObject<T extends object, Z extends T | null | undefined>(\n param: string,\n schema: ZodSchema<T>,\n defaultValue: Z,\n ): Z {\n const rawValue = this.getOptionalNullable(param, undefined)\n if (!rawValue) {\n return defaultValue\n }\n\n return this.validateSchema(\n JSON.parse(rawValue),\n schema,\n `Configuration parameter ${param} must be a valid JSON meeting the given schema, but was ${rawValue}`,\n ) as Z\n }\n\n getOptionalJsonObject<T extends object>(param: string, schema: ZodSchema<T>, defaultValue: T): T {\n return this.getOptionalNullableJsonObject(param, schema, defaultValue)\n }\n\n isProduction(): boolean {\n return this.env.NODE_ENV === 'production'\n }\n\n isDevelopment(): boolean {\n return this.env.NODE_ENV !== 'production'\n }\n\n isTest(): boolean {\n return this.env.NODE_ENV === 'test'\n }\n\n private validateSchema<T extends object>(\n value: unknown,\n schema: ZodSchema<T>,\n errorMessage: string,\n ): T {\n const parsedValue = schema.safeParse(value)\n if (!parsedValue.success) {\n throw new InternalError({\n message: errorMessage,\n errorCode: 'CONFIGURATION_ERROR',\n details: parsedValue.error,\n })\n }\n\n return parsedValue.data\n }\n}\n\nexport function validateOneOf<const T>(\n validatedEntity: unknown,\n expectedOneOfEntities: T[],\n errorText?: string,\n): T {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-argument\n if (!expectedOneOfEntities.includes(validatedEntity as T)) {\n throw new InternalError({\n message:\n errorText ||\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n `Validated entity ${validatedEntity} is not one of: ${expectedOneOfEntities.toString()}`,\n errorCode: 'CONFIGURATION_ERROR',\n })\n }\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return validatedEntity as T\n}\n\nexport function validateNumber(validatedObject: unknown, errorText: string): number {\n if (!Number.isFinite(validatedObject)) {\n throw new InternalError({\n message: errorText,\n errorCode: 'CONFIGURATION_ERROR',\n })\n }\n return validatedObject as number\n}\n","import type { EnvValueTransformer } from './configTypes'\n\nexport const ensureClosingSlashTransformer: EnvValueTransformer<\n string | undefined | null,\n string\n> = (value) => {\n if (!value) {\n return ''\n }\n\n const lastChar = value.at(-1)\n if (lastChar !== '/') {\n return `${value}/`\n }\n return value\n}\n","import type { EnvValueValidator } from './configTypes'\n\nexport const createRangeValidator = (\n greaterOrEqualThan: number,\n lessOrEqualThan: number,\n): EnvValueValidator<number> => {\n return (value) => {\n return value >= greaterOrEqualThan && value <= lessOrEqualThan\n }\n}\n","type Left<T> = {\n error: T\n result?: never\n}\n\ntype Right<U> = {\n error?: never\n result: U\n}\n\n/**\n * Either is a functional programming type which is used to communicate errors happening in potentially recoverable scenarios.\n * It can return either an error (Left side) or a resolved result (Right side), but not both.\n * It is up to caller of the function to handle received error or throw (Public)NonRecoverableError if it cannot.\n *\n * @see {@link https://antman-does-software.com/stop-catching-errors-in-typescript-use-the-either-type-to-make-your-code-predictable Further reading on motivation for Either type}\n */\nexport type Either<T, U> = NonNullable<Left<T> | Right<U>>\n\n/***\n * Variation of Either, which may or may not have Error set, but always has Result\n */\nexport type DefiniteEither<T, U> = {\n error?: T\n result: U\n}\n\nexport const isFailure = <T, U>(e: Either<T, U>): e is Left<T> => {\n return e.error !== undefined\n}\n\nexport const isSuccess = <T, U>(e: Either<T, U>): e is Right<U> => {\n return e.result !== undefined\n}\n\nexport const failure = <T>(error: T): Left<T> => ({ error })\n\nexport const success = <U>(result: U): Right<U> => ({ result })\n","import * as crypto from 'node:crypto'\n\nconst algorithm = 'aes-256-gcm'\nconst ivLength = 16\nconst tagLength = 16\nconst defaultEncoding = 'hex'\nconst defaultSaltLength = 64\nconst defaultPbkdf2Iterations = 100000\n\nexport type Options = {\n saltLength?: number\n pbkdf2Iterations?: number\n encoding?: NodeJS.BufferEncoding\n}\n\n/**\n * Type-scripted version of https://github.com/MauriceButler/cryptr\n */\nexport class EncryptionUtility {\n private readonly secret: string\n private readonly saltLength: number\n private readonly encryptedPosition: number\n private readonly tagPosition: number\n private readonly pbkdf2Iterations: number\n private readonly encoding: NodeJS.BufferEncoding\n\n constructor(secret: string, options?: Options) {\n this.secret = secret\n\n this.encoding = options?.encoding ?? defaultEncoding\n this.pbkdf2Iterations = options?.pbkdf2Iterations ?? defaultPbkdf2Iterations\n this.saltLength = options?.saltLength ?? defaultSaltLength\n\n this.tagPosition = this.saltLength + ivLength\n this.encryptedPosition = this.tagPosition + tagLength\n }\n\n private getKey(salt: Buffer) {\n return crypto.pbkdf2Sync(this.secret, salt, this.pbkdf2Iterations, 32, 'sha512')\n }\n\n public encrypt(value: string) {\n const iv = crypto.randomBytes(ivLength)\n const salt = crypto.randomBytes(this.saltLength)\n\n const key = this.getKey(salt)\n\n const cipher = crypto.createCipheriv(algorithm, key, iv)\n const encrypted = Buffer.concat([cipher.update(String(value), 'utf8'), cipher.final()])\n\n const tag = cipher.getAuthTag()\n\n return Buffer.concat([salt, iv, tag, encrypted]).toString(this.encoding)\n }\n\n public decrypt(value: string) {\n const stringValue = Buffer.from(String(value), this.encoding)\n\n const salt = stringValue.subarray(0, this.saltLength)\n const iv = stringValue.subarray(this.saltLength, this.tagPosition)\n const tag = stringValue.subarray(this.tagPosition, this.encryptedPosition)\n const encrypted = stringValue.subarray(this.encryptedPosition)\n\n const key = this.getKey(salt)\n\n const decipher = crypto.createDecipheriv(algorithm, key, iv)\n\n decipher.setAuthTag(tag)\n\n return Buffer.concat([\n decipher.update(encrypted),\n Buffer.from(decipher.final('utf8')),\n ]).toString('utf8')\n }\n}\n","export function chunk<T>(array: T[], chunkSize: number): T[][] {\n const length = array.length\n if (!length || chunkSize < 1) {\n return []\n }\n let index = 0\n let resIndex = 0\n const result = new Array(Math.ceil(length / chunkSize))\n\n while (index < length) {\n // biome-ignore lint/suspicious/noAssignInExpressions: <explanation>\n result[resIndex++] = array.slice(index, (index += chunkSize))\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return result\n}\n\nexport async function callChunked<Item>(\n chunkSize: number,\n array: readonly Item[],\n processFn: (arrayChunk: Item[]) => Promise<unknown>,\n): Promise<void> {\n for (let i = 0; i < array.length; i += chunkSize) {\n const arrayChunk = array.slice(i, i + chunkSize)\n await processFn(arrayChunk)\n }\n}\n\n/**\n * Return a copy of the given array without null or undefined values\n */\nexport function removeNullish<const T>(array: readonly (T | null | undefined)[]): T[] {\n return array.filter((e) => e !== undefined && e !== null) as T[]\n}\n\n/**\n * Return a copy of the given array without falsy values (eg: false, 0, '', null, undefined)\n */\nexport function removeFalsy<const T>(\n array: readonly (T | null | undefined | 0 | '' | false)[],\n): T[] {\n return array.filter((e) => e) as T[]\n}\n\n/**\n * Return a copy of the given array without duplicates.\n */\nexport function removeDuplicates<const T>(array: readonly T[]): T[] {\n return [...new Set(array)]\n}\n","import dotProp from 'dot-prop'\n\nimport { InternalError } from '../errors/InternalError'\n\ntype RecordKeyType = string | number | symbol\n\nexport function copyWithoutUndefined<\n T extends Record<RecordKeyType, unknown>,\n TargetRecordType = Pick<\n T,\n {\n [Prop in keyof T]: T[Prop] extends null | undefined ? never : Prop\n }[keyof T]\n >,\n>(originalValue: T): TargetRecordType {\n return Object.keys(originalValue).reduce(\n (acc, key) => {\n // @ts-ignore\n if (originalValue[key] !== undefined) {\n // @ts-ignore\n acc[key] = originalValue[key]\n }\n return acc\n },\n {} as Record<string, unknown>,\n ) as TargetRecordType\n}\n\nexport function copyWithoutEmpty<\n T extends Record<RecordKeyType, unknown>,\n TargetRecordType = Pick<\n T,\n {\n [Prop in keyof T]: T[Prop] extends null | undefined | '' ? never : Prop\n }[keyof T]\n >,\n>(originalValue: T): TargetRecordType {\n return Object.keys(originalValue).reduce(\n (acc, key) => {\n if (\n originalValue[key] !== undefined &&\n originalValue[key] !== null &&\n // @ts-ignore\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call\n (typeof originalValue[key] !== 'string' || originalValue[key].trim().length > 0)\n ) {\n // @ts-ignore\n acc[key] = originalValue[key]\n }\n return acc\n },\n {} as Record<string, unknown>,\n ) as TargetRecordType\n}\n\nexport function pick<T, K extends string | number | symbol>(\n source: T,\n propNames: readonly K[],\n): Pick<T, Exclude<keyof T, Exclude<keyof T, K>>> {\n const result = {} as T\n let idx = 0\n while (idx < propNames.length) {\n // @ts-ignore\n if (propNames[idx] in source) {\n // @ts-ignore\n result[propNames[idx]] = source[propNames[idx]]\n }\n idx += 1\n }\n return result\n}\n\nexport function pickWithoutUndefined<T, K extends string | number | symbol>(\n source: T,\n propNames: readonly K[],\n): Pick<T, Exclude<keyof T, Exclude<keyof T, K>>> {\n const result = {} as T\n let idx = 0\n while (idx < propNames.length) {\n // @ts-ignore\n if (propNames[idx] in source && source[propNames[idx]] !== undefined) {\n // @ts-ignore\n result[propNames[idx]] = source[propNames[idx]]\n }\n idx += 1\n }\n return result\n}\n\nexport function isEmptyObject(params: Record<string, unknown>): boolean {\n for (const key in params) {\n if (Object.hasOwn(params, key) && params[key] !== undefined) {\n return false\n }\n }\n return true\n}\n\ntype KeysMatching<T, V> = { [K in keyof T]: T[K] extends V ? K : never }[keyof T]\n\n/**\n * @param array The array of objects to be grouped.\n * @param selector The key used for grouping the objects.\n * @returns An object where the keys are unique values from the given selector and the values are the corresponding objects from the array.\n */\nexport function groupBy<\n T extends object,\n K extends KeysMatching<T, RecordKeyType | null | undefined>,\n>(array: T[], selector: K): Record<RecordKeyType, T[]> {\n return array.reduce(\n (acc, item) => {\n const key = item[selector] as RecordKeyType | null | undefined\n if (key === undefined || key === null) {\n return acc\n }\n if (!acc[key]) {\n acc[key] = []\n }\n acc[key].push(item)\n return acc\n },\n {} as Record<RecordKeyType, T[]>,\n )\n}\n\n/**\n * @param array The array of objects to be grouped.\n * @param selector The key used for grouping the objects. Support nested keys.\n * @returns An object where the keys are unique values from the given selector and the values are the corresponding objects from the array.\n */\nexport function groupByPath<T extends object>(array: T[], selector: string): Record<string, T[]> {\n return array.reduce(\n (acc, item) => {\n const key = dotProp.get(item, selector)\n if (key === undefined || key === null) {\n return acc\n }\n const strKeyPath = key as string\n\n if (!acc[strKeyPath]) {\n acc[strKeyPath] = []\n }\n acc[strKeyPath].push(item)\n return acc\n },\n {} as Record<RecordKeyType, T[]>,\n )\n}\n\n/**\n * @param array The array of objects to be grouped.\n * @param selector The key used for grouping the objects.\n * @returns An object where the keys are unique values from the given selector and the value is the\n * corresponding object from the array.\n * @throws InternalError If a duplicated value is found for the given selector.\n */\nexport function groupByUnique<\n T extends object,\n K extends KeysMatching<T, RecordKeyType | null | undefined>,\n>(array: T[], selector: K): Record<RecordKeyType, T> {\n return array.reduce(\n (acc, item) => {\n const key = item[selector] as RecordKeyType | null | undefined\n if (key === undefined || key === null) {\n return acc\n }\n if (acc[key] !== undefined) {\n throw new InternalError({\n message: `Duplicated item for selector ${selector.toString()} with value ${key.toString()}`,\n errorCode: 'DUPLICATED_ITEM',\n details: { selector, value: key },\n })\n }\n acc[key] = item\n return acc\n },\n {} as Record<RecordKeyType, T>,\n )\n}\n\ntype DatesAsString<T> = T extends Date ? string : ExactlyLikeWithDateAsString<T>\n\ntype ExactlyLikeWithDateAsString<T> = T extends object ? { [K in keyof T]: DatesAsString<T[K]> } : T\n\nexport function convertDateFieldsToIsoString<Input extends object>(\n object: Input,\n): ExactlyLikeWithDateAsString<Input>\nexport function convertDateFieldsToIsoString<Input extends object>(\n object: Input[],\n): ExactlyLikeWithDateAsString<Input>[]\nexport function convertDateFieldsToIsoString<Input extends object>(\n object: Input | Input[],\n): ExactlyLikeWithDateAsString<Input> | ExactlyLikeWithDateAsString<Input>[] {\n if (Array.isArray(object)) {\n // @ts-ignore\n return object.map(convertDateFieldsToIsoStringAux)\n }\n\n return Object.entries(object).reduce(\n (result, [key, value]) => {\n // @ts-ignore\n result[key] = convertDateFieldsToIsoStringAux(value)\n return result\n },\n {} as ExactlyLikeWithDateAsString<Input>,\n )\n}\n\nfunction convertDateFieldsToIsoStringAux<T>(item: T): DatesAsString<T> {\n if (item instanceof Date) {\n // @ts-ignore\n return item.toISOString()\n }\n\n if (item && typeof item === 'object') {\n // @ts-ignore\n return convertDateFieldsToIsoString(item)\n }\n\n // @ts-ignore\n return item\n}\n\n/**\n * Return a deep clone copy of an object.\n *\n * Please Note: This uses structuredClone, which has the limitations of these restricted Types: functions,\n * Error objects, WeakMap, WeakSet, DOM nodes, and certain other browser-specific objects like Window.\n */\nexport function deepClone<T extends object | undefined | null>(object: T): T {\n if (object === undefined || object === null) {\n return object\n }\n return structuredClone(object)\n}\n\nfunction transformKey(key: string): string {\n return key\n .replace(/([a-z])([A-Z])/g, '$1-$2') // transforms basic camelCase\n .replace(/([A-Z])([A-Z][a-z])/g, '$1-$2') // transforms abbreviations\n .replace(/_/g, '-') // transforms snake_case\n .toLowerCase() // finally lowercase all\n}\n\ntype TransformToKebabCaseInputType = Record<string, unknown> | null | undefined\ntype TransformToKebabCaseReturnType<Input, Output> = Input extends Record<string, unknown>\n ? Output\n : Input\n/**\n * Transforms an object's keys from camelCase or snake_case to kebab-case.\n * @param object\n */\nexport function transformToKebabCase<\n Output extends Record<string, unknown>,\n Input extends TransformToKebabCaseInputType,\n>(object: Input): TransformToKebabCaseReturnType<Input, Output>\n\nexport function transformToKebabCase<\n Output extends Record<string, unknown>,\n Input extends TransformToKebabCaseInputType,\n>(object: Input[]): TransformToKebabCaseReturnType<Input, Output>[]\n\nexport function transformToKebabCase<Output, Input>(\n object: Input | Input[],\n): TransformToKebabCaseReturnType<Input, Output> | TransformToKebabCaseReturnType<Input, Output>[] {\n if (Array.isArray(object)) {\n // @ts-ignore\n return object.map(transformToKebabCase)\n }\n if (typeof object !== 'object' || object === null || object === undefined) {\n return object as TransformToKebabCaseReturnType<Input, Output>\n }\n\n return Object.entries(object as Record<string, unknown>).reduce(\n (result, [key, value]) => {\n const transformedKey = transformKey(key)\n const transformedValue =\n value && typeof value === 'object'\n ? transformToKebabCase(value as TransformToKebabCaseInputType)\n : value\n\n // Avoiding destructuring by directly assigning the new key-value pair\n result[transformedKey] = transformedValue\n return result\n },\n {} as Record<string, unknown>,\n ) as TransformToKebabCaseReturnType<Input, Output>\n}\n","import { createHash } from 'node:crypto'\n\nexport enum HashEncoding {\n HEX = 'hex',\n BASE64 = 'base64',\n}\n\nexport enum HashAlgorithm {\n SHA256 = 'sha256',\n SHA512 = 'sha512',\n}\n\nexport function generateHash(\n algorithm: HashAlgorithm,\n data: string,\n encoding: HashEncoding = HashEncoding.HEX,\n) {\n return createHash(algorithm).update(data).digest(encoding)\n}\n","import type { Level, Logger, LoggerOptions, redactOptions } from 'pino'\nimport { levels, pino } from 'pino'\nimport pretty from 'pino-pretty'\n\nexport type AppLoggerConfig = {\n logLevel: 'fatal' | 'error' | 'warn' | 'info' | 'debug' | 'trace' | 'silent'\n nodeEnv: 'production' | 'development' | 'test'\n base?: Record<string, unknown>\n redact?: redactOptions\n}\n\nexport type MonorepoAppLoggerConfig = AppLoggerConfig & {\n targetFile?: string\n append?: boolean\n}\n\n/* c8 ignore next 8 */\nexport function resolveMonorepoLogger(appConfig: MonorepoAppLoggerConfig): Logger {\n if (appConfig.nodeEnv !== 'development') {\n return resolveLogger(appConfig)\n }\n\n const configuration = resolveMonorepoLoggerConfiguration(appConfig) as LoggerOptions\n return pino(configuration)\n}\n\n// Note that transports do not work in vitest, likely because pino attempts to run them in a separate worker\n/* c8 ignore next 25 */\nexport function resolveMonorepoLoggerConfiguration(\n appConfig: MonorepoAppLoggerConfig,\n): LoggerOptions | Logger {\n if (appConfig.nodeEnv !== 'development') {\n return resolveLoggerConfiguration(appConfig)\n }\n\n return {\n level: appConfig.logLevel,\n formatters: {\n level: (label) => {\n return { level: label }\n },\n },\n redact: appConfig.redact,\n transport: {\n target: 'pino/file',\n options: {\n destination: appConfig.targetFile ?? './service.log',\n mkdir: true,\n append: appConfig.append ?? false,\n },\n },\n }\n}\n\nexport function resolveLogger(appConfig: AppLoggerConfig): Logger {\n if (appConfig.nodeEnv !== 'production') {\n return resolveLoggerConfiguration(appConfig) as Logger\n }\n\n const configuration = resolveLoggerConfiguration(appConfig) as LoggerOptions\n return pino(configuration)\n}\n\nexport function resolveLoggerConfiguration(appConfig: AppLoggerConfig): LoggerOptions | Logger {\n if (appConfig.nodeEnv !== 'production') {\n return pino(\n pretty({\n sync: true,\n minimumLevel: appConfig.logLevel as Level,\n colorize: true,\n translateTime: 'SYS:standard',\n ignore: 'hostname,pid',\n }),\n )\n }\n\n return {\n level: appConfig.logLevel,\n formatters: {\n level: (_label, numericLevel): { level: string } => {\n const level = levels.labels[numericLevel] || 'unknown'\n return { level }\n },\n },\n redact: appConfig.redact,\n } satisfies LoggerOptions\n}\n","import { types } from 'node:util'\n\nimport type { SerializedError } from 'pino'\nimport { levels, pino, stdSerializers } from 'pino'\n\nimport type { CommonLogger } from '../logging/commonLogger'\nimport { hasMessage } from '../utils/typeUtils'\n\ntype LogObject = {\n message: string\n 'x-request-id'?: string\n error?: SerializedError\n}\n\nexport const globalLogger: CommonLogger = pino({\n formatters: {\n level: (_label, numericLevel): { level: string } => {\n const level = levels.labels[numericLevel] || 'unknown'\n return { level }\n },\n },\n})\n\nexport function resolveGlobalErrorLogObject(err: unknown, correlationId?: string): LogObject {\n if (types.isNativeError(err)) {\n return {\n message: err.message,\n error: stdSerializers.err(err),\n 'x-request-id': correlationId,\n }\n }\n\n if (hasMessage(err)) {\n return {\n message: err.message,\n 'x-request-id': correlationId,\n }\n }\n\n return {\n message: 'Unknown error',\n 'x-request-id': correlationId,\n }\n}\n\nexport function executeAndHandleGlobalErrors<T>(operation: () => T) {\n try {\n const result = operation()\n return result\n } catch (err) {\n const logObject = resolveGlobalErrorLogObject(err)\n globalLogger.error(logObject, logObject.message)\n process.exit(1)\n }\n}\n\nexport async function executeAsyncAndHandleGlobalErrors<T>(\n operation: () => Promise<T>,\n stopOnError = true,\n) {\n try {\n const result = await operation()\n return result\n } catch (err) {\n const logObject = resolveGlobalErrorLogObject(err)\n globalLogger.error(logObject, logObject.message)\n if (stopOnError) {\n process.exit(1)\n }\n }\n}\n\nexport async function executeSettleAllAndHandleGlobalErrors(\n promises: Promise<unknown>[],\n stopOnError = true,\n) {\n const result = await Promise.allSettled(promises)\n\n let errorsHappened: boolean | undefined\n for (const entry of result) {\n if (entry.status === 'rejected') {\n const logObject = resolveGlobalErrorLogObject(entry.reason)\n globalLogger.error(logObject, logObject.message)\n errorsHappened = true\n }\n }\n\n if (stopOnError && errorsHappened) {\n process.exit(1)\n }\n\n return result\n}\n","import { constants as httpConstants } from 'node:http2'\n\nimport type { FreeformRecord } from '../common/commonTypes'\n\nimport { PublicNonRecoverableError } from './PublicNonRecoverableError'\n\nexport type CommonErrorParams = {\n message: string\n details?: FreeformRecord\n cause?: Error\n}\n\nexport type OptionalMessageErrorParams = Partial<CommonErrorParams>\n\nexport type ValidationError = {\n message: string\n path: string[]\n}\n\nexport class RequestValidationError extends PublicNonRecoverableError {\n constructor(errors: ValidationError[]) {\n super({\n message: 'Invalid params',\n errorCode: 'VALIDATION_ERROR',\n httpStatusCode: httpConstants.HTTP_STATUS_BAD_REQUEST,\n details: {\n error: errors,\n },\n })\n }\n}\n\nexport class AccessDeniedError extends PublicNonRecoverableError {\n constructor(params: CommonErrorParams) {\n super({\n message: params.message,\n errorCode: 'ACCESS_DENIED',\n httpStatusCode: httpConstants.HTTP_STATUS_FORBIDDEN,\n details: params.details,\n cause: params.cause,\n })\n }\n}\n\nexport class EntityNotFoundError extends PublicNonRecoverableError {\n constructor(params: CommonErrorParams) {\n super({\n message: params.message,\n errorCode: 'ENTITY_NOT_FOUND',\n httpStatusCode: httpConstants.HTTP_STATUS_NOT_FOUND,\n details: params.details,\n cause: params.cause,\n })\n }\n}\n\nexport class EntityGoneError extends PublicNonRecoverableError {\n constructor(params: CommonErrorParams) {\n super({\n message: params.message,\n errorCode: 'ENTITY_GONE',\n httpStatusCode: 410,\n details: params.details,\n })\n }\n}\n\nexport class AuthFailedError extends PublicNonRecoverableError {\n constructor(params: OptionalMessageErrorParams = {}) {\n super({\n message: params.message ?? 'Authentication failed',\n errorCode: 'AUTH_FAILED',\n httpStatusCode: httpConstants.HTTP_STATUS_UNAUTHORIZED,\n details: params.details,\n cause: params.cause,\n })\n }\n}\n","export const waitAndRetry = async <T>(\n predicateFn: () => T,\n sleepTime = 20,\n maxRetryCount = 15,\n): Promise<T> => {\n return new Promise((resolve, reject) => {\n let retryCount = 0\n function performCheck() {\n // amount of retries exceeded\n if (maxRetryCount !== 0 && retryCount > maxRetryCount) {\n resolve(predicateFn())\n }\n\n // Try executing predicateFn\n Promise.resolve()\n .then(() => {\n return predicateFn()\n })\n .then((result) => {\n if (result) {\n resolve(result)\n } else {\n retryCount++\n setTimeout(performCheck, sleepTime)\n }\n })\n .catch((err) => {\n reject(err)\n })\n }\n\n performCheck()\n })\n}\n","import type { TransactionObservabilityManager } from './observabilityTypes'\n\n/**\n * Groups different TransactionObservabilityManager instances into one\n * to facilitate tracking transactions across multiple observability tools.\n */\nexport class MultiTransactionObservabilityManager implements TransactionObservabilityManager {\n private readonly managers: TransactionObservabilityManager[]\n\n constructor(managers: TransactionObservabilityManager[]) {\n this.managers = managers\n }\n\n start(transactionName: string, uniqueTransactionKey: string): void {\n for (const manager of this.managers) {\n manager.start(transactionName, uniqueTransactionKey)\n }\n }\n\n startWithGroup(\n transactionName: string,\n uniqueTransactionKey: string,\n transactionGroup: string,\n ): void {\n for (const manager of this.managers) {\n manager.startWithGroup(transactionName, uniqueTransactionKey, transactionGroup)\n }\n }\n\n stop(uniqueTransactionKey: string, wasSuccessful?: boolean): void {\n for (const manager of this.managers) {\n manager.stop(uniqueTransactionKey, wasSuccessful)\n }\n }\n}\n","import type { BinaryLike } from 'node:crypto'\nimport { createHash } from 'node:crypto'\nimport type { Readable } from 'node:stream'\n\nconst HASH_ALGORITHM = 'md5'\n\nexport function generateChecksumForBufferOrString(data: BinaryLike): string {\n return createHash(HASH_ALGORITHM).update(data).digest('hex')\n}\n\nexport function generateChecksumForObject(object: object): string {\n const objectAsString = JSON.stringify(object)\n return generateChecksumForBufferOrString(objectAsString)\n}\n\nexport function generateChecksumForReadable(readable: Readable): Promise<string> {\n return new Promise((resolve, reject) => {\n const hashCreator = createHash(HASH_ALGORITHM)\n readable.on('data', (data) => {\n if (Buffer.isBuffer(data)) {\n hashCreator.update(data)\n } else {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-argument\n hashCreator.update(Buffer.from(data))\n }\n })\n\n readable.on('end', () => {\n const hash = hashCreator.digest('hex')\n resolve(hash)\n })\n readable.on('error', (err) => {\n /* c8 ignore next 1 */\n reject(err)\n })\n })\n}\n","import { F_OK } from 'node:constants'\nimport { access, createReadStream, createWriteStream } from 'node:fs'\nimport { stat, unlink } from 'node:fs/promises'\nimport type { Readable } from 'node:stream'\nimport { pipeline } from 'node:stream'\n\nexport type ReadableProvider = {\n /**\n * Guarantees to provide a new stream every time this is called, before `destroy` is invoked.\n */\n createStream(): Promise<Readable>\n\n /**\n * Returns size of the persisted content\n */\n getContentLength(): Promise<number>\n\n /**\n * Remove the persisted value. No new streams can be created after this is called\n */\n destroy(): Promise<void>\n}\n\nexport type PersistToFsOptions = {\n targetFile: string\n sourceReadable: Readable\n}\n\nexport type FsReadableProviderOptions = {\n storageFile: string\n}\n\nexport class FsReadableProvider implements ReadableProvider {\n public readonly storageFile: string\n constructor(options: FsReadableProviderOptions) {\n this.storageFile = options.storageFile\n }\n\n fileExists(): Promise<boolean> {\n return new Promise((resolve) => {\n access(this.storageFile, F_OK, (err) => {\n return resolve(!err)\n })\n })\n }\n\n async getContentLength(): Promise<number> {\n if (!(await this.fileExists())) {\n throw new Error(`File ${this.storageFile} was already deleted.`)\n }\n const stats = await stat(this.storageFile)\n return stats.size\n }\n\n async createStream(): Promise<Readable> {\n if (!(await this.fileExists())) {\n throw new Error(`File ${this.storageFile} was already deleted.`)\n }\n\n return createReadStream(this.storageFile)\n }\n\n async destroy(): Promise<void> {\n if (!(await this.fileExists())) {\n // nothing to do here\n return\n }\n\n return unlink(this.storageFile)\n }\n\n protected async persist(sourceReadable: Readable): Promise<void> {\n const writable = createWriteStream(this.storageFile)\n return new Promise((resolve, reject) => {\n pipeline(sourceReadable, writable, (err) => {\n if (err) {\n /* c8 ignore next 1 */\n reject(err)\n } else {\n resolve()\n }\n })\n })\n }\n\n public static async persistReadableToFs(\n options: PersistToFsOptions,\n ): Promise<FsReadableProvider> {\n const provider = new FsReadableProvider({\n storageFile: options.targetFile,\n })\n await provider.persist(options.sourceReadable)\n return provider\n }\n}\n\n/**\n * Consumes the readable in order to calculate its length in bytes\n * @param readable\n */\nexport function getReadableContentLength(readable: Readable): Promise<number> {\n return new Promise((resolve, reject) => {\n let size = 0\n readable.on('data', (chunk) => {\n if (typeof chunk === 'string' || Buffer.isBuffer(chunk)) {\n size += Buffer.byteLength(chunk)\n }\n })\n readable.on('end', () => {\n resolve(size)\n })\n readable.on('error', (error) => {\n /* c8 ignore next 1 */\n reject(error)\n })\n })\n}\n"],"mappings":"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","names":["dotProp","HashEncoding","HashAlgorithm","algorithm","pretty","import_pino","httpConstants","import_node_crypto"]}
|
package/dist/index.d.cts
ADDED
|
@@ -0,0 +1,404 @@
|
|
|
1
|
+
import { ZodSchema } from 'zod';
|
|
2
|
+
import { redactOptions, Logger, LoggerOptions, BaseLogger, Bindings, ChildLoggerOptions, SerializedError } from 'pino';
|
|
3
|
+
import { BinaryLike } from 'node:crypto';
|
|
4
|
+
import { Readable } from 'node:stream';
|
|
5
|
+
|
|
6
|
+
type ErrorDetails = Record<string, unknown>;
|
|
7
|
+
|
|
8
|
+
type PublicNonRecoverableErrorParams<T = ErrorDetails> = {
|
|
9
|
+
message: string;
|
|
10
|
+
errorCode: string;
|
|
11
|
+
details?: T;
|
|
12
|
+
httpStatusCode?: number;
|
|
13
|
+
cause?: unknown;
|
|
14
|
+
};
|
|
15
|
+
declare const publicNonRecoverableErrorSymbol: unique symbol;
|
|
16
|
+
/**
|
|
17
|
+
* This error is returned to the consumer of API
|
|
18
|
+
*/
|
|
19
|
+
declare class PublicNonRecoverableError<T = ErrorDetails> extends Error {
|
|
20
|
+
readonly [publicNonRecoverableErrorSymbol] = true;
|
|
21
|
+
readonly details?: T;
|
|
22
|
+
readonly errorCode: string;
|
|
23
|
+
readonly httpStatusCode: number;
|
|
24
|
+
constructor(params: PublicNonRecoverableErrorParams<T>);
|
|
25
|
+
}
|
|
26
|
+
declare function isPublicNonRecoverableError(error: unknown): error is PublicNonRecoverableError;
|
|
27
|
+
|
|
28
|
+
type InternalErrorParams<T = ErrorDetails> = {
|
|
29
|
+
message: string;
|
|
30
|
+
errorCode: string;
|
|
31
|
+
details?: T;
|
|
32
|
+
cause?: unknown;
|
|
33
|
+
};
|
|
34
|
+
declare const internalErrorSymbol: unique symbol;
|
|
35
|
+
declare class InternalError<T = ErrorDetails> extends Error {
|
|
36
|
+
readonly [internalErrorSymbol] = true;
|
|
37
|
+
readonly details?: T;
|
|
38
|
+
readonly errorCode: string;
|
|
39
|
+
constructor(params: InternalErrorParams<T>);
|
|
40
|
+
}
|
|
41
|
+
declare function isInternalError(error: unknown): error is InternalError;
|
|
42
|
+
|
|
43
|
+
type FreeformRecord = Record<string, any>;
|
|
44
|
+
|
|
45
|
+
type CommonErrorParams = {
|
|
46
|
+
message: string;
|
|
47
|
+
details?: FreeformRecord;
|
|
48
|
+
cause?: Error;
|
|
49
|
+
};
|
|
50
|
+
type OptionalMessageErrorParams = Partial<CommonErrorParams>;
|
|
51
|
+
type ValidationError = {
|
|
52
|
+
message: string;
|
|
53
|
+
path: string[];
|
|
54
|
+
};
|
|
55
|
+
declare class RequestValidationError extends PublicNonRecoverableError {
|
|
56
|
+
constructor(errors: ValidationError[]);
|
|
57
|
+
}
|
|
58
|
+
declare class AccessDeniedError extends PublicNonRecoverableError {
|
|
59
|
+
constructor(params: CommonErrorParams);
|
|
60
|
+
}
|
|
61
|
+
declare class EntityNotFoundError extends PublicNonRecoverableError {
|
|
62
|
+
constructor(params: CommonErrorParams);
|
|
63
|
+
}
|
|
64
|
+
declare class EntityGoneError extends PublicNonRecoverableError {
|
|
65
|
+
constructor(params: CommonErrorParams);
|
|
66
|
+
}
|
|
67
|
+
declare class AuthFailedError extends PublicNonRecoverableError {
|
|
68
|
+
constructor(params?: OptionalMessageErrorParams);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
declare function isEntityGoneError(entity: unknown): entity is EntityGoneError;
|
|
72
|
+
|
|
73
|
+
type EnvValueValidator<InputType> = (value: InputType) => boolean;
|
|
74
|
+
type EnvValueTransformer<InputType, OutputType> = (value: InputType) => OutputType;
|
|
75
|
+
type RedisConfig = {
|
|
76
|
+
host: string;
|
|
77
|
+
/**
|
|
78
|
+
* An integer from 0 to 15, inclusive
|
|
79
|
+
*/
|
|
80
|
+
db?: number;
|
|
81
|
+
keyPrefix?: string;
|
|
82
|
+
port: number;
|
|
83
|
+
username?: string;
|
|
84
|
+
password?: string;
|
|
85
|
+
commandTimeout?: number;
|
|
86
|
+
connectTimeout?: number;
|
|
87
|
+
/**
|
|
88
|
+
* Set this option explicitly to null for infinite retries
|
|
89
|
+
* By default (for undefined) there are 20 retries, see: https://redis.github.io/ioredis/interfaces/CommonRedisOptions.html#maxRetriesPerRequest
|
|
90
|
+
*/
|
|
91
|
+
maxRetriesPerRequest?: number | null;
|
|
92
|
+
enableReadyCheck?: boolean;
|
|
93
|
+
lazyConnect?: boolean;
|
|
94
|
+
useTls: boolean;
|
|
95
|
+
};
|
|
96
|
+
type AppConfig = {
|
|
97
|
+
port: number;
|
|
98
|
+
bindAddress: string;
|
|
99
|
+
logLevel: string;
|
|
100
|
+
nodeEnv: 'production' | 'development' | 'test';
|
|
101
|
+
appEnv: 'production' | 'development' | 'staging';
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
type EnvType = {
|
|
105
|
+
[key: string]: string | undefined;
|
|
106
|
+
};
|
|
107
|
+
declare class ConfigScope {
|
|
108
|
+
private env;
|
|
109
|
+
constructor(envOverride?: EnvType);
|
|
110
|
+
updateEnv(): void;
|
|
111
|
+
getMandatoryInteger(param: string): number;
|
|
112
|
+
getMandatory(param: string): string;
|
|
113
|
+
getMandatoryOneOf<const T>(param: string, supportedValues: T[]): T;
|
|
114
|
+
getMandatoryValidatedInteger(param: string, validator: EnvValueValidator<number>): number;
|
|
115
|
+
getOptionalNullable<T extends string | null | undefined>(param: string, defaultValue: T): T | string;
|
|
116
|
+
getOptional(param: string, defaultValue: string): string;
|
|
117
|
+
getOptionalInteger(param: string, defaultValue: number): number;
|
|
118
|
+
getOptionalNullableInteger<T extends number | null | undefined>(param: string, defaultValue: T): T | number;
|
|
119
|
+
getOptionalOneOf<const T extends string>(param: string, defaultValue: T, supportedValues: T[]): T;
|
|
120
|
+
getOptionalValidated(param: string, defaultValue: string, validator: EnvValueValidator<string>): string;
|
|
121
|
+
getOptionalValidatedInteger(param: string, defaultValue: number, validator: EnvValueValidator<number>): number;
|
|
122
|
+
getOptionalTransformed(param: string, defaultValue: string, transformer: (value: string) => string): string;
|
|
123
|
+
getOptionalNullableTransformed<T extends string | undefined>(param: string, defaultValue: T, transformer: (value: T | string) => T | string): T | string;
|
|
124
|
+
getMandatoryTransformed(param: string, transformer: (value: string) => string): string;
|
|
125
|
+
getOptionalBoolean(param: string, defaultValue: boolean): boolean;
|
|
126
|
+
getMandatoryJsonObject<T extends object>(param: string, schema: ZodSchema<T>): T;
|
|
127
|
+
getOptionalNullableJsonObject<T extends object, Z extends T | null | undefined>(param: string, schema: ZodSchema<T>, defaultValue: Z): Z;
|
|
128
|
+
getOptionalJsonObject<T extends object>(param: string, schema: ZodSchema<T>, defaultValue: T): T;
|
|
129
|
+
isProduction(): boolean;
|
|
130
|
+
isDevelopment(): boolean;
|
|
131
|
+
isTest(): boolean;
|
|
132
|
+
private validateSchema;
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
declare const ensureClosingSlashTransformer: EnvValueTransformer<string | undefined | null, string>;
|
|
136
|
+
|
|
137
|
+
declare const createRangeValidator: (greaterOrEqualThan: number, lessOrEqualThan: number) => EnvValueValidator<number>;
|
|
138
|
+
|
|
139
|
+
type Left<T> = {
|
|
140
|
+
error: T;
|
|
141
|
+
result?: never;
|
|
142
|
+
};
|
|
143
|
+
type Right<U> = {
|
|
144
|
+
error?: never;
|
|
145
|
+
result: U;
|
|
146
|
+
};
|
|
147
|
+
/**
|
|
148
|
+
* Either is a functional programming type which is used to communicate errors happening in potentially recoverable scenarios.
|
|
149
|
+
* It can return either an error (Left side) or a resolved result (Right side), but not both.
|
|
150
|
+
* It is up to caller of the function to handle received error or throw (Public)NonRecoverableError if it cannot.
|
|
151
|
+
*
|
|
152
|
+
* @see {@link https://antman-does-software.com/stop-catching-errors-in-typescript-use-the-either-type-to-make-your-code-predictable Further reading on motivation for Either type}
|
|
153
|
+
*/
|
|
154
|
+
type Either<T, U> = NonNullable<Left<T> | Right<U>>;
|
|
155
|
+
/***
|
|
156
|
+
* Variation of Either, which may or may not have Error set, but always has Result
|
|
157
|
+
*/
|
|
158
|
+
type DefiniteEither<T, U> = {
|
|
159
|
+
error?: T;
|
|
160
|
+
result: U;
|
|
161
|
+
};
|
|
162
|
+
declare const isFailure: <T, U>(e: Either<T, U>) => e is Left<T>;
|
|
163
|
+
declare const isSuccess: <T, U>(e: Either<T, U>) => e is Right<U>;
|
|
164
|
+
declare const failure: <T>(error: T) => Left<T>;
|
|
165
|
+
declare const success: <U>(result: U) => Right<U>;
|
|
166
|
+
|
|
167
|
+
type Options = {
|
|
168
|
+
saltLength?: number;
|
|
169
|
+
pbkdf2Iterations?: number;
|
|
170
|
+
encoding?: NodeJS.BufferEncoding;
|
|
171
|
+
};
|
|
172
|
+
/**
|
|
173
|
+
* Type-scripted version of https://github.com/MauriceButler/cryptr
|
|
174
|
+
*/
|
|
175
|
+
declare class EncryptionUtility {
|
|
176
|
+
private readonly secret;
|
|
177
|
+
private readonly saltLength;
|
|
178
|
+
private readonly encryptedPosition;
|
|
179
|
+
private readonly tagPosition;
|
|
180
|
+
private readonly pbkdf2Iterations;
|
|
181
|
+
private readonly encoding;
|
|
182
|
+
constructor(secret: string, options?: Options);
|
|
183
|
+
private getKey;
|
|
184
|
+
encrypt(value: string): string;
|
|
185
|
+
decrypt(value: string): string;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
declare function chunk<T>(array: T[], chunkSize: number): T[][];
|
|
189
|
+
declare function callChunked<Item>(chunkSize: number, array: readonly Item[], processFn: (arrayChunk: Item[]) => Promise<unknown>): Promise<void>;
|
|
190
|
+
/**
|
|
191
|
+
* Return a copy of the given array without null or undefined values
|
|
192
|
+
*/
|
|
193
|
+
declare function removeNullish<const T>(array: readonly (T | null | undefined)[]): T[];
|
|
194
|
+
/**
|
|
195
|
+
* Return a copy of the given array without falsy values (eg: false, 0, '', null, undefined)
|
|
196
|
+
*/
|
|
197
|
+
declare function removeFalsy<const T>(array: readonly (T | null | undefined | 0 | '' | false)[]): T[];
|
|
198
|
+
/**
|
|
199
|
+
* Return a copy of the given array without duplicates.
|
|
200
|
+
*/
|
|
201
|
+
declare function removeDuplicates<const T>(array: readonly T[]): T[];
|
|
202
|
+
|
|
203
|
+
type RecordKeyType = string | number | symbol;
|
|
204
|
+
declare function copyWithoutUndefined<T extends Record<RecordKeyType, unknown>, TargetRecordType = Pick<T, {
|
|
205
|
+
[Prop in keyof T]: T[Prop] extends null | undefined ? never : Prop;
|
|
206
|
+
}[keyof T]>>(originalValue: T): TargetRecordType;
|
|
207
|
+
declare function copyWithoutEmpty<T extends Record<RecordKeyType, unknown>, TargetRecordType = Pick<T, {
|
|
208
|
+
[Prop in keyof T]: T[Prop] extends null | undefined | '' ? never : Prop;
|
|
209
|
+
}[keyof T]>>(originalValue: T): TargetRecordType;
|
|
210
|
+
declare function pick<T, K extends string | number | symbol>(source: T, propNames: readonly K[]): Pick<T, Exclude<keyof T, Exclude<keyof T, K>>>;
|
|
211
|
+
declare function pickWithoutUndefined<T, K extends string | number | symbol>(source: T, propNames: readonly K[]): Pick<T, Exclude<keyof T, Exclude<keyof T, K>>>;
|
|
212
|
+
declare function isEmptyObject(params: Record<string, unknown>): boolean;
|
|
213
|
+
type KeysMatching<T, V> = {
|
|
214
|
+
[K in keyof T]: T[K] extends V ? K : never;
|
|
215
|
+
}[keyof T];
|
|
216
|
+
/**
|
|
217
|
+
* @param array The array of objects to be grouped.
|
|
218
|
+
* @param selector The key used for grouping the objects.
|
|
219
|
+
* @returns An object where the keys are unique values from the given selector and the values are the corresponding objects from the array.
|
|
220
|
+
*/
|
|
221
|
+
declare function groupBy<T extends object, K extends KeysMatching<T, RecordKeyType | null | undefined>>(array: T[], selector: K): Record<RecordKeyType, T[]>;
|
|
222
|
+
/**
|
|
223
|
+
* @param array The array of objects to be grouped.
|
|
224
|
+
* @param selector The key used for grouping the objects. Support nested keys.
|
|
225
|
+
* @returns An object where the keys are unique values from the given selector and the values are the corresponding objects from the array.
|
|
226
|
+
*/
|
|
227
|
+
declare function groupByPath<T extends object>(array: T[], selector: string): Record<string, T[]>;
|
|
228
|
+
/**
|
|
229
|
+
* @param array The array of objects to be grouped.
|
|
230
|
+
* @param selector The key used for grouping the objects.
|
|
231
|
+
* @returns An object where the keys are unique values from the given selector and the value is the
|
|
232
|
+
* corresponding object from the array.
|
|
233
|
+
* @throws InternalError If a duplicated value is found for the given selector.
|
|
234
|
+
*/
|
|
235
|
+
declare function groupByUnique<T extends object, K extends KeysMatching<T, RecordKeyType | null | undefined>>(array: T[], selector: K): Record<RecordKeyType, T>;
|
|
236
|
+
type DatesAsString<T> = T extends Date ? string : ExactlyLikeWithDateAsString<T>;
|
|
237
|
+
type ExactlyLikeWithDateAsString<T> = T extends object ? {
|
|
238
|
+
[K in keyof T]: DatesAsString<T[K]>;
|
|
239
|
+
} : T;
|
|
240
|
+
declare function convertDateFieldsToIsoString<Input extends object>(object: Input): ExactlyLikeWithDateAsString<Input>;
|
|
241
|
+
declare function convertDateFieldsToIsoString<Input extends object>(object: Input[]): ExactlyLikeWithDateAsString<Input>[];
|
|
242
|
+
/**
|
|
243
|
+
* Return a deep clone copy of an object.
|
|
244
|
+
*
|
|
245
|
+
* Please Note: This uses structuredClone, which has the limitations of these restricted Types: functions,
|
|
246
|
+
* Error objects, WeakMap, WeakSet, DOM nodes, and certain other browser-specific objects like Window.
|
|
247
|
+
*/
|
|
248
|
+
declare function deepClone<T extends object | undefined | null>(object: T): T;
|
|
249
|
+
|
|
250
|
+
type StandardizedError = {
|
|
251
|
+
code: string;
|
|
252
|
+
message: string;
|
|
253
|
+
};
|
|
254
|
+
declare function hasMessage(maybe: unknown): maybe is {
|
|
255
|
+
message: string;
|
|
256
|
+
};
|
|
257
|
+
declare function isObject(maybeObject: unknown): maybeObject is Record<PropertyKey, unknown>;
|
|
258
|
+
declare function isStandardizedError(error: unknown): error is StandardizedError;
|
|
259
|
+
declare function isError(maybeError: unknown): maybeError is Error;
|
|
260
|
+
|
|
261
|
+
declare enum HashEncoding {
|
|
262
|
+
HEX = "hex",
|
|
263
|
+
BASE64 = "base64"
|
|
264
|
+
}
|
|
265
|
+
declare enum HashAlgorithm {
|
|
266
|
+
SHA256 = "sha256",
|
|
267
|
+
SHA512 = "sha512"
|
|
268
|
+
}
|
|
269
|
+
declare function generateHash(algorithm: HashAlgorithm, data: string, encoding?: HashEncoding): string;
|
|
270
|
+
|
|
271
|
+
type AppLoggerConfig = {
|
|
272
|
+
logLevel: 'fatal' | 'error' | 'warn' | 'info' | 'debug' | 'trace' | 'silent';
|
|
273
|
+
nodeEnv: 'production' | 'development' | 'test';
|
|
274
|
+
base?: Record<string, unknown>;
|
|
275
|
+
redact?: redactOptions;
|
|
276
|
+
};
|
|
277
|
+
type MonorepoAppLoggerConfig = AppLoggerConfig & {
|
|
278
|
+
targetFile?: string;
|
|
279
|
+
append?: boolean;
|
|
280
|
+
};
|
|
281
|
+
declare function resolveMonorepoLogger(appConfig: MonorepoAppLoggerConfig): Logger;
|
|
282
|
+
declare function resolveMonorepoLoggerConfiguration(appConfig: MonorepoAppLoggerConfig): LoggerOptions | Logger;
|
|
283
|
+
declare function resolveLogger(appConfig: AppLoggerConfig): Logger;
|
|
284
|
+
declare function resolveLoggerConfiguration(appConfig: AppLoggerConfig): LoggerOptions | Logger;
|
|
285
|
+
|
|
286
|
+
type CommonLogger = BaseLogger & {
|
|
287
|
+
/**
|
|
288
|
+
* Creates a child logger, setting all key-value pairs in `bindings` as properties in the log lines. All serializers will be applied to the given pair.
|
|
289
|
+
* Child loggers use the same output stream as the parent and inherit the current log level of the parent at the time they are spawned.
|
|
290
|
+
* If a `level` property is present in the object passed to `child` it will override the child logger level.
|
|
291
|
+
*
|
|
292
|
+
* @param bindings: an object of key-value pairs to include in log lines as properties.
|
|
293
|
+
* @param options: an options object that will override child logger inherited options.
|
|
294
|
+
* @returns a child logger instance.
|
|
295
|
+
*/
|
|
296
|
+
child(bindings: Bindings, options?: ChildLoggerOptions): CommonLogger;
|
|
297
|
+
/**
|
|
298
|
+
* A utility method for determining if a given log level will write to the destination.
|
|
299
|
+
*/
|
|
300
|
+
isLevelEnabled(level: string): boolean;
|
|
301
|
+
};
|
|
302
|
+
|
|
303
|
+
/**
|
|
304
|
+
* Generic interface for resolving specific kind of errors based on something that was thrown during execution
|
|
305
|
+
*/
|
|
306
|
+
type ErrorResolver = {
|
|
307
|
+
processError: (thrownError: unknown) => InternalError;
|
|
308
|
+
};
|
|
309
|
+
interface ErrorReport {
|
|
310
|
+
error: Error;
|
|
311
|
+
context?: Record<string, unknown>;
|
|
312
|
+
}
|
|
313
|
+
type ErrorReporter = {
|
|
314
|
+
report: (errorReport: ErrorReport) => void;
|
|
315
|
+
};
|
|
316
|
+
|
|
317
|
+
type LogObject = {
|
|
318
|
+
message: string;
|
|
319
|
+
'x-request-id'?: string;
|
|
320
|
+
error?: SerializedError;
|
|
321
|
+
};
|
|
322
|
+
declare const globalLogger: CommonLogger;
|
|
323
|
+
declare function resolveGlobalErrorLogObject(err: unknown, correlationId?: string): LogObject;
|
|
324
|
+
declare function executeAndHandleGlobalErrors<T>(operation: () => T): T;
|
|
325
|
+
declare function executeAsyncAndHandleGlobalErrors<T>(operation: () => Promise<T>, stopOnError?: boolean): Promise<T | undefined>;
|
|
326
|
+
declare function executeSettleAllAndHandleGlobalErrors(promises: Promise<unknown>[], stopOnError?: boolean): Promise<PromiseSettledResult<unknown>[]>;
|
|
327
|
+
|
|
328
|
+
type MayOmit<T, K extends keyof T> = Pick<Partial<T>, K> & Omit<T, K>;
|
|
329
|
+
|
|
330
|
+
declare const waitAndRetry: <T>(predicateFn: () => T, sleepTime?: number, maxRetryCount?: number) => Promise<T>;
|
|
331
|
+
|
|
332
|
+
type TransactionObservabilityManager = {
|
|
333
|
+
/**
|
|
334
|
+
* Creates and starts a background transaction to record work done
|
|
335
|
+
*
|
|
336
|
+
* @param transactionName - used for grouping similar transactions together
|
|
337
|
+
* @param uniqueTransactionKey - used for identifying specific ongoing transaction. Must be reasonably unique to reduce possibility of collisions
|
|
338
|
+
*/
|
|
339
|
+
start: (transactionName: string, uniqueTransactionKey: string) => unknown;
|
|
340
|
+
/**
|
|
341
|
+
* Creates and starts a background transaction to record work done, and relates it to a specified group
|
|
342
|
+
*
|
|
343
|
+
* @param transactionName - used for grouping similar transactions together
|
|
344
|
+
* @param uniqueTransactionKey - used for identifying specific ongoing transaction. Must be reasonably unique to reduce possibility of collisions *
|
|
345
|
+
* @param transactionGroup - group is used for grouping related transactions with different names
|
|
346
|
+
*/
|
|
347
|
+
startWithGroup: (transactionName: string, uniqueTransactionKey: string, transactionGroup: string) => void;
|
|
348
|
+
/**
|
|
349
|
+
* Ends the transaction
|
|
350
|
+
* @param uniqueTransactionKey - used for identifying specific ongoing transaction. Must be reasonably unique to reduce possibility of collisions
|
|
351
|
+
* @param wasSuccessful - indicates if the transaction was successful or not
|
|
352
|
+
*/
|
|
353
|
+
stop: (uniqueTransactionKey: string, wasSuccessful?: boolean) => unknown;
|
|
354
|
+
};
|
|
355
|
+
|
|
356
|
+
/**
|
|
357
|
+
* Groups different TransactionObservabilityManager instances into one
|
|
358
|
+
* to facilitate tracking transactions across multiple observability tools.
|
|
359
|
+
*/
|
|
360
|
+
declare class MultiTransactionObservabilityManager implements TransactionObservabilityManager {
|
|
361
|
+
private readonly managers;
|
|
362
|
+
constructor(managers: TransactionObservabilityManager[]);
|
|
363
|
+
start(transactionName: string, uniqueTransactionKey: string): void;
|
|
364
|
+
startWithGroup(transactionName: string, uniqueTransactionKey: string, transactionGroup: string): void;
|
|
365
|
+
stop(uniqueTransactionKey: string, wasSuccessful?: boolean): void;
|
|
366
|
+
}
|
|
367
|
+
|
|
368
|
+
declare function generateChecksumForBufferOrString(data: BinaryLike): string;
|
|
369
|
+
declare function generateChecksumForObject(object: object): string;
|
|
370
|
+
declare function generateChecksumForReadable(readable: Readable): Promise<string>;
|
|
371
|
+
|
|
372
|
+
type ReadableProvider = {
|
|
373
|
+
/**
|
|
374
|
+
* Guarantees to provide a new stream every time this is called, before `destroy` is invoked.
|
|
375
|
+
*/
|
|
376
|
+
createStream(): Promise<Readable>;
|
|
377
|
+
/**
|
|
378
|
+
* Returns size of the persisted content
|
|
379
|
+
*/
|
|
380
|
+
getContentLength(): Promise<number>;
|
|
381
|
+
/**
|
|
382
|
+
* Remove the persisted value. No new streams can be created after this is called
|
|
383
|
+
*/
|
|
384
|
+
destroy(): Promise<void>;
|
|
385
|
+
};
|
|
386
|
+
type PersistToFsOptions = {
|
|
387
|
+
targetFile: string;
|
|
388
|
+
sourceReadable: Readable;
|
|
389
|
+
};
|
|
390
|
+
type FsReadableProviderOptions = {
|
|
391
|
+
storageFile: string;
|
|
392
|
+
};
|
|
393
|
+
declare class FsReadableProvider implements ReadableProvider {
|
|
394
|
+
readonly storageFile: string;
|
|
395
|
+
constructor(options: FsReadableProviderOptions);
|
|
396
|
+
fileExists(): Promise<boolean>;
|
|
397
|
+
getContentLength(): Promise<number>;
|
|
398
|
+
createStream(): Promise<Readable>;
|
|
399
|
+
destroy(): Promise<void>;
|
|
400
|
+
protected persist(sourceReadable: Readable): Promise<void>;
|
|
401
|
+
static persistReadableToFs(options: PersistToFsOptions): Promise<FsReadableProvider>;
|
|
402
|
+
}
|
|
403
|
+
|
|
404
|
+
export { AccessDeniedError, type AppConfig, type AppLoggerConfig, AuthFailedError, type CommonErrorParams, type CommonLogger, ConfigScope, type DefiniteEither, type Either, EncryptionUtility, EntityGoneError, EntityNotFoundError, type EnvValueTransformer, type EnvValueValidator, type ErrorDetails, type ErrorReport, type ErrorReporter, type ErrorResolver, type FreeformRecord, FsReadableProvider, type FsReadableProviderOptions, HashAlgorithm, HashEncoding, InternalError, type InternalErrorParams, type MayOmit, type MonorepoAppLoggerConfig, MultiTransactionObservabilityManager, type OptionalMessageErrorParams, type PersistToFsOptions, PublicNonRecoverableError, type PublicNonRecoverableErrorParams, type ReadableProvider, type RedisConfig, RequestValidationError, type StandardizedError, type TransactionObservabilityManager, type ValidationError, callChunked, chunk, convertDateFieldsToIsoString, copyWithoutEmpty, copyWithoutUndefined, createRangeValidator, deepClone, ensureClosingSlashTransformer, executeAndHandleGlobalErrors, executeAsyncAndHandleGlobalErrors, executeSettleAllAndHandleGlobalErrors, failure, generateChecksumForBufferOrString, generateChecksumForObject, generateChecksumForReadable, generateHash, globalLogger, groupBy, groupByPath, groupByUnique, hasMessage, isEmptyObject, isEntityGoneError, isError, isFailure, isInternalError, isObject, isPublicNonRecoverableError, isStandardizedError, isSuccess, pick, pickWithoutUndefined, removeDuplicates, removeFalsy, removeNullish, resolveGlobalErrorLogObject, resolveLogger, resolveLoggerConfiguration, resolveMonorepoLogger, resolveMonorepoLoggerConfiguration, success, waitAndRetry };
|