@explorins/pers-shared 2.1.35 → 2.1.37
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/CHANGELOG.md +21 -0
- package/dist/cjs/index.d.ts +2 -0
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +5 -2
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/shared-lib/dto/auth.dto.d.ts +1 -2
- package/dist/cjs/shared-lib/dto/auth.dto.d.ts.map +1 -1
- package/dist/cjs/shared-lib/dto/auth.dto.js +1 -10
- package/dist/cjs/shared-lib/dto/auth.dto.js.map +1 -1
- package/dist/cjs/shared-lib/errors/base/error-classification-enums.d.ts +157 -1
- package/dist/cjs/shared-lib/errors/base/error-classification-enums.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/base/error-classification-enums.js +20 -1
- package/dist/cjs/shared-lib/errors/base/error-classification-enums.js.map +1 -1
- package/dist/cjs/shared-lib/errors/base-business-error.d.ts +56 -2
- package/dist/cjs/shared-lib/errors/base-business-error.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/base-business-error.js +110 -11
- package/dist/cjs/shared-lib/errors/base-business-error.js.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/authentication-errors.d.ts +7 -7
- package/dist/cjs/shared-lib/errors/domains/authentication-errors.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/authentication-errors.js +6 -6
- package/dist/cjs/shared-lib/errors/domains/authentication-errors.js.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/balance-errors.d.ts +2 -2
- package/dist/cjs/shared-lib/errors/domains/balance-errors.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/balance-errors.js +2 -2
- package/dist/cjs/shared-lib/errors/domains/balance-errors.js.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/business-errors.d.ts +24 -3
- package/dist/cjs/shared-lib/errors/domains/business-errors.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/business-errors.js +42 -3
- package/dist/cjs/shared-lib/errors/domains/business-errors.js.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/contract-errors.d.ts +2 -2
- package/dist/cjs/shared-lib/errors/domains/contract-errors.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/contract-errors.js +1 -1
- package/dist/cjs/shared-lib/errors/domains/contract-errors.js.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/signing-account-errors.d.ts +7 -7
- package/dist/cjs/shared-lib/errors/domains/signing-account-errors.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/signing-account-errors.js +12 -10
- package/dist/cjs/shared-lib/errors/domains/signing-account-errors.js.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/system-errors.d.ts +7 -4
- package/dist/cjs/shared-lib/errors/domains/system-errors.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/system-errors.js +13 -6
- package/dist/cjs/shared-lib/errors/domains/system-errors.js.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/token-errors.d.ts +10 -4
- package/dist/cjs/shared-lib/errors/domains/token-errors.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/token-errors.js +19 -5
- package/dist/cjs/shared-lib/errors/domains/token-errors.js.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/transaction-errors.d.ts +8 -5
- package/dist/cjs/shared-lib/errors/domains/transaction-errors.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/transaction-errors.js +14 -7
- package/dist/cjs/shared-lib/errors/domains/transaction-errors.js.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/user-errors.d.ts +2 -2
- package/dist/cjs/shared-lib/errors/domains/user-errors.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/user-errors.js +1 -1
- package/dist/cjs/shared-lib/errors/domains/user-errors.js.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/validation-errors.d.ts +4 -4
- package/dist/cjs/shared-lib/errors/domains/validation-errors.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/validation-errors.js +6 -7
- package/dist/cjs/shared-lib/errors/domains/validation-errors.js.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/wallet-errors.d.ts +4 -4
- package/dist/cjs/shared-lib/errors/domains/wallet-errors.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/domains/wallet-errors.js +5 -4
- package/dist/cjs/shared-lib/errors/domains/wallet-errors.js.map +1 -1
- package/dist/cjs/shared-lib/errors/index.d.ts +1 -1
- package/dist/cjs/shared-lib/errors/index.d.ts.map +1 -1
- package/dist/cjs/shared-lib/errors/index.js +9 -1
- package/dist/cjs/shared-lib/errors/index.js.map +1 -1
- package/dist/cjs/shared-patterns/database/index.d.ts +6 -0
- package/dist/cjs/shared-patterns/database/index.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/database/index.js +24 -0
- package/dist/cjs/shared-patterns/database/index.js.map +1 -0
- package/dist/cjs/shared-patterns/database/models/base.model.d.ts +7 -0
- package/dist/cjs/shared-patterns/database/models/base.model.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/database/models/base.model.js +11 -0
- package/dist/cjs/shared-patterns/database/models/base.model.js.map +1 -0
- package/dist/cjs/shared-patterns/database/models/fixture.model.d.ts +4 -0
- package/dist/cjs/shared-patterns/database/models/fixture.model.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/database/models/fixture.model.js +8 -0
- package/dist/cjs/shared-patterns/database/models/fixture.model.js.map +1 -0
- package/dist/cjs/shared-patterns/database/schemas/fixture-fields.schema.d.ts +5 -0
- package/dist/cjs/shared-patterns/database/schemas/fixture-fields.schema.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/database/schemas/fixture-fields.schema.js +11 -0
- package/dist/cjs/shared-patterns/database/schemas/fixture-fields.schema.js.map +1 -0
- package/dist/cjs/shared-patterns/database/schemas/shared-fields.schema.d.ts +44 -0
- package/dist/cjs/shared-patterns/database/schemas/shared-fields.schema.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/database/schemas/shared-fields.schema.js +64 -0
- package/dist/cjs/shared-patterns/database/schemas/shared-fields.schema.js.map +1 -0
- package/dist/cjs/shared-patterns/database/schemas/tenant-fields.schema.d.ts +51 -0
- package/dist/cjs/shared-patterns/database/schemas/tenant-fields.schema.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/database/schemas/tenant-fields.schema.js +57 -0
- package/dist/cjs/shared-patterns/database/schemas/tenant-fields.schema.js.map +1 -0
- package/dist/cjs/shared-patterns/enums/lambda.enum.d.ts +28 -0
- package/dist/cjs/shared-patterns/enums/lambda.enum.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/enums/lambda.enum.js +34 -0
- package/dist/cjs/shared-patterns/enums/lambda.enum.js.map +1 -0
- package/dist/cjs/shared-patterns/errors/error-factory.d.ts +150 -0
- package/dist/cjs/shared-patterns/errors/error-factory.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/errors/error-factory.js +257 -0
- package/dist/cjs/shared-patterns/errors/error-factory.js.map +1 -0
- package/dist/cjs/shared-patterns/exceptions/base/error-classification-enums.d.ts +118 -0
- package/dist/cjs/shared-patterns/exceptions/base/error-classification-enums.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/exceptions/base/error-classification-enums.js +111 -0
- package/dist/cjs/shared-patterns/exceptions/base/error-classification-enums.js.map +1 -0
- package/dist/cjs/shared-patterns/exceptions/base/error-classifier.d.ts +23 -0
- package/dist/cjs/shared-patterns/exceptions/base/error-classifier.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/exceptions/base/error-classifier.js +165 -0
- package/dist/cjs/shared-patterns/exceptions/base/error-classifier.js.map +1 -0
- package/dist/cjs/shared-patterns/exceptions/index.d.ts +3 -0
- package/dist/cjs/shared-patterns/exceptions/index.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/exceptions/index.js +24 -0
- package/dist/cjs/shared-patterns/exceptions/index.js.map +1 -0
- package/dist/cjs/shared-patterns/functions/crypto.functions.d.ts +16 -0
- package/dist/cjs/shared-patterns/functions/crypto.functions.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/functions/crypto.functions.js +110 -0
- package/dist/cjs/shared-patterns/functions/crypto.functions.js.map +1 -0
- package/dist/cjs/shared-patterns/functions/helper.functions.d.ts +10 -0
- package/dist/cjs/shared-patterns/functions/helper.functions.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/functions/helper.functions.js +38 -0
- package/dist/cjs/shared-patterns/functions/helper.functions.js.map +1 -0
- package/dist/cjs/shared-patterns/functions/index.d.ts +4 -0
- package/dist/cjs/shared-patterns/functions/index.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/functions/index.js +21 -0
- package/dist/cjs/shared-patterns/functions/index.js.map +1 -0
- package/dist/cjs/shared-patterns/functions/request.functions.d.ts +14 -0
- package/dist/cjs/shared-patterns/functions/request.functions.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/functions/request.functions.js +69 -0
- package/dist/cjs/shared-patterns/functions/request.functions.js.map +1 -0
- package/dist/cjs/shared-patterns/index.d.ts +15 -0
- package/dist/cjs/shared-patterns/index.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/index.js +44 -0
- package/dist/cjs/shared-patterns/index.js.map +1 -0
- package/dist/cjs/shared-patterns/interfaces/index.d.ts +3 -0
- package/dist/cjs/shared-patterns/interfaces/index.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/interfaces/index.js +19 -0
- package/dist/cjs/shared-patterns/interfaces/index.js.map +1 -0
- package/dist/cjs/shared-patterns/interfaces/request.interface.d.ts +21 -0
- package/dist/cjs/shared-patterns/interfaces/request.interface.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/interfaces/request.interface.js +15 -0
- package/dist/cjs/shared-patterns/interfaces/request.interface.js.map +1 -0
- package/dist/cjs/shared-patterns/interfaces/stripe-payment-intent-metadata.interface.d.ts +9 -0
- package/dist/cjs/shared-patterns/interfaces/stripe-payment-intent-metadata.interface.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/interfaces/stripe-payment-intent-metadata.interface.js +3 -0
- package/dist/cjs/shared-patterns/interfaces/stripe-payment-intent-metadata.interface.js.map +1 -0
- package/dist/cjs/shared-patterns/orchestrators/base-orchestrator.d.ts +90 -0
- package/dist/cjs/shared-patterns/orchestrators/base-orchestrator.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/orchestrators/base-orchestrator.js +124 -0
- package/dist/cjs/shared-patterns/orchestrators/base-orchestrator.js.map +1 -0
- package/dist/cjs/shared-patterns/orchestrators/base-workflow.d.ts +50 -0
- package/dist/cjs/shared-patterns/orchestrators/base-workflow.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/orchestrators/base-workflow.js +68 -0
- package/dist/cjs/shared-patterns/orchestrators/base-workflow.js.map +1 -0
- package/dist/cjs/shared-patterns/orchestrators/index.d.ts +26 -0
- package/dist/cjs/shared-patterns/orchestrators/index.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/orchestrators/index.js +46 -0
- package/dist/cjs/shared-patterns/orchestrators/index.js.map +1 -0
- package/dist/cjs/shared-patterns/utils/error-message.utils.d.ts +175 -0
- package/dist/cjs/shared-patterns/utils/error-message.utils.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/utils/error-message.utils.js +258 -0
- package/dist/cjs/shared-patterns/utils/error-message.utils.js.map +1 -0
- package/dist/cjs/shared-patterns/utils/index.d.ts +3 -0
- package/dist/cjs/shared-patterns/utils/index.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/utils/index.js +20 -0
- package/dist/cjs/shared-patterns/utils/index.js.map +1 -0
- package/dist/cjs/shared-patterns/utils/validation.utils.d.ts +49 -0
- package/dist/cjs/shared-patterns/utils/validation.utils.d.ts.map +1 -0
- package/dist/cjs/shared-patterns/utils/validation.utils.js +76 -0
- package/dist/cjs/shared-patterns/utils/validation.utils.js.map +1 -0
- package/dist/esm/index.d.ts +2 -0
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +5 -2
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/shared-lib/dto/auth.dto.d.ts +1 -2
- package/dist/esm/shared-lib/dto/auth.dto.d.ts.map +1 -1
- package/dist/esm/shared-lib/dto/auth.dto.js +1 -9
- package/dist/esm/shared-lib/dto/auth.dto.js.map +1 -1
- package/dist/esm/shared-lib/errors/base/error-classification-enums.d.ts +157 -1
- package/dist/esm/shared-lib/errors/base/error-classification-enums.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/base/error-classification-enums.js +11 -0
- package/dist/esm/shared-lib/errors/base/error-classification-enums.js.map +1 -1
- package/dist/esm/shared-lib/errors/base-business-error.d.ts +56 -2
- package/dist/esm/shared-lib/errors/base-business-error.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/base-business-error.js +101 -10
- package/dist/esm/shared-lib/errors/base-business-error.js.map +1 -1
- package/dist/esm/shared-lib/errors/domains/authentication-errors.d.ts +7 -7
- package/dist/esm/shared-lib/errors/domains/authentication-errors.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/domains/authentication-errors.js +7 -7
- package/dist/esm/shared-lib/errors/domains/authentication-errors.js.map +1 -1
- package/dist/esm/shared-lib/errors/domains/balance-errors.d.ts +2 -2
- package/dist/esm/shared-lib/errors/domains/balance-errors.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/domains/balance-errors.js +3 -3
- package/dist/esm/shared-lib/errors/domains/balance-errors.js.map +1 -1
- package/dist/esm/shared-lib/errors/domains/business-errors.d.ts +24 -3
- package/dist/esm/shared-lib/errors/domains/business-errors.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/domains/business-errors.js +37 -3
- package/dist/esm/shared-lib/errors/domains/business-errors.js.map +1 -1
- package/dist/esm/shared-lib/errors/domains/contract-errors.d.ts +2 -2
- package/dist/esm/shared-lib/errors/domains/contract-errors.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/domains/contract-errors.js +2 -2
- package/dist/esm/shared-lib/errors/domains/contract-errors.js.map +1 -1
- package/dist/esm/shared-lib/errors/domains/signing-account-errors.d.ts +7 -7
- package/dist/esm/shared-lib/errors/domains/signing-account-errors.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/domains/signing-account-errors.js +13 -11
- package/dist/esm/shared-lib/errors/domains/signing-account-errors.js.map +1 -1
- package/dist/esm/shared-lib/errors/domains/system-errors.d.ts +7 -4
- package/dist/esm/shared-lib/errors/domains/system-errors.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/domains/system-errors.js +12 -6
- package/dist/esm/shared-lib/errors/domains/system-errors.js.map +1 -1
- package/dist/esm/shared-lib/errors/domains/token-errors.d.ts +10 -4
- package/dist/esm/shared-lib/errors/domains/token-errors.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/domains/token-errors.js +17 -5
- package/dist/esm/shared-lib/errors/domains/token-errors.js.map +1 -1
- package/dist/esm/shared-lib/errors/domains/transaction-errors.d.ts +8 -5
- package/dist/esm/shared-lib/errors/domains/transaction-errors.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/domains/transaction-errors.js +13 -7
- package/dist/esm/shared-lib/errors/domains/transaction-errors.js.map +1 -1
- package/dist/esm/shared-lib/errors/domains/user-errors.d.ts +2 -2
- package/dist/esm/shared-lib/errors/domains/user-errors.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/domains/user-errors.js +2 -2
- package/dist/esm/shared-lib/errors/domains/user-errors.js.map +1 -1
- package/dist/esm/shared-lib/errors/domains/validation-errors.d.ts +4 -4
- package/dist/esm/shared-lib/errors/domains/validation-errors.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/domains/validation-errors.js +7 -8
- package/dist/esm/shared-lib/errors/domains/validation-errors.js.map +1 -1
- package/dist/esm/shared-lib/errors/domains/wallet-errors.d.ts +4 -4
- package/dist/esm/shared-lib/errors/domains/wallet-errors.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/domains/wallet-errors.js +6 -5
- package/dist/esm/shared-lib/errors/domains/wallet-errors.js.map +1 -1
- package/dist/esm/shared-lib/errors/index.d.ts +1 -1
- package/dist/esm/shared-lib/errors/index.d.ts.map +1 -1
- package/dist/esm/shared-lib/errors/index.js +1 -1
- package/dist/esm/shared-lib/errors/index.js.map +1 -1
- package/dist/esm/shared-lib/interfaces/wallet-signing-scenario.interface.d.ts +0 -2
- package/dist/esm/shared-lib/interfaces/wallet-signing-scenario.interface.d.ts.map +1 -1
- package/dist/esm/shared-patterns/database/index.d.ts +6 -0
- package/dist/esm/shared-patterns/database/index.d.ts.map +1 -0
- package/dist/esm/shared-patterns/database/index.js +8 -0
- package/dist/esm/shared-patterns/database/index.js.map +1 -0
- package/dist/esm/shared-patterns/database/models/base.model.d.ts +7 -0
- package/dist/esm/shared-patterns/database/models/base.model.d.ts.map +1 -0
- package/dist/esm/shared-patterns/database/models/base.model.js +7 -0
- package/dist/esm/shared-patterns/database/models/base.model.js.map +1 -0
- package/dist/esm/shared-patterns/database/models/fixture.model.d.ts +4 -0
- package/dist/esm/shared-patterns/database/models/fixture.model.d.ts.map +1 -0
- package/dist/esm/shared-patterns/database/models/fixture.model.js +4 -0
- package/dist/esm/shared-patterns/database/models/fixture.model.js.map +1 -0
- package/dist/esm/shared-patterns/database/schemas/fixture-fields.schema.d.ts +5 -0
- package/dist/esm/shared-patterns/database/schemas/fixture-fields.schema.d.ts.map +1 -0
- package/dist/esm/shared-patterns/database/schemas/fixture-fields.schema.js +8 -0
- package/dist/esm/shared-patterns/database/schemas/fixture-fields.schema.js.map +1 -0
- package/dist/esm/shared-patterns/database/schemas/shared-fields.schema.d.ts +44 -0
- package/dist/esm/shared-patterns/database/schemas/shared-fields.schema.d.ts.map +1 -0
- package/dist/esm/shared-patterns/database/schemas/shared-fields.schema.js +61 -0
- package/dist/esm/shared-patterns/database/schemas/shared-fields.schema.js.map +1 -0
- package/dist/esm/shared-patterns/database/schemas/tenant-fields.schema.d.ts +51 -0
- package/dist/esm/shared-patterns/database/schemas/tenant-fields.schema.d.ts.map +1 -0
- package/dist/esm/shared-patterns/database/schemas/tenant-fields.schema.js +54 -0
- package/dist/esm/shared-patterns/database/schemas/tenant-fields.schema.js.map +1 -0
- package/dist/esm/shared-patterns/enums/lambda.enum.d.ts +28 -0
- package/dist/esm/shared-patterns/enums/lambda.enum.d.ts.map +1 -0
- package/dist/esm/shared-patterns/enums/lambda.enum.js +31 -0
- package/dist/esm/shared-patterns/enums/lambda.enum.js.map +1 -0
- package/dist/esm/shared-patterns/errors/error-factory.d.ts +150 -0
- package/dist/esm/shared-patterns/errors/error-factory.d.ts.map +1 -0
- package/dist/esm/shared-patterns/errors/error-factory.js +254 -0
- package/dist/esm/shared-patterns/errors/error-factory.js.map +1 -0
- package/dist/esm/shared-patterns/exceptions/base/error-classification-enums.d.ts +118 -0
- package/dist/esm/shared-patterns/exceptions/base/error-classification-enums.d.ts.map +1 -0
- package/dist/esm/shared-patterns/exceptions/base/error-classification-enums.js +108 -0
- package/dist/esm/shared-patterns/exceptions/base/error-classification-enums.js.map +1 -0
- package/dist/esm/shared-patterns/exceptions/base/error-classifier.d.ts +23 -0
- package/dist/esm/shared-patterns/exceptions/base/error-classifier.d.ts.map +1 -0
- package/dist/esm/shared-patterns/exceptions/base/error-classifier.js +161 -0
- package/dist/esm/shared-patterns/exceptions/base/error-classifier.js.map +1 -0
- package/dist/esm/shared-patterns/exceptions/index.d.ts +3 -0
- package/dist/esm/shared-patterns/exceptions/index.d.ts.map +1 -0
- package/dist/esm/shared-patterns/exceptions/index.js +6 -0
- package/dist/esm/shared-patterns/exceptions/index.js.map +1 -0
- package/dist/esm/shared-patterns/functions/crypto.functions.d.ts +16 -0
- package/dist/esm/shared-patterns/functions/crypto.functions.d.ts.map +1 -0
- package/dist/esm/shared-patterns/functions/crypto.functions.js +67 -0
- package/dist/esm/shared-patterns/functions/crypto.functions.js.map +1 -0
- package/dist/esm/shared-patterns/functions/helper.functions.d.ts +10 -0
- package/dist/esm/shared-patterns/functions/helper.functions.d.ts.map +1 -0
- package/dist/esm/shared-patterns/functions/helper.functions.js +32 -0
- package/dist/esm/shared-patterns/functions/helper.functions.js.map +1 -0
- package/dist/esm/shared-patterns/functions/index.d.ts +4 -0
- package/dist/esm/shared-patterns/functions/index.d.ts.map +1 -0
- package/dist/esm/shared-patterns/functions/index.js +5 -0
- package/dist/esm/shared-patterns/functions/index.js.map +1 -0
- package/dist/esm/shared-patterns/functions/request.functions.d.ts +14 -0
- package/dist/esm/shared-patterns/functions/request.functions.d.ts.map +1 -0
- package/dist/esm/shared-patterns/functions/request.functions.js +61 -0
- package/dist/esm/shared-patterns/functions/request.functions.js.map +1 -0
- package/dist/esm/shared-patterns/index.d.ts +15 -0
- package/dist/esm/shared-patterns/index.d.ts.map +1 -0
- package/dist/esm/shared-patterns/index.js +28 -0
- package/dist/esm/shared-patterns/index.js.map +1 -0
- package/dist/esm/shared-patterns/interfaces/index.d.ts +3 -0
- package/dist/esm/shared-patterns/interfaces/index.d.ts.map +1 -0
- package/dist/esm/shared-patterns/interfaces/index.js +3 -0
- package/dist/esm/shared-patterns/interfaces/index.js.map +1 -0
- package/dist/esm/shared-patterns/interfaces/request.interface.d.ts +21 -0
- package/dist/esm/shared-patterns/interfaces/request.interface.d.ts.map +1 -0
- package/dist/esm/shared-patterns/interfaces/request.interface.js +11 -0
- package/dist/esm/shared-patterns/interfaces/request.interface.js.map +1 -0
- package/dist/esm/shared-patterns/interfaces/stripe-payment-intent-metadata.interface.d.ts +9 -0
- package/dist/esm/shared-patterns/interfaces/stripe-payment-intent-metadata.interface.d.ts.map +1 -0
- package/dist/esm/shared-patterns/interfaces/stripe-payment-intent-metadata.interface.js +2 -0
- package/dist/esm/shared-patterns/interfaces/stripe-payment-intent-metadata.interface.js.map +1 -0
- package/dist/esm/shared-patterns/orchestrators/base-orchestrator.d.ts +90 -0
- package/dist/esm/shared-patterns/orchestrators/base-orchestrator.d.ts.map +1 -0
- package/dist/esm/shared-patterns/orchestrators/base-orchestrator.js +116 -0
- package/dist/esm/shared-patterns/orchestrators/base-orchestrator.js.map +1 -0
- package/dist/esm/shared-patterns/orchestrators/base-workflow.d.ts +50 -0
- package/dist/esm/shared-patterns/orchestrators/base-workflow.d.ts.map +1 -0
- package/dist/esm/shared-patterns/orchestrators/base-workflow.js +64 -0
- package/dist/esm/shared-patterns/orchestrators/base-workflow.js.map +1 -0
- package/dist/esm/shared-patterns/orchestrators/index.d.ts +26 -0
- package/dist/esm/shared-patterns/orchestrators/index.d.ts.map +1 -0
- package/dist/esm/shared-patterns/orchestrators/index.js +30 -0
- package/dist/esm/shared-patterns/orchestrators/index.js.map +1 -0
- package/dist/esm/shared-patterns/utils/error-message.utils.d.ts +175 -0
- package/dist/esm/shared-patterns/utils/error-message.utils.d.ts.map +1 -0
- package/dist/esm/shared-patterns/utils/error-message.utils.js +244 -0
- package/dist/esm/shared-patterns/utils/error-message.utils.js.map +1 -0
- package/dist/esm/shared-patterns/utils/index.d.ts +3 -0
- package/dist/esm/shared-patterns/utils/index.d.ts.map +1 -0
- package/dist/esm/shared-patterns/utils/index.js +4 -0
- package/dist/esm/shared-patterns/utils/index.js.map +1 -0
- package/dist/esm/shared-patterns/utils/validation.utils.d.ts +49 -0
- package/dist/esm/shared-patterns/utils/validation.utils.d.ts.map +1 -0
- package/dist/esm/shared-patterns/utils/validation.utils.js +70 -0
- package/dist/esm/shared-patterns/utils/validation.utils.js.map +1 -0
- package/package.json +2 -25
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PERS Validation Utilities
|
|
3
|
+
*
|
|
4
|
+
* Centralized validation functions for consistent data validation
|
|
5
|
+
* across all PERS backend modules and domains.
|
|
6
|
+
*/
|
|
7
|
+
/**
|
|
8
|
+
* Validates email format according to RFC standards
|
|
9
|
+
*
|
|
10
|
+
* Features:
|
|
11
|
+
* - RFC-compliant email regex pattern
|
|
12
|
+
* - RFC 5321 length limit enforcement (254 characters)
|
|
13
|
+
* - Performance optimized with length check first
|
|
14
|
+
* - DoS protection against extremely long strings
|
|
15
|
+
*
|
|
16
|
+
* @param email - Email address to validate
|
|
17
|
+
* @returns true if email is valid, false otherwise
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* ```typescript
|
|
21
|
+
* isValidEmail('user@example.com'); // true
|
|
22
|
+
* isValidEmail('invalid-email'); // false
|
|
23
|
+
* isValidEmail('a'.repeat(300) + '@example.com'); // false (too long)
|
|
24
|
+
* ```
|
|
25
|
+
*/
|
|
26
|
+
export declare function isValidEmail(email: string): boolean;
|
|
27
|
+
/**
|
|
28
|
+
* Validates wallet address format
|
|
29
|
+
*
|
|
30
|
+
* @param address - Wallet address to validate
|
|
31
|
+
* @returns true if address format is valid
|
|
32
|
+
*/
|
|
33
|
+
export declare function isValidWalletAddress(address: string): boolean;
|
|
34
|
+
/**
|
|
35
|
+
* Validates that a string is not empty and meets minimum length requirements
|
|
36
|
+
*
|
|
37
|
+
* @param value - String to validate
|
|
38
|
+
* @param minLength - Minimum required length (default: 1)
|
|
39
|
+
* @returns true if string meets requirements
|
|
40
|
+
*/
|
|
41
|
+
export declare function isValidNonEmptyString(value: string, minLength?: number): boolean;
|
|
42
|
+
/**
|
|
43
|
+
* Validates UUID format (v4)
|
|
44
|
+
*
|
|
45
|
+
* @param uuid - UUID string to validate
|
|
46
|
+
* @returns true if UUID format is valid
|
|
47
|
+
*/
|
|
48
|
+
export declare function isValidUuid(uuid: string): boolean;
|
|
49
|
+
//# sourceMappingURL=validation.utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.utils.d.ts","sourceRoot":"","sources":["../../../../src/shared-patterns/utils/validation.utils.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CASnD;AAED;;;;;GAKG;AACH,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAM7D;AAED;;;;;;GAMG;AACH,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,GAAE,MAAU,GAAG,OAAO,CAEnF;AAED;;;;;GAKG;AACH,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAKjD"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* PERS Validation Utilities
|
|
4
|
+
*
|
|
5
|
+
* Centralized validation functions for consistent data validation
|
|
6
|
+
* across all PERS backend modules and domains.
|
|
7
|
+
*/
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.isValidEmail = isValidEmail;
|
|
10
|
+
exports.isValidWalletAddress = isValidWalletAddress;
|
|
11
|
+
exports.isValidNonEmptyString = isValidNonEmptyString;
|
|
12
|
+
exports.isValidUuid = isValidUuid;
|
|
13
|
+
/**
|
|
14
|
+
* Validates email format according to RFC standards
|
|
15
|
+
*
|
|
16
|
+
* Features:
|
|
17
|
+
* - RFC-compliant email regex pattern
|
|
18
|
+
* - RFC 5321 length limit enforcement (254 characters)
|
|
19
|
+
* - Performance optimized with length check first
|
|
20
|
+
* - DoS protection against extremely long strings
|
|
21
|
+
*
|
|
22
|
+
* @param email - Email address to validate
|
|
23
|
+
* @returns true if email is valid, false otherwise
|
|
24
|
+
*
|
|
25
|
+
* @example
|
|
26
|
+
* ```typescript
|
|
27
|
+
* isValidEmail('user@example.com'); // true
|
|
28
|
+
* isValidEmail('invalid-email'); // false
|
|
29
|
+
* isValidEmail('a'.repeat(300) + '@example.com'); // false (too long)
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
function isValidEmail(email) {
|
|
33
|
+
// Quick length check first for performance and RFC 5321 compliance
|
|
34
|
+
if (!email || email.length > 254) {
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
// RFC-compliant email regex pattern
|
|
38
|
+
const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
|
|
39
|
+
return emailRegex.test(email);
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Validates wallet address format
|
|
43
|
+
*
|
|
44
|
+
* @param address - Wallet address to validate
|
|
45
|
+
* @returns true if address format is valid
|
|
46
|
+
*/
|
|
47
|
+
function isValidWalletAddress(address) {
|
|
48
|
+
if (!address)
|
|
49
|
+
return false;
|
|
50
|
+
// Ethereum address format: 0x followed by 40 hexadecimal characters
|
|
51
|
+
const ethereumAddressRegex = /^0x[a-fA-F0-9]{40}$/;
|
|
52
|
+
return ethereumAddressRegex.test(address);
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Validates that a string is not empty and meets minimum length requirements
|
|
56
|
+
*
|
|
57
|
+
* @param value - String to validate
|
|
58
|
+
* @param minLength - Minimum required length (default: 1)
|
|
59
|
+
* @returns true if string meets requirements
|
|
60
|
+
*/
|
|
61
|
+
function isValidNonEmptyString(value, minLength = 1) {
|
|
62
|
+
return typeof value === 'string' && value.trim().length >= minLength;
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Validates UUID format (v4)
|
|
66
|
+
*
|
|
67
|
+
* @param uuid - UUID string to validate
|
|
68
|
+
* @returns true if UUID format is valid
|
|
69
|
+
*/
|
|
70
|
+
function isValidUuid(uuid) {
|
|
71
|
+
if (!uuid)
|
|
72
|
+
return false;
|
|
73
|
+
const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-4[0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;
|
|
74
|
+
return uuidRegex.test(uuid);
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=validation.utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.utils.js","sourceRoot":"","sources":["../../../../src/shared-patterns/utils/validation.utils.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;AAqBH,oCASC;AAQD,oDAMC;AASD,sDAEC;AAQD,kCAKC;AAlED;;;;;;;;;;;;;;;;;;GAkBG;AACH,SAAgB,YAAY,CAAC,KAAa;IACxC,mEAAmE;IACnE,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC;QACjC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,oCAAoC;IACpC,MAAM,UAAU,GAAG,4BAA4B,CAAC;IAChD,OAAO,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AAChC,CAAC;AAED;;;;;GAKG;AACH,SAAgB,oBAAoB,CAAC,OAAe;IAClD,IAAI,CAAC,OAAO;QAAE,OAAO,KAAK,CAAC;IAE3B,oEAAoE;IACpE,MAAM,oBAAoB,GAAG,qBAAqB,CAAC;IACnD,OAAO,oBAAoB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;AAC5C,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,qBAAqB,CAAC,KAAa,EAAE,YAAoB,CAAC;IACxE,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC,MAAM,IAAI,SAAS,CAAC;AACvE,CAAC;AAED;;;;;GAKG;AACH,SAAgB,WAAW,CAAC,IAAY;IACtC,IAAI,CAAC,IAAI;QAAE,OAAO,KAAK,CAAC;IAExB,MAAM,SAAS,GAAG,wEAAwE,CAAC;IAC3F,OAAO,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC9B,CAAC"}
|
package/dist/esm/index.d.ts
CHANGED
|
@@ -3,4 +3,6 @@ export type * from './shared-lib/interfaces';
|
|
|
3
3
|
export type * from './shared-lib/types';
|
|
4
4
|
export type * from './shared-lib/dto';
|
|
5
5
|
export type * from './shared-lib/errors';
|
|
6
|
+
export * from './shared-lib/errors';
|
|
7
|
+
export * from './shared-patterns';
|
|
6
8
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/esm/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAIA,cAAc,mBAAmB,CAAC;AAClC,mBAAmB,yBAAyB,CAAC;AAC7C,mBAAmB,oBAAoB,CAAC;AACxC,mBAAmB,kBAAkB,CAAC;AAGtC,mBAAmB,qBAAqB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAIA,cAAc,mBAAmB,CAAC;AAClC,mBAAmB,yBAAyB,CAAC;AAC7C,mBAAmB,oBAAoB,CAAC;AACxC,mBAAmB,kBAAkB,CAAC;AAGtC,mBAAmB,qBAAqB,CAAC;AACzC,cAAc,qBAAqB,CAAC;AAGpC,cAAc,mBAAmB,CAAC"}
|
package/dist/esm/index.js
CHANGED
|
@@ -2,6 +2,9 @@
|
|
|
2
2
|
// 🌐 PUBLIC: Safe for external consumption - contains only DTOs, interfaces, types, and enums
|
|
3
3
|
// Core domain contracts
|
|
4
4
|
export * from './shared-lib/enum';
|
|
5
|
-
|
|
6
|
-
//
|
|
5
|
+
export * from './shared-lib/errors'; // Export actual error classes and functions
|
|
6
|
+
// Shared patterns (architecture components)
|
|
7
|
+
export * from './shared-patterns';
|
|
8
|
+
// Note: This library contains both pure data contracts and internal architecture patterns
|
|
9
|
+
// External consumers should only use the type exports and documented public APIs
|
|
7
10
|
//# sourceMappingURL=index.js.map
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,4EAA4E;AAC5E,8FAA8F;AAE9F,wBAAwB;AACxB,cAAc,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,4EAA4E;AAC5E,8FAA8F;AAE9F,wBAAwB;AACxB,cAAc,mBAAmB,CAAC;AAOlC,cAAc,qBAAqB,CAAC,CAAC,4CAA4C;AAEjF,4CAA4C;AAC5C,cAAc,mBAAmB,CAAC;AAElC,0FAA0F;AAC1F,iFAAiF"}
|
|
@@ -9,9 +9,8 @@ export declare class SessionAuthRequestDTO {
|
|
|
9
9
|
export declare class RefreshTokenRequestDTO {
|
|
10
10
|
refreshToken: string;
|
|
11
11
|
}
|
|
12
|
-
export declare class SessionAuthResponseDTO {
|
|
12
|
+
export declare class SessionAuthResponseDTO extends RefreshTokenRequestDTO {
|
|
13
13
|
accessToken: string;
|
|
14
|
-
refreshToken: string;
|
|
15
14
|
}
|
|
16
15
|
export declare class SessionAuthContextResponseDTO extends SessionAuthResponseDTO {
|
|
17
16
|
admin?: AdminDTO;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.dto.d.ts","sourceRoot":"","sources":["../../../../src/shared-lib/dto/auth.dto.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,OAAO,EAAG,WAAW,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,qBAAa,qBAAqB;IAQ9B,SAAS,EAAE,MAAM,CAAM;IAQvB,QAAQ,CAAC,EAAE,gBAAgB,CAAyB;CACvD;AAGD,qBAAa,sBAAsB;IAO/B,YAAY,EAAE,MAAM,CAAM;CAC7B;AAGD,qBAAa,sBAAsB;
|
|
1
|
+
{"version":3,"file":"auth.dto.d.ts","sourceRoot":"","sources":["../../../../src/shared-lib/dto/auth.dto.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,OAAO,EAAG,WAAW,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,qBAAa,qBAAqB;IAQ9B,SAAS,EAAE,MAAM,CAAM;IAQvB,QAAQ,CAAC,EAAE,gBAAgB,CAAyB;CACvD;AAGD,qBAAa,sBAAsB;IAO/B,YAAY,EAAE,MAAM,CAAM;CAC7B;AAGD,qBAAa,sBAAuB,SAAQ,sBAAsB;IAQ9D,WAAW,EAAE,MAAM,CAAM;CAUxB;AAEL,qBAAa,6BAA8B,SAAQ,sBAAsB;IAKrE,KAAK,CAAC,EAAE,QAAQ,CAAC;IAMjB,IAAI,CAAC,EAAE,OAAO,CAAC;IAMf,QAAQ,CAAC,EAAE,WAAW,CAAC;IAQvB,QAAQ,EAAE,gBAAgB,CAAyB;CACtD"}
|
|
@@ -43,9 +43,8 @@ __decorate([
|
|
|
43
43
|
IsNotEmpty(),
|
|
44
44
|
IsString()
|
|
45
45
|
], RefreshTokenRequestDTO.prototype, "refreshToken", void 0);
|
|
46
|
-
export class SessionAuthResponseDTO {
|
|
46
|
+
export class SessionAuthResponseDTO extends RefreshTokenRequestDTO {
|
|
47
47
|
accessToken = '';
|
|
48
|
-
refreshToken = '';
|
|
49
48
|
}
|
|
50
49
|
__decorate([
|
|
51
50
|
ApiProperty({
|
|
@@ -54,13 +53,6 @@ __decorate([
|
|
|
54
53
|
IsNotEmpty(),
|
|
55
54
|
IsString()
|
|
56
55
|
], SessionAuthResponseDTO.prototype, "accessToken", void 0);
|
|
57
|
-
__decorate([
|
|
58
|
-
ApiProperty({
|
|
59
|
-
description: 'JWT refresh token this token is used to get a new access token when the current one expires. It is valid for 1 day.',
|
|
60
|
-
}),
|
|
61
|
-
IsNotEmpty(),
|
|
62
|
-
IsString()
|
|
63
|
-
], SessionAuthResponseDTO.prototype, "refreshToken", void 0);
|
|
64
56
|
export class SessionAuthContextResponseDTO extends SessionAuthResponseDTO {
|
|
65
57
|
admin;
|
|
66
58
|
user;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.dto.js","sourceRoot":"","sources":["../../../../src/shared-lib/dto/auth.dto.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,OAAO,EAAG,WAAW,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,MAAM,OAAO,qBAAqB;IAQ9B,SAAS,GAAW,EAAE,CAAC;IAQvB,AADA,4BAA4B;IAC5B,QAAQ,GAAsB,gBAAgB,CAAC,IAAI,CAAC;CACvD;AATG;IAPC,WAAW,CAAC;QACT,WAAW,EAAE,qEAAqE;QAClF,OAAO,EAAE,yCAAyC;QAClD,IAAI,EAAE,MAAM;KACf,CAAC;IACD,UAAU,EAAE;IACZ,QAAQ,EAAE;wDACY;AAQvB;IANC,mBAAmB,CAAC;QACjB,WAAW,EAAE,iFAAiF;QAC9F,0BAA0B;QAC1B,IAAI,EAAE,gBAAgB;KACzB,CAAC;IACF,4BAA4B;uDACwB;AAIxD,MAAM,OAAO,sBAAsB;IAO/B,YAAY,GAAW,EAAE,CAAC;CAC7B;AADG;IANC,WAAW,CAAC;QACT,WAAW,EAAE,eAAe;QAC5B,OAAO,EAAE,sJAAsJ;KAClK,CAAC;IACD,UAAU,EAAE;IACZ,QAAQ,EAAE;4DACe;AAI9B,MAAM,OAAO,sBAAsB;
|
|
1
|
+
{"version":3,"file":"auth.dto.js","sourceRoot":"","sources":["../../../../src/shared-lib/dto/auth.dto.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,OAAO,EAAG,WAAW,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,MAAM,OAAO,qBAAqB;IAQ9B,SAAS,GAAW,EAAE,CAAC;IAQvB,AADA,4BAA4B;IAC5B,QAAQ,GAAsB,gBAAgB,CAAC,IAAI,CAAC;CACvD;AATG;IAPC,WAAW,CAAC;QACT,WAAW,EAAE,qEAAqE;QAClF,OAAO,EAAE,yCAAyC;QAClD,IAAI,EAAE,MAAM;KACf,CAAC;IACD,UAAU,EAAE;IACZ,QAAQ,EAAE;wDACY;AAQvB;IANC,mBAAmB,CAAC;QACjB,WAAW,EAAE,iFAAiF;QAC9F,0BAA0B;QAC1B,IAAI,EAAE,gBAAgB;KACzB,CAAC;IACF,4BAA4B;uDACwB;AAIxD,MAAM,OAAO,sBAAsB;IAO/B,YAAY,GAAW,EAAE,CAAC;CAC7B;AADG;IANC,WAAW,CAAC;QACT,WAAW,EAAE,eAAe;QAC5B,OAAO,EAAE,sJAAsJ;KAClK,CAAC;IACD,UAAU,EAAE;IACZ,QAAQ,EAAE;4DACe;AAI9B,MAAM,OAAO,sBAAuB,SAAQ,sBAAsB;IAQ9D,WAAW,GAAW,EAAE,CAAC;CAUxB;AAVD;IAPC,WAAW,CACR;QACI,WAAW,EAAE,uKAAuK;KACvL,CACJ;IACA,UAAU,EAAE;IACZ,QAAQ,EAAE;2DACc;AAY7B,MAAM,OAAO,6BAA8B,SAAQ,sBAAsB;IAKrE,KAAK,CAAY;IAMjB,IAAI,CAAW;IAMf,QAAQ,CAAe;IAQvB,AADA,4BAA4B;IAC5B,QAAQ,GAAqB,gBAAgB,CAAC,IAAI,CAAC;CACtD;AArBG;IAJC,mBAAmB,CAAC;QACjB,WAAW,EAAE,yCAAyC;QACtD,IAAI,EAAE,GAAG,EAAE,CAAC,QAAQ;KACvB,CAAC;4DACe;AAMjB;IAJC,mBAAmB,CAAC;QACjB,WAAW,EAAE,uCAAuC;QACpD,IAAI,EAAE,GAAG,EAAE,CAAC,OAAO;KACtB,CAAC;2DACa;AAMf;IAJC,mBAAmB,CAAC;QACjB,WAAW,EAAE,+CAA+C;QAC5D,IAAI,EAAE,GAAG,EAAE,CAAC,WAAW;KAC1B,CAAC;+DACqB;AAQvB;IANC,WAAW,CAAC;QACT,WAAW,EAAE,iFAAiF;QAC9F,0BAA0B;QAC1B,IAAI,EAAE,gBAAgB;KACzB,CAAC;IACF,4BAA4B;+DACuB"}
|
|
@@ -40,15 +40,171 @@ export declare enum ErrorCategory {
|
|
|
40
40
|
}
|
|
41
41
|
/**
|
|
42
42
|
* Structured error object for classification
|
|
43
|
+
* Follows RFC 7807 (Problem Details for HTTP APIs) with extensions
|
|
43
44
|
*/
|
|
44
45
|
export interface StructuredError {
|
|
46
|
+
/** HTTP status code as number (industry standard) */
|
|
47
|
+
status: number;
|
|
48
|
+
/** Human-readable summary of the error type */
|
|
49
|
+
title: string;
|
|
50
|
+
/** Human-readable explanation specific to this occurrence */
|
|
51
|
+
detail: string;
|
|
52
|
+
/** Common error message field (industry standard) - usually same as detail */
|
|
45
53
|
message: string;
|
|
54
|
+
/** URI reference identifying the problem type (optional) */
|
|
55
|
+
type?: string;
|
|
56
|
+
/** URI reference to this specific error occurrence (optional) */
|
|
57
|
+
instance?: string;
|
|
58
|
+
/** Service-defined error code for programmatic handling */
|
|
46
59
|
code: string;
|
|
47
|
-
|
|
60
|
+
/** Error category for classification and routing */
|
|
48
61
|
category: ErrorCategory;
|
|
62
|
+
/** ISO 8601 timestamp when error occurred */
|
|
63
|
+
timestamp?: string;
|
|
64
|
+
/** Correlation ID for request tracing */
|
|
49
65
|
correlationId?: string;
|
|
66
|
+
/** Additional structured error details */
|
|
50
67
|
details?: Record<string, any>;
|
|
68
|
+
/** User-friendly message safe for end-user display */
|
|
51
69
|
userMessage?: string;
|
|
70
|
+
/** Whether the operation can be safely retried */
|
|
71
|
+
retryable: boolean;
|
|
72
|
+
/** Target property/parameter that caused the error (for validation errors) */
|
|
73
|
+
target?: string;
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Backward compatibility alias
|
|
77
|
+
* @deprecated Use StructuredError instead
|
|
78
|
+
*/
|
|
79
|
+
export type ErrorResponse = StructuredError;
|
|
80
|
+
/**
|
|
81
|
+
* Validation error detail for field-specific errors
|
|
82
|
+
*/
|
|
83
|
+
export interface ValidationErrorDetail {
|
|
84
|
+
field: string;
|
|
85
|
+
code: string;
|
|
86
|
+
message: string;
|
|
87
|
+
rejectedValue?: any;
|
|
88
|
+
constraints?: Record<string, string>;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Category-specific structured error interfaces for type safety
|
|
92
|
+
*/
|
|
93
|
+
/**
|
|
94
|
+
* Validation error for input validation failures
|
|
95
|
+
*/
|
|
96
|
+
export interface ValidationStructuredError extends StructuredError {
|
|
97
|
+
category: ErrorCategory.VALIDATION;
|
|
98
|
+
details: {
|
|
99
|
+
violations: ValidationErrorDetail[];
|
|
100
|
+
[key: string]: any;
|
|
101
|
+
};
|
|
102
|
+
target: string;
|
|
103
|
+
retryable: false;
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Domain rule error for business logic violations
|
|
107
|
+
*/
|
|
108
|
+
export interface DomainRuleStructuredError extends StructuredError {
|
|
109
|
+
category: ErrorCategory.DOMAIN_RULE;
|
|
110
|
+
details?: {
|
|
111
|
+
businessRule: string;
|
|
112
|
+
violatedConstraints?: string[];
|
|
113
|
+
[key: string]: any;
|
|
114
|
+
};
|
|
115
|
+
retryable: false;
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Technical error for application/configuration issues
|
|
119
|
+
*/
|
|
120
|
+
export interface TechnicalStructuredError extends StructuredError {
|
|
121
|
+
category: ErrorCategory.TECHNICAL;
|
|
122
|
+
details?: {
|
|
123
|
+
component?: string;
|
|
124
|
+
operation?: string;
|
|
125
|
+
technicalDetails?: string;
|
|
126
|
+
[key: string]: any;
|
|
127
|
+
};
|
|
52
128
|
retryable: boolean;
|
|
53
129
|
}
|
|
130
|
+
/**
|
|
131
|
+
* Infrastructure error for system/external service failures
|
|
132
|
+
*/
|
|
133
|
+
export interface InfrastructureStructuredError extends StructuredError {
|
|
134
|
+
category: ErrorCategory.INFRASTRUCTURE;
|
|
135
|
+
details?: {
|
|
136
|
+
service?: string;
|
|
137
|
+
endpoint?: string;
|
|
138
|
+
connectionDetails?: string;
|
|
139
|
+
[key: string]: any;
|
|
140
|
+
};
|
|
141
|
+
retryable: true;
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Security error for authentication/authorization failures
|
|
145
|
+
*/
|
|
146
|
+
export interface SecurityStructuredError extends StructuredError {
|
|
147
|
+
category: ErrorCategory.SECURITY;
|
|
148
|
+
details?: {
|
|
149
|
+
securityViolationType?: 'authentication' | 'authorization' | 'suspicious_activity';
|
|
150
|
+
requiredPermissions?: string[];
|
|
151
|
+
attemptedAction?: string;
|
|
152
|
+
[key: string]: any;
|
|
153
|
+
};
|
|
154
|
+
retryable: false;
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Rate limit error for usage limit violations
|
|
158
|
+
*/
|
|
159
|
+
export interface RateLimitStructuredError extends StructuredError {
|
|
160
|
+
category: ErrorCategory.RATE_LIMIT;
|
|
161
|
+
details: {
|
|
162
|
+
limit: number;
|
|
163
|
+
remaining: number;
|
|
164
|
+
resetTime: string;
|
|
165
|
+
window: string;
|
|
166
|
+
[key: string]: any;
|
|
167
|
+
};
|
|
168
|
+
retryable: true;
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* Timeout error for operations that exceed time limits
|
|
172
|
+
*/
|
|
173
|
+
export interface TimeoutStructuredError extends StructuredError {
|
|
174
|
+
category: ErrorCategory.TIMEOUT;
|
|
175
|
+
details?: {
|
|
176
|
+
timeoutMs: number;
|
|
177
|
+
operation?: string;
|
|
178
|
+
elapsedMs?: number;
|
|
179
|
+
[key: string]: any;
|
|
180
|
+
};
|
|
181
|
+
retryable: true;
|
|
182
|
+
}
|
|
183
|
+
/**
|
|
184
|
+
* Unknown error for unclassified failures
|
|
185
|
+
*/
|
|
186
|
+
export interface UnknownStructuredError extends StructuredError {
|
|
187
|
+
category: ErrorCategory.UNKNOWN;
|
|
188
|
+
details?: {
|
|
189
|
+
originalError?: string;
|
|
190
|
+
context?: string;
|
|
191
|
+
[key: string]: any;
|
|
192
|
+
};
|
|
193
|
+
retryable: boolean;
|
|
194
|
+
}
|
|
195
|
+
/**
|
|
196
|
+
* Union type of all category-specific structured errors for type safety
|
|
197
|
+
*/
|
|
198
|
+
export type CategorizedStructuredError = ValidationStructuredError | DomainRuleStructuredError | TechnicalStructuredError | InfrastructureStructuredError | SecurityStructuredError | RateLimitStructuredError | TimeoutStructuredError | UnknownStructuredError;
|
|
199
|
+
/**
|
|
200
|
+
* Type guard functions for category-specific error handling
|
|
201
|
+
*/
|
|
202
|
+
export declare const isValidationError: (error: StructuredError) => error is ValidationStructuredError;
|
|
203
|
+
export declare const isDomainRuleError: (error: StructuredError) => error is DomainRuleStructuredError;
|
|
204
|
+
export declare const isTechnicalError: (error: StructuredError) => error is TechnicalStructuredError;
|
|
205
|
+
export declare const isInfrastructureError: (error: StructuredError) => error is InfrastructureStructuredError;
|
|
206
|
+
export declare const isSecurityError: (error: StructuredError) => error is SecurityStructuredError;
|
|
207
|
+
export declare const isRateLimitError: (error: StructuredError) => error is RateLimitStructuredError;
|
|
208
|
+
export declare const isTimeoutError: (error: StructuredError) => error is TimeoutStructuredError;
|
|
209
|
+
export declare const isUnknownError: (error: StructuredError) => error is UnknownStructuredError;
|
|
54
210
|
//# sourceMappingURL=error-classification-enums.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"error-classification-enums.d.ts","sourceRoot":"","sources":["../../../../../src/shared-lib/errors/base/error-classification-enums.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,oBAAY,aAAa;IACvB;;OAEG;IACH,UAAU,eAAe;IAEzB;;OAEG;IACH,WAAW,gBAAgB;IAE3B;;OAEG;IACH,SAAS,cAAc;IAEvB;;OAEG;IACH,cAAc,mBAAmB;IAEjC;;OAEG;IACH,QAAQ,aAAa;IAErB;;OAEG;IACH,UAAU,eAAe;IAEzB;;OAEG;IACH,OAAO,YAAY;IAEnB;;OAEG;IACH,OAAO,YAAY;CACpB;AAED
|
|
1
|
+
{"version":3,"file":"error-classification-enums.d.ts","sourceRoot":"","sources":["../../../../../src/shared-lib/errors/base/error-classification-enums.ts"],"names":[],"mappings":"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"}
|
|
@@ -39,4 +39,15 @@ export var ErrorCategory;
|
|
|
39
39
|
*/
|
|
40
40
|
ErrorCategory["UNKNOWN"] = "UNKNOWN";
|
|
41
41
|
})(ErrorCategory || (ErrorCategory = {}));
|
|
42
|
+
/**
|
|
43
|
+
* Type guard functions for category-specific error handling
|
|
44
|
+
*/
|
|
45
|
+
export const isValidationError = (error) => error.category === ErrorCategory.VALIDATION;
|
|
46
|
+
export const isDomainRuleError = (error) => error.category === ErrorCategory.DOMAIN_RULE;
|
|
47
|
+
export const isTechnicalError = (error) => error.category === ErrorCategory.TECHNICAL;
|
|
48
|
+
export const isInfrastructureError = (error) => error.category === ErrorCategory.INFRASTRUCTURE;
|
|
49
|
+
export const isSecurityError = (error) => error.category === ErrorCategory.SECURITY;
|
|
50
|
+
export const isRateLimitError = (error) => error.category === ErrorCategory.RATE_LIMIT;
|
|
51
|
+
export const isTimeoutError = (error) => error.category === ErrorCategory.TIMEOUT;
|
|
52
|
+
export const isUnknownError = (error) => error.category === ErrorCategory.UNKNOWN;
|
|
42
53
|
//# sourceMappingURL=error-classification-enums.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"error-classification-enums.js","sourceRoot":"","sources":["../../../../../src/shared-lib/errors/base/error-classification-enums.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,MAAM,CAAN,IAAY,aAwCX;AAxCD,WAAY,aAAa;IACvB;;OAEG;IACH,0CAAyB,CAAA;IAEzB;;OAEG;IACH,4CAA2B,CAAA;IAE3B;;OAEG;IACH,wCAAuB,CAAA;IAEvB;;OAEG;IACH,kDAAiC,CAAA;IAEjC;;OAEG;IACH,sCAAqB,CAAA;IAErB;;OAEG;IACH,0CAAyB,CAAA;IAEzB;;OAEG;IACH,oCAAmB,CAAA;IAEnB;;OAEG;IACH,oCAAmB,CAAA;AACrB,CAAC,EAxCW,aAAa,KAAb,aAAa,QAwCxB"}
|
|
1
|
+
{"version":3,"file":"error-classification-enums.js","sourceRoot":"","sources":["../../../../../src/shared-lib/errors/base/error-classification-enums.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,MAAM,CAAN,IAAY,aAwCX;AAxCD,WAAY,aAAa;IACvB;;OAEG;IACH,0CAAyB,CAAA;IAEzB;;OAEG;IACH,4CAA2B,CAAA;IAE3B;;OAEG;IACH,wCAAuB,CAAA;IAEvB;;OAEG;IACH,kDAAiC,CAAA;IAEjC;;OAEG;IACH,sCAAqB,CAAA;IAErB;;OAEG;IACH,0CAAyB,CAAA;IAEzB;;OAEG;IACH,oCAAmB,CAAA;IAEnB;;OAEG;IACH,oCAAmB,CAAA;AACrB,CAAC,EAxCW,aAAa,KAAb,aAAa,QAwCxB;AAoMD;;GAEG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,KAAsB,EAAsC,EAAE,CAC9F,KAAK,CAAC,QAAQ,KAAK,aAAa,CAAC,UAAU,CAAC;AAE9C,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,KAAsB,EAAsC,EAAE,CAC9F,KAAK,CAAC,QAAQ,KAAK,aAAa,CAAC,WAAW,CAAC;AAE/C,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,KAAsB,EAAqC,EAAE,CAC5F,KAAK,CAAC,QAAQ,KAAK,aAAa,CAAC,SAAS,CAAC;AAE7C,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,KAAsB,EAA0C,EAAE,CACtG,KAAK,CAAC,QAAQ,KAAK,aAAa,CAAC,cAAc,CAAC;AAElD,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,KAAsB,EAAoC,EAAE,CAC1F,KAAK,CAAC,QAAQ,KAAK,aAAa,CAAC,QAAQ,CAAC;AAE5C,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,KAAsB,EAAqC,EAAE,CAC5F,KAAK,CAAC,QAAQ,KAAK,aAAa,CAAC,UAAU,CAAC;AAE9C,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,KAAsB,EAAmC,EAAE,CACxF,KAAK,CAAC,QAAQ,KAAK,aAAa,CAAC,OAAO,CAAC;AAE3C,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,KAAsB,EAAmC,EAAE,CACxF,KAAK,CAAC,QAAQ,KAAK,aAAa,CAAC,OAAO,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { HttpException, HttpStatus } from '@nestjs/common';
|
|
2
|
+
import { ErrorCategory, StructuredError } from './base/error-classification-enums';
|
|
2
3
|
/**
|
|
3
4
|
* Base class for business logic errors that should be surfaced to clients
|
|
4
5
|
* with meaningful error messages and appropriate HTTP status codes.
|
|
@@ -11,7 +12,9 @@ export declare abstract class BusinessLogicError extends HttpException {
|
|
|
11
12
|
readonly userMessage: string;
|
|
12
13
|
readonly developerMessage: string;
|
|
13
14
|
readonly action?: string;
|
|
14
|
-
|
|
15
|
+
readonly category: ErrorCategory;
|
|
16
|
+
readonly retryable: boolean;
|
|
17
|
+
constructor(errorCode: string, domain: string, userMessage: string, developerMessage: string, httpStatus?: HttpStatus, action?: string, category?: ErrorCategory, retryable?: boolean);
|
|
15
18
|
/**
|
|
16
19
|
* Type guard to check if an error is a business logic error
|
|
17
20
|
*/
|
|
@@ -19,6 +22,57 @@ export declare abstract class BusinessLogicError extends HttpException {
|
|
|
19
22
|
/**
|
|
20
23
|
* Get structured error response for API consumers
|
|
21
24
|
*/
|
|
22
|
-
getStructuredResponse():
|
|
25
|
+
getStructuredResponse(): StructuredError;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Category-specific base error classes for type safety and proper defaults
|
|
29
|
+
*/
|
|
30
|
+
/**
|
|
31
|
+
* Base class for validation errors - input validation failures
|
|
32
|
+
*/
|
|
33
|
+
export declare class ValidationError extends BusinessLogicError {
|
|
34
|
+
constructor(errorCode: string, domain: string, userMessage: string, developerMessage: string, target: string, action?: string);
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Base class for domain rule errors - business logic violations
|
|
38
|
+
*/
|
|
39
|
+
export declare class DomainRuleError extends BusinessLogicError {
|
|
40
|
+
constructor(errorCode: string, domain: string, userMessage: string, developerMessage: string, httpStatus?: HttpStatus, action?: string);
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Base class for technical errors - application/configuration issues
|
|
44
|
+
*/
|
|
45
|
+
export declare class TechnicalError extends BusinessLogicError {
|
|
46
|
+
constructor(errorCode: string, domain: string, userMessage: string, developerMessage: string, httpStatus?: HttpStatus, action?: string, retryable?: boolean);
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Base class for infrastructure errors - system/external service failures
|
|
50
|
+
*/
|
|
51
|
+
export declare class InfrastructureError extends BusinessLogicError {
|
|
52
|
+
constructor(errorCode: string, domain: string, userMessage: string, developerMessage: string, httpStatus?: HttpStatus, action?: string);
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Base class for security errors - authentication/authorization failures
|
|
56
|
+
*/
|
|
57
|
+
export declare class SecurityError extends BusinessLogicError {
|
|
58
|
+
constructor(errorCode: string, domain: string, userMessage: string, developerMessage: string, httpStatus?: HttpStatus, action?: string);
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Base class for rate limit errors - usage limit violations
|
|
62
|
+
*/
|
|
63
|
+
export declare class RateLimitError extends BusinessLogicError {
|
|
64
|
+
constructor(errorCode: string, domain: string, userMessage: string, developerMessage: string, action?: string);
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Base class for timeout errors - operations that exceed time limits
|
|
68
|
+
*/
|
|
69
|
+
export declare class TimeoutError extends BusinessLogicError {
|
|
70
|
+
constructor(errorCode: string, domain: string, userMessage: string, developerMessage: string, httpStatus?: HttpStatus, action?: string);
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Base class for unknown errors - unclassified failures
|
|
74
|
+
*/
|
|
75
|
+
export declare class UnknownError extends BusinessLogicError {
|
|
76
|
+
constructor(errorCode: string, domain: string, userMessage: string, developerMessage: string, httpStatus?: HttpStatus, action?: string, retryable?: boolean);
|
|
23
77
|
}
|
|
24
78
|
//# sourceMappingURL=base-business-error.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-business-error.d.ts","sourceRoot":"","sources":["../../../../src/shared-lib/errors/base-business-error.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"base-business-error.d.ts","sourceRoot":"","sources":["../../../../src/shared-lib/errors/base-business-error.ts"],"names":[],"mappings":"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"}
|
|
@@ -12,16 +12,26 @@ export class BusinessLogicError extends HttpException {
|
|
|
12
12
|
userMessage;
|
|
13
13
|
developerMessage;
|
|
14
14
|
action;
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
category;
|
|
16
|
+
retryable;
|
|
17
|
+
constructor(errorCode, domain, userMessage, developerMessage, httpStatus = HttpStatus.BAD_REQUEST, action, category = ErrorCategory.DOMAIN_RULE, retryable = false) {
|
|
18
|
+
// Create structured response following RFC 7807 with extensions
|
|
17
19
|
const response = {
|
|
20
|
+
// RFC 7807 core fields
|
|
21
|
+
status: httpStatus,
|
|
22
|
+
title: userMessage,
|
|
23
|
+
detail: developerMessage,
|
|
24
|
+
message: userMessage, // Industry standard field
|
|
25
|
+
// Custom extensions
|
|
18
26
|
code: errorCode,
|
|
27
|
+
category: category,
|
|
28
|
+
timestamp: new Date().toISOString(),
|
|
29
|
+
retryable: retryable,
|
|
30
|
+
// Legacy fields for backward compatibility
|
|
19
31
|
domain: domain,
|
|
20
|
-
message: userMessage,
|
|
21
32
|
developerMessage: developerMessage,
|
|
22
33
|
action: action,
|
|
23
|
-
|
|
24
|
-
category: ErrorCategory.DOMAIN_RULE
|
|
34
|
+
userMessage: userMessage
|
|
25
35
|
};
|
|
26
36
|
super(response, httpStatus);
|
|
27
37
|
this.errorCode = errorCode;
|
|
@@ -29,6 +39,8 @@ export class BusinessLogicError extends HttpException {
|
|
|
29
39
|
this.userMessage = userMessage;
|
|
30
40
|
this.developerMessage = developerMessage;
|
|
31
41
|
this.action = action;
|
|
42
|
+
this.category = category;
|
|
43
|
+
this.retryable = retryable;
|
|
32
44
|
this.name = this.constructor.name;
|
|
33
45
|
}
|
|
34
46
|
/**
|
|
@@ -43,14 +55,93 @@ export class BusinessLogicError extends HttpException {
|
|
|
43
55
|
getStructuredResponse() {
|
|
44
56
|
const response = this.getResponse();
|
|
45
57
|
return typeof response === 'object' ? response : {
|
|
46
|
-
|
|
47
|
-
|
|
58
|
+
status: this.getStatus(),
|
|
59
|
+
title: this.userMessage,
|
|
60
|
+
detail: this.developerMessage,
|
|
48
61
|
message: this.userMessage,
|
|
49
|
-
|
|
50
|
-
|
|
62
|
+
code: this.errorCode,
|
|
63
|
+
category: this.category,
|
|
51
64
|
timestamp: new Date().toISOString(),
|
|
52
|
-
|
|
65
|
+
retryable: this.retryable,
|
|
66
|
+
userMessage: this.userMessage,
|
|
67
|
+
details: {
|
|
68
|
+
domain: this.domain,
|
|
69
|
+
action: this.action
|
|
70
|
+
}
|
|
53
71
|
};
|
|
54
72
|
}
|
|
55
73
|
}
|
|
74
|
+
/**
|
|
75
|
+
* Category-specific base error classes for type safety and proper defaults
|
|
76
|
+
*/
|
|
77
|
+
/**
|
|
78
|
+
* Base class for validation errors - input validation failures
|
|
79
|
+
*/
|
|
80
|
+
export class ValidationError extends BusinessLogicError {
|
|
81
|
+
constructor(errorCode, domain, userMessage, developerMessage, target, action) {
|
|
82
|
+
super(errorCode, domain, userMessage, developerMessage, HttpStatus.BAD_REQUEST, action, ErrorCategory.VALIDATION, false // Validation errors are never retryable
|
|
83
|
+
);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Base class for domain rule errors - business logic violations
|
|
88
|
+
*/
|
|
89
|
+
export class DomainRuleError extends BusinessLogicError {
|
|
90
|
+
constructor(errorCode, domain, userMessage, developerMessage, httpStatus = HttpStatus.BAD_REQUEST, action) {
|
|
91
|
+
super(errorCode, domain, userMessage, developerMessage, httpStatus, action, ErrorCategory.DOMAIN_RULE, false // Domain rules don't change on retry
|
|
92
|
+
);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Base class for technical errors - application/configuration issues
|
|
97
|
+
*/
|
|
98
|
+
export class TechnicalError extends BusinessLogicError {
|
|
99
|
+
constructor(errorCode, domain, userMessage, developerMessage, httpStatus = HttpStatus.INTERNAL_SERVER_ERROR, action, retryable = true) {
|
|
100
|
+
super(errorCode, domain, userMessage, developerMessage, httpStatus, action, ErrorCategory.TECHNICAL, retryable);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Base class for infrastructure errors - system/external service failures
|
|
105
|
+
*/
|
|
106
|
+
export class InfrastructureError extends BusinessLogicError {
|
|
107
|
+
constructor(errorCode, domain, userMessage, developerMessage, httpStatus = HttpStatus.SERVICE_UNAVAILABLE, action) {
|
|
108
|
+
super(errorCode, domain, userMessage, developerMessage, httpStatus, action, ErrorCategory.INFRASTRUCTURE, true // Infrastructure issues are typically retryable
|
|
109
|
+
);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Base class for security errors - authentication/authorization failures
|
|
114
|
+
*/
|
|
115
|
+
export class SecurityError extends BusinessLogicError {
|
|
116
|
+
constructor(errorCode, domain, userMessage, developerMessage, httpStatus = HttpStatus.UNAUTHORIZED, action) {
|
|
117
|
+
super(errorCode, domain, userMessage, developerMessage, httpStatus, action, ErrorCategory.SECURITY, false // Security violations are never retryable
|
|
118
|
+
);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Base class for rate limit errors - usage limit violations
|
|
123
|
+
*/
|
|
124
|
+
export class RateLimitError extends BusinessLogicError {
|
|
125
|
+
constructor(errorCode, domain, userMessage, developerMessage, action) {
|
|
126
|
+
super(errorCode, domain, userMessage, developerMessage, HttpStatus.TOO_MANY_REQUESTS, action, ErrorCategory.RATE_LIMIT, true // Can retry after rate limit window
|
|
127
|
+
);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Base class for timeout errors - operations that exceed time limits
|
|
132
|
+
*/
|
|
133
|
+
export class TimeoutError extends BusinessLogicError {
|
|
134
|
+
constructor(errorCode, domain, userMessage, developerMessage, httpStatus = HttpStatus.REQUEST_TIMEOUT, action) {
|
|
135
|
+
super(errorCode, domain, userMessage, developerMessage, httpStatus, action, ErrorCategory.TIMEOUT, true // Timeouts can often be retried
|
|
136
|
+
);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Base class for unknown errors - unclassified failures
|
|
141
|
+
*/
|
|
142
|
+
export class UnknownError extends BusinessLogicError {
|
|
143
|
+
constructor(errorCode, domain, userMessage, developerMessage, httpStatus = HttpStatus.INTERNAL_SERVER_ERROR, action, retryable = false) {
|
|
144
|
+
super(errorCode, domain, userMessage, developerMessage, httpStatus, action, ErrorCategory.UNKNOWN, retryable);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
56
147
|
//# sourceMappingURL=base-business-error.js.map
|