UNPKG

@smooai/utils

Version:

A collection of shared utilities and tools used across SmooAI projects. This package provides common functionality to standardize and simplify development across all SmooAI repositories.

41 lines (40 loc) 1.92 kB
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" }); const require_chunk = require("../chunk-CoPdw6nB.cjs"); const require_validation_standardSchema = require("../validation/standardSchema.cjs"); const require_api_ApiError = require("./ApiError.cjs"); let zod = require("zod"); let _smooai_logger_AwsServerLogger = require("@smooai/logger/AwsServerLogger"); _smooai_logger_AwsServerLogger = require_chunk.__toESM(_smooai_logger_AwsServerLogger); //#region src/api/sqsHandler.ts const logger = new _smooai_logger_AwsServerLogger.default(); function sqsHandler(handler) { return async (event, context) => { try { const batchItemFailures = []; logger.addLambdaContext(void 0, context); for (const record of event.Records) try { logger.addSQSRecordContext(record); await handler({ ...record, body: record.body ? JSON.parse(record.body) : {} }, context); } catch (error) { if (error instanceof require_api_ApiError.ApiError) logger.error(error, `An API error occurred: Status: ${error.status} (${error.statusText}); Message: ${error.message}`); else if (error instanceof require_validation_standardSchema.HumanReadableSchemaError) logger.error(error, `A schema validation error occurred: ${error.message}`); else if (error instanceof zod.ZodError) { const prettyError = zod.z.prettifyError(error); logger.error(error, `A validation error occurred: ${prettyError}`); } else if (error instanceof Error) logger.error(error, `An unexpected error occurred: ${error.message}`); else logger.error(error, `An unexpected error occurred: ${error}`); batchItemFailures.push({ itemIdentifier: record.messageId }); } return { batchItemFailures }; } catch (error) { logger.error(error, `An unexpected error occurred: ${error}`); throw error; } }; } //#endregion exports.sqsHandler = sqsHandler; //# sourceMappingURL=sqsHandler.cjs.map