@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,118 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Error Classification Enums and Interfaces
|
|
3
|
+
*
|
|
4
|
+
* This file defines the error categorization system used throughout the application.
|
|
5
|
+
*
|
|
6
|
+
* 🎯 DEVELOPER GUIDANCE:
|
|
7
|
+
*
|
|
8
|
+
* When creating errors, choose the appropriate category:
|
|
9
|
+
*
|
|
10
|
+
* 1. DOMAIN_RULE: Business logic violations
|
|
11
|
+
* → Use BusinessLogicError subclasses (e.g., TokenTypeNotFoundError)
|
|
12
|
+
*
|
|
13
|
+
* 2. TECHNICAL: Application/config issues
|
|
14
|
+
* → Use TechnicalError.withMessage() for meaningful technical errors
|
|
15
|
+
*
|
|
16
|
+
* 3. VALIDATION: Input format/validation failures
|
|
17
|
+
* → Let NestJS validation decorators handle these automatically
|
|
18
|
+
*
|
|
19
|
+
* 4. INFRASTRUCTURE: External system failures
|
|
20
|
+
* → These are usually classified automatically from generic Error() instances
|
|
21
|
+
*
|
|
22
|
+
* 5. SECURITY: Auth/authorization issues
|
|
23
|
+
* → Use NestJS guards and filters for consistent security errors
|
|
24
|
+
*
|
|
25
|
+
* 💡 TIP: Prefer structured errors (BusinessLogicError/TechnicalError) over generic Error()
|
|
26
|
+
* for better user experience and debugging capability.
|
|
27
|
+
*
|
|
28
|
+
* 📊 QUICK REFERENCE TABLE:
|
|
29
|
+
* ┌─────────────────┬─────────────┬─────────────────────────────────────┬───────────┐
|
|
30
|
+
* │ Category │ HTTP Status │ Example │ Retryable │
|
|
31
|
+
* ├─────────────────┼─────────────┼─────────────────────────────────────┼───────────┤
|
|
32
|
+
* │ VALIDATION │ 400 │ "Email format invalid" │ No │
|
|
33
|
+
* │ DOMAIN_RULE │ 422 │ "Insufficient balance" │ No │
|
|
34
|
+
* │ TECHNICAL │ 422 │ "Invalid file format" │ Maybe │
|
|
35
|
+
* │ INFRASTRUCTURE │ 503 │ "Database connection failed" │ Yes │
|
|
36
|
+
* │ SECURITY │ 403 │ "Access denied" │ No │
|
|
37
|
+
* │ RATE_LIMIT │ 429 │ "API rate limit exceeded" │ Yes │
|
|
38
|
+
* │ TIMEOUT │ 504 │ "Request timeout" │ Yes │
|
|
39
|
+
* │ UNKNOWN │ 500 │ Generic Error() instances │ Yes │
|
|
40
|
+
* └─────────────────┴─────────────┴─────────────────────────────────────┴───────────┘
|
|
41
|
+
*/
|
|
42
|
+
/**
|
|
43
|
+
* Error severity levels for prioritization and alerting
|
|
44
|
+
*
|
|
45
|
+
* Determines the urgency of response and escalation procedures:
|
|
46
|
+
* - Monitoring alert thresholds
|
|
47
|
+
* - On-call escalation policies
|
|
48
|
+
* - SLA response times
|
|
49
|
+
* - Business impact assessment
|
|
50
|
+
*/
|
|
51
|
+
export declare enum ErrorSeverity {
|
|
52
|
+
/**
|
|
53
|
+
* Low severity - Minor issues, degraded experience but service functional
|
|
54
|
+
* Examples: Optional feature failures, cosmetic issues, non-critical warnings
|
|
55
|
+
* Response Time: 24-48 hours
|
|
56
|
+
* Escalation: Development team during business hours
|
|
57
|
+
* Business Impact: Minimal
|
|
58
|
+
*/
|
|
59
|
+
LOW = "LOW",
|
|
60
|
+
/**
|
|
61
|
+
* Medium severity - Noticeable issues, some functionality impaired
|
|
62
|
+
* Examples: Performance degradation, secondary feature failures, data sync delays
|
|
63
|
+
* Response Time: 4-8 hours
|
|
64
|
+
* Escalation: Development team within same day
|
|
65
|
+
* Business Impact: Moderate
|
|
66
|
+
*/
|
|
67
|
+
MEDIUM = "MEDIUM",
|
|
68
|
+
/**
|
|
69
|
+
* High severity - Significant issues, core functionality impaired
|
|
70
|
+
* Examples: Payment failures, authentication issues, critical feature outages
|
|
71
|
+
* Response Time: 1-2 hours
|
|
72
|
+
* Escalation: Immediate development team notification
|
|
73
|
+
* Business Impact: High
|
|
74
|
+
*/
|
|
75
|
+
HIGH = "HIGH",
|
|
76
|
+
/**
|
|
77
|
+
* Critical severity - System down, major business impact
|
|
78
|
+
* Examples: Complete service outage, data corruption, security breaches
|
|
79
|
+
* Response Time: Immediate (< 15 minutes)
|
|
80
|
+
* Escalation: Page on-call engineer, notify leadership
|
|
81
|
+
* Business Impact: Severe
|
|
82
|
+
*/
|
|
83
|
+
CRITICAL = "CRITICAL"
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* API error response format including correlation tracking
|
|
87
|
+
*/
|
|
88
|
+
export interface ApiErrorResponse {
|
|
89
|
+
code: string;
|
|
90
|
+
domain: string;
|
|
91
|
+
message: string;
|
|
92
|
+
developerMessage?: string;
|
|
93
|
+
action?: string;
|
|
94
|
+
timestamp: string;
|
|
95
|
+
category: string;
|
|
96
|
+
correlationId: string;
|
|
97
|
+
retryable: boolean;
|
|
98
|
+
severity: ErrorSeverity;
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* HTTP Status codes used by our error classification system
|
|
102
|
+
*
|
|
103
|
+
* Centralized here to maintain consistency across error classification
|
|
104
|
+
* and avoid duplication with NestJS HttpStatus values.
|
|
105
|
+
*/
|
|
106
|
+
export declare enum ErrorHttpStatus {
|
|
107
|
+
BAD_REQUEST = 400,
|
|
108
|
+
UNAUTHORIZED = 401,
|
|
109
|
+
FORBIDDEN = 403,
|
|
110
|
+
NOT_FOUND = 404,
|
|
111
|
+
CONFLICT = 409,
|
|
112
|
+
UNPROCESSABLE_ENTITY = 422,
|
|
113
|
+
TOO_MANY_REQUESTS = 429,
|
|
114
|
+
INTERNAL_SERVER_ERROR = 500,
|
|
115
|
+
SERVICE_UNAVAILABLE = 503,
|
|
116
|
+
GATEWAY_TIMEOUT = 504
|
|
117
|
+
}
|
|
118
|
+
//# sourceMappingURL=error-classification-enums.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error-classification-enums.d.ts","sourceRoot":"","sources":["../../../../../src/shared-patterns/exceptions/base/error-classification-enums.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCG;AAKH;;;;;;;;GAQG;AACH,oBAAY,aAAa;IACvB;;;;;;OAMG;IACH,GAAG,QAAQ;IAEX;;;;;;OAMG;IACH,MAAM,WAAW;IAEjB;;;;;;OAMG;IACH,IAAI,SAAS;IAEb;;;;;;OAMG;IACH,QAAQ,aAAa;CACtB;AAID;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,aAAa,CAAC;CACzB;AAID;;;;;GAKG;AACH,oBAAY,eAAe;IACzB,WAAW,MAAM;IACjB,YAAY,MAAM;IAClB,SAAS,MAAM;IACf,SAAS,MAAM;IACf,QAAQ,MAAM;IACd,oBAAoB,MAAM;IAC1B,iBAAiB,MAAM;IACvB,qBAAqB,MAAM;IAC3B,mBAAmB,MAAM;IACzB,eAAe,MAAM;CACtB"}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Error Classification Enums and Interfaces
|
|
4
|
+
*
|
|
5
|
+
* This file defines the error categorization system used throughout the application.
|
|
6
|
+
*
|
|
7
|
+
* 🎯 DEVELOPER GUIDANCE:
|
|
8
|
+
*
|
|
9
|
+
* When creating errors, choose the appropriate category:
|
|
10
|
+
*
|
|
11
|
+
* 1. DOMAIN_RULE: Business logic violations
|
|
12
|
+
* → Use BusinessLogicError subclasses (e.g., TokenTypeNotFoundError)
|
|
13
|
+
*
|
|
14
|
+
* 2. TECHNICAL: Application/config issues
|
|
15
|
+
* → Use TechnicalError.withMessage() for meaningful technical errors
|
|
16
|
+
*
|
|
17
|
+
* 3. VALIDATION: Input format/validation failures
|
|
18
|
+
* → Let NestJS validation decorators handle these automatically
|
|
19
|
+
*
|
|
20
|
+
* 4. INFRASTRUCTURE: External system failures
|
|
21
|
+
* → These are usually classified automatically from generic Error() instances
|
|
22
|
+
*
|
|
23
|
+
* 5. SECURITY: Auth/authorization issues
|
|
24
|
+
* → Use NestJS guards and filters for consistent security errors
|
|
25
|
+
*
|
|
26
|
+
* 💡 TIP: Prefer structured errors (BusinessLogicError/TechnicalError) over generic Error()
|
|
27
|
+
* for better user experience and debugging capability.
|
|
28
|
+
*
|
|
29
|
+
* 📊 QUICK REFERENCE TABLE:
|
|
30
|
+
* ┌─────────────────┬─────────────┬─────────────────────────────────────┬───────────┐
|
|
31
|
+
* │ Category │ HTTP Status │ Example │ Retryable │
|
|
32
|
+
* ├─────────────────┼─────────────┼─────────────────────────────────────┼───────────┤
|
|
33
|
+
* │ VALIDATION │ 400 │ "Email format invalid" │ No │
|
|
34
|
+
* │ DOMAIN_RULE │ 422 │ "Insufficient balance" │ No │
|
|
35
|
+
* │ TECHNICAL │ 422 │ "Invalid file format" │ Maybe │
|
|
36
|
+
* │ INFRASTRUCTURE │ 503 │ "Database connection failed" │ Yes │
|
|
37
|
+
* │ SECURITY │ 403 │ "Access denied" │ No │
|
|
38
|
+
* │ RATE_LIMIT │ 429 │ "API rate limit exceeded" │ Yes │
|
|
39
|
+
* │ TIMEOUT │ 504 │ "Request timeout" │ Yes │
|
|
40
|
+
* │ UNKNOWN │ 500 │ Generic Error() instances │ Yes │
|
|
41
|
+
* └─────────────────┴─────────────┴─────────────────────────────────────┴───────────┘
|
|
42
|
+
*/
|
|
43
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
44
|
+
exports.ErrorHttpStatus = exports.ErrorSeverity = void 0;
|
|
45
|
+
// Note: ErrorCategory is now imported from @explorins/pers-shared
|
|
46
|
+
// This library contains only the detailed classification enums and interfaces
|
|
47
|
+
/**
|
|
48
|
+
* Error severity levels for prioritization and alerting
|
|
49
|
+
*
|
|
50
|
+
* Determines the urgency of response and escalation procedures:
|
|
51
|
+
* - Monitoring alert thresholds
|
|
52
|
+
* - On-call escalation policies
|
|
53
|
+
* - SLA response times
|
|
54
|
+
* - Business impact assessment
|
|
55
|
+
*/
|
|
56
|
+
var ErrorSeverity;
|
|
57
|
+
(function (ErrorSeverity) {
|
|
58
|
+
/**
|
|
59
|
+
* Low severity - Minor issues, degraded experience but service functional
|
|
60
|
+
* Examples: Optional feature failures, cosmetic issues, non-critical warnings
|
|
61
|
+
* Response Time: 24-48 hours
|
|
62
|
+
* Escalation: Development team during business hours
|
|
63
|
+
* Business Impact: Minimal
|
|
64
|
+
*/
|
|
65
|
+
ErrorSeverity["LOW"] = "LOW";
|
|
66
|
+
/**
|
|
67
|
+
* Medium severity - Noticeable issues, some functionality impaired
|
|
68
|
+
* Examples: Performance degradation, secondary feature failures, data sync delays
|
|
69
|
+
* Response Time: 4-8 hours
|
|
70
|
+
* Escalation: Development team within same day
|
|
71
|
+
* Business Impact: Moderate
|
|
72
|
+
*/
|
|
73
|
+
ErrorSeverity["MEDIUM"] = "MEDIUM";
|
|
74
|
+
/**
|
|
75
|
+
* High severity - Significant issues, core functionality impaired
|
|
76
|
+
* Examples: Payment failures, authentication issues, critical feature outages
|
|
77
|
+
* Response Time: 1-2 hours
|
|
78
|
+
* Escalation: Immediate development team notification
|
|
79
|
+
* Business Impact: High
|
|
80
|
+
*/
|
|
81
|
+
ErrorSeverity["HIGH"] = "HIGH";
|
|
82
|
+
/**
|
|
83
|
+
* Critical severity - System down, major business impact
|
|
84
|
+
* Examples: Complete service outage, data corruption, security breaches
|
|
85
|
+
* Response Time: Immediate (< 15 minutes)
|
|
86
|
+
* Escalation: Page on-call engineer, notify leadership
|
|
87
|
+
* Business Impact: Severe
|
|
88
|
+
*/
|
|
89
|
+
ErrorSeverity["CRITICAL"] = "CRITICAL";
|
|
90
|
+
})(ErrorSeverity || (exports.ErrorSeverity = ErrorSeverity = {}));
|
|
91
|
+
// Note: All interfaces moved to @explorins/pers-shared for proper data contract separation
|
|
92
|
+
/**
|
|
93
|
+
* HTTP Status codes used by our error classification system
|
|
94
|
+
*
|
|
95
|
+
* Centralized here to maintain consistency across error classification
|
|
96
|
+
* and avoid duplication with NestJS HttpStatus values.
|
|
97
|
+
*/
|
|
98
|
+
var ErrorHttpStatus;
|
|
99
|
+
(function (ErrorHttpStatus) {
|
|
100
|
+
ErrorHttpStatus[ErrorHttpStatus["BAD_REQUEST"] = 400] = "BAD_REQUEST";
|
|
101
|
+
ErrorHttpStatus[ErrorHttpStatus["UNAUTHORIZED"] = 401] = "UNAUTHORIZED";
|
|
102
|
+
ErrorHttpStatus[ErrorHttpStatus["FORBIDDEN"] = 403] = "FORBIDDEN";
|
|
103
|
+
ErrorHttpStatus[ErrorHttpStatus["NOT_FOUND"] = 404] = "NOT_FOUND";
|
|
104
|
+
ErrorHttpStatus[ErrorHttpStatus["CONFLICT"] = 409] = "CONFLICT";
|
|
105
|
+
ErrorHttpStatus[ErrorHttpStatus["UNPROCESSABLE_ENTITY"] = 422] = "UNPROCESSABLE_ENTITY";
|
|
106
|
+
ErrorHttpStatus[ErrorHttpStatus["TOO_MANY_REQUESTS"] = 429] = "TOO_MANY_REQUESTS";
|
|
107
|
+
ErrorHttpStatus[ErrorHttpStatus["INTERNAL_SERVER_ERROR"] = 500] = "INTERNAL_SERVER_ERROR";
|
|
108
|
+
ErrorHttpStatus[ErrorHttpStatus["SERVICE_UNAVAILABLE"] = 503] = "SERVICE_UNAVAILABLE";
|
|
109
|
+
ErrorHttpStatus[ErrorHttpStatus["GATEWAY_TIMEOUT"] = 504] = "GATEWAY_TIMEOUT";
|
|
110
|
+
})(ErrorHttpStatus || (exports.ErrorHttpStatus = ErrorHttpStatus = {}));
|
|
111
|
+
//# sourceMappingURL=error-classification-enums.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error-classification-enums.js","sourceRoot":"","sources":["../../../../../src/shared-patterns/exceptions/base/error-classification-enums.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCG;;;AAEH,kEAAkE;AAClE,8EAA8E;AAE9E;;;;;;;;GAQG;AACH,IAAY,aAoCX;AApCD,WAAY,aAAa;IACvB;;;;;;OAMG;IACH,4BAAW,CAAA;IAEX;;;;;;OAMG;IACH,kCAAiB,CAAA;IAEjB;;;;;;OAMG;IACH,8BAAa,CAAA;IAEb;;;;;;OAMG;IACH,sCAAqB,CAAA;AACvB,CAAC,EApCW,aAAa,6BAAb,aAAa,QAoCxB;AAoBD,2FAA2F;AAE3F;;;;;GAKG;AACH,IAAY,eAWX;AAXD,WAAY,eAAe;IACzB,qEAAiB,CAAA;IACjB,uEAAkB,CAAA;IAClB,iEAAe,CAAA;IACf,iEAAe,CAAA;IACf,+DAAc,CAAA;IACd,uFAA0B,CAAA;IAC1B,iFAAuB,CAAA;IACvB,yFAA2B,CAAA;IAC3B,qFAAyB,CAAA;IACzB,6EAAqB,CAAA;AACvB,CAAC,EAXW,eAAe,+BAAf,eAAe,QAW1B"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { StructuredError } from '../../../shared-lib/errors';
|
|
2
|
+
/**
|
|
3
|
+
* Error classification utilities with 3-path decision logic
|
|
4
|
+
*/
|
|
5
|
+
export declare class ErrorClassifier {
|
|
6
|
+
/**
|
|
7
|
+
* Simplified error classification with 3-path logic
|
|
8
|
+
* 1. BusinessLogicError -> Preserve structure (fast path)
|
|
9
|
+
* 2. TechnicalError -> Preserve message (fast path)
|
|
10
|
+
* 3. Everything else -> Security-first fallback
|
|
11
|
+
*/
|
|
12
|
+
static classify(error: any, domain: string): StructuredError;
|
|
13
|
+
/**
|
|
14
|
+
* Determine if an error message is safe to expose to users
|
|
15
|
+
* Uses a balanced approach: block sensitive system data while allowing business messages
|
|
16
|
+
*/
|
|
17
|
+
private static isSafeForUsers;
|
|
18
|
+
/**
|
|
19
|
+
* Convert structured error to HTTP status code
|
|
20
|
+
*/
|
|
21
|
+
static getHttpStatusCode(structuredError: StructuredError): number;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=error-classifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error-classifier.d.ts","sourceRoot":"","sources":["../../../../../src/shared-patterns/exceptions/base/error-classifier.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqC,eAAe,EAAkB,MAAM,4BAA4B,CAAC;AAGhH;;GAEG;AACH,qBAAa,eAAe;IAC1B;;;;;OAKG;IACH,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,GAAG,eAAe;IAyE5D;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAC,cAAc;IAgE7B;;OAEG;IACH,MAAM,CAAC,iBAAiB,CAAC,eAAe,EAAE,eAAe,GAAG,MAAM;CAkBnE"}
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ErrorClassifier = void 0;
|
|
4
|
+
const errors_1 = require("../../../shared-lib/errors");
|
|
5
|
+
const error_classification_enums_1 = require("./error-classification-enums");
|
|
6
|
+
/**
|
|
7
|
+
* Error classification utilities with 3-path decision logic
|
|
8
|
+
*/
|
|
9
|
+
class ErrorClassifier {
|
|
10
|
+
/**
|
|
11
|
+
* Simplified error classification with 3-path logic
|
|
12
|
+
* 1. BusinessLogicError -> Preserve structure (fast path)
|
|
13
|
+
* 2. TechnicalError -> Preserve message (fast path)
|
|
14
|
+
* 3. Everything else -> Security-first fallback
|
|
15
|
+
*/
|
|
16
|
+
static classify(error, domain) {
|
|
17
|
+
// Fast path 1: BusinessLogicError (already structured)
|
|
18
|
+
if (errors_1.BusinessLogicError.isBusinessError(error)) {
|
|
19
|
+
const response = error.getResponse();
|
|
20
|
+
const responseObj = typeof response === 'object' ? response : {};
|
|
21
|
+
return {
|
|
22
|
+
status: 422,
|
|
23
|
+
title: 'Business Rule Violation',
|
|
24
|
+
detail: responseObj.message || error.message,
|
|
25
|
+
message: responseObj.message || error.message,
|
|
26
|
+
code: responseObj.code || 'BUSINESS_ERROR',
|
|
27
|
+
category: errors_1.ErrorCategory.DOMAIN_RULE,
|
|
28
|
+
timestamp: new Date().toISOString(),
|
|
29
|
+
retryable: false,
|
|
30
|
+
userMessage: responseObj.message || error.message
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
// Fast path 2: TechnicalError (preserve meaningful messages)
|
|
34
|
+
if (error instanceof errors_1.TechnicalError) {
|
|
35
|
+
const response = error.getResponse();
|
|
36
|
+
const responseObj = typeof response === 'object' ? response : {};
|
|
37
|
+
return {
|
|
38
|
+
status: 503,
|
|
39
|
+
title: 'Technical Error',
|
|
40
|
+
detail: responseObj.message || error.message,
|
|
41
|
+
message: responseObj.message || error.message,
|
|
42
|
+
code: 'TECHNICAL_ERROR',
|
|
43
|
+
category: errors_1.ErrorCategory.INFRASTRUCTURE,
|
|
44
|
+
timestamp: new Date().toISOString(),
|
|
45
|
+
retryable: true,
|
|
46
|
+
userMessage: responseObj.message || error.message
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
// Fast path 3: HttpExceptions with BUSINESS_LOGIC category (for backward compatibility)
|
|
50
|
+
if (typeof error.getStatus === 'function') {
|
|
51
|
+
const response = error.getResponse ? error.getResponse() : null;
|
|
52
|
+
if (typeof response === 'object' && response?.category === 'BUSINESS_LOGIC') {
|
|
53
|
+
const responseObj = response;
|
|
54
|
+
return {
|
|
55
|
+
status: 422,
|
|
56
|
+
title: 'Business Rule Violation',
|
|
57
|
+
detail: responseObj.message || error.message,
|
|
58
|
+
message: responseObj.message || error.message,
|
|
59
|
+
code: responseObj.code || 'BUSINESS_ERROR',
|
|
60
|
+
category: errors_1.ErrorCategory.DOMAIN_RULE,
|
|
61
|
+
timestamp: new Date().toISOString(),
|
|
62
|
+
retryable: false,
|
|
63
|
+
userMessage: responseObj.message || error.message
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
// Security-first fallback for everything else
|
|
68
|
+
const message = error.message || 'Unknown error';
|
|
69
|
+
// Check if error message is safe to expose to users
|
|
70
|
+
const isSafe = this.isSafeForUsers(message);
|
|
71
|
+
return {
|
|
72
|
+
status: 500,
|
|
73
|
+
title: 'Internal Server Error',
|
|
74
|
+
detail: isSafe ? message : 'An unexpected error occurred',
|
|
75
|
+
message: isSafe ? message : 'Internal server error',
|
|
76
|
+
code: 'INTERNAL_ERROR',
|
|
77
|
+
category: errors_1.ErrorCategory.UNKNOWN,
|
|
78
|
+
timestamp: new Date().toISOString(),
|
|
79
|
+
retryable: true,
|
|
80
|
+
userMessage: isSafe ? message : 'An unexpected error occurred. Please try again.'
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Determine if an error message is safe to expose to users
|
|
85
|
+
* Uses a balanced approach: block sensitive system data while allowing business messages
|
|
86
|
+
*/
|
|
87
|
+
static isSafeForUsers(message) {
|
|
88
|
+
if (!message || message.length < 3 || message.length > 300)
|
|
89
|
+
return false;
|
|
90
|
+
// Allow common business error phrases that are safe for users
|
|
91
|
+
const safeBusinessPatterns = [
|
|
92
|
+
/cannot process payment/i,
|
|
93
|
+
/unable to complete transaction/i,
|
|
94
|
+
/insufficient (balance|funds)/i,
|
|
95
|
+
/user not found/i,
|
|
96
|
+
/token not active/i,
|
|
97
|
+
/wallet not found/i,
|
|
98
|
+
/invalid (amount|address|format)/i,
|
|
99
|
+
/transaction (failed|rejected|expired)/i,
|
|
100
|
+
/account (locked|inactive|suspended)/i,
|
|
101
|
+
/permission denied/i,
|
|
102
|
+
/rate limit exceeded/i,
|
|
103
|
+
/service temporarily unavailable/i
|
|
104
|
+
];
|
|
105
|
+
// If it matches safe business patterns, allow it
|
|
106
|
+
if (safeBusinessPatterns.some(pattern => pattern.test(message))) {
|
|
107
|
+
return true;
|
|
108
|
+
}
|
|
109
|
+
// Block definitely unsafe patterns (system internals and sensitive data)
|
|
110
|
+
const unsafePatterns = [
|
|
111
|
+
// System internals with technical context
|
|
112
|
+
/internal server error/i,
|
|
113
|
+
/database connection (failed|lost|timeout)/i,
|
|
114
|
+
/sql (error|exception|syntax)/i,
|
|
115
|
+
/stack trace|stacktrace/i,
|
|
116
|
+
/undefined (property|method|function)/i,
|
|
117
|
+
/null pointer|reference error/i,
|
|
118
|
+
// Sensitive data indicators
|
|
119
|
+
/secret|password|private.?key|credential/i,
|
|
120
|
+
/jwt.?token|bearer.?token|api.?key/i,
|
|
121
|
+
/localhost|127\.0\.0\.1|192\.168\.|10\.\d+\./i,
|
|
122
|
+
/\.env|config\.json|\.xml|\.yml/i,
|
|
123
|
+
// Technical stack traces and system paths
|
|
124
|
+
/\/var\/|\/etc\/|\/home\/|\/usr\/bin|\/opt\//i,
|
|
125
|
+
/node_modules|package\.json|tsconfig/i,
|
|
126
|
+
/at Object\.|at Function\.|at async/i,
|
|
127
|
+
// Database and system queries
|
|
128
|
+
/SELECT.*FROM|INSERT.*INTO|UPDATE.*SET/i,
|
|
129
|
+
/mongodb|postgresql|redis|elasticsearch/i
|
|
130
|
+
];
|
|
131
|
+
// Block if it matches unsafe patterns
|
|
132
|
+
if (unsafePatterns.some(pattern => pattern.test(message))) {
|
|
133
|
+
return false;
|
|
134
|
+
}
|
|
135
|
+
// For everything else, apply basic safety checks
|
|
136
|
+
// Allow if it looks like a user-friendly business message
|
|
137
|
+
const hasBusinessContext = /\b(user|account|transaction|payment|balance|wallet|token)\b/i.test(message);
|
|
138
|
+
const hasGenericWords = /\b(invalid|missing|required|expired|failed|rejected|denied)\b/i.test(message);
|
|
139
|
+
const noSystemJargon = !/\b(undefined|null|exception|stack|trace|object|function|method|class)\b/i.test(message);
|
|
140
|
+
return (hasBusinessContext || hasGenericWords) && noSystemJargon;
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Convert structured error to HTTP status code
|
|
144
|
+
*/
|
|
145
|
+
static getHttpStatusCode(structuredError) {
|
|
146
|
+
switch (structuredError.category) {
|
|
147
|
+
case errors_1.ErrorCategory.VALIDATION:
|
|
148
|
+
return error_classification_enums_1.ErrorHttpStatus.BAD_REQUEST;
|
|
149
|
+
case errors_1.ErrorCategory.DOMAIN_RULE:
|
|
150
|
+
return error_classification_enums_1.ErrorHttpStatus.UNPROCESSABLE_ENTITY;
|
|
151
|
+
case errors_1.ErrorCategory.SECURITY:
|
|
152
|
+
return error_classification_enums_1.ErrorHttpStatus.FORBIDDEN;
|
|
153
|
+
case errors_1.ErrorCategory.RATE_LIMIT:
|
|
154
|
+
return error_classification_enums_1.ErrorHttpStatus.TOO_MANY_REQUESTS;
|
|
155
|
+
case errors_1.ErrorCategory.TIMEOUT:
|
|
156
|
+
return error_classification_enums_1.ErrorHttpStatus.GATEWAY_TIMEOUT;
|
|
157
|
+
case errors_1.ErrorCategory.INFRASTRUCTURE:
|
|
158
|
+
return error_classification_enums_1.ErrorHttpStatus.SERVICE_UNAVAILABLE;
|
|
159
|
+
default:
|
|
160
|
+
return error_classification_enums_1.ErrorHttpStatus.INTERNAL_SERVER_ERROR;
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
exports.ErrorClassifier = ErrorClassifier;
|
|
165
|
+
//# sourceMappingURL=error-classifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error-classifier.js","sourceRoot":"","sources":["../../../../../src/shared-patterns/exceptions/base/error-classifier.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/shared-patterns/exceptions/index.ts"],"names":[],"mappings":"AACA,cAAc,mCAAmC,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.ErrorClassifier = void 0;
|
|
18
|
+
// Error classification utilities (patterns-specific logic only)
|
|
19
|
+
__exportStar(require("./base/error-classification-enums"), exports);
|
|
20
|
+
var error_classifier_1 = require("./base/error-classifier");
|
|
21
|
+
Object.defineProperty(exports, "ErrorClassifier", { enumerable: true, get: function () { return error_classifier_1.ErrorClassifier; } });
|
|
22
|
+
// Note: All error classes (BusinessLogicError, TechnicalError, domain errors) are exported from @explorins/pers-shared
|
|
23
|
+
// This library only contains error classification logic and patterns
|
|
24
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/shared-patterns/exceptions/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,gEAAgE;AAChE,oEAAkD;AAClD,4DAA0D;AAAjD,mHAAA,eAAe,OAAA;AAExB,uHAAuH;AACvH,qEAAqE"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
type KeyFormat = 'pem';
|
|
2
|
+
type KeyType = 'pkcs1' | 'pkcs8';
|
|
3
|
+
export interface EncryptedDataObject {
|
|
4
|
+
encryptedData: string;
|
|
5
|
+
iv: string;
|
|
6
|
+
authTag: string;
|
|
7
|
+
}
|
|
8
|
+
export declare const hashString: (input: string, maxLength?: number | null, algorithm?: "sha256" | "sha512" | "md5") => string;
|
|
9
|
+
export declare const checkMatching: (plainString: string, hashedString: string) => Promise<any>;
|
|
10
|
+
export declare const hashPassword: (password: string, saltRounds?: number) => Promise<string>;
|
|
11
|
+
export declare const generatePseudoRandomData: (size?: number) => string;
|
|
12
|
+
export declare const generateDecryptedPrivateKey: (privateKey: string, passphrase: string | undefined, keyType?: KeyType, keyFormat?: KeyFormat) => string;
|
|
13
|
+
export declare const encryptData: (data: string, encryptionKey: string) => EncryptedDataObject;
|
|
14
|
+
export declare const decryptData: (encryptedDataObject: EncryptedDataObject, encryptionKey: string) => string;
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=crypto.functions.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"crypto.functions.d.ts","sourceRoot":"","sources":["../../../../src/shared-patterns/functions/crypto.functions.ts"],"names":[],"mappings":"AAKA,KAAK,SAAS,GAAG,KAAK,CAAE;AACxB,KAAK,OAAO,GAAG,OAAO,GAAG,OAAO,CAAC;AAEjC,MAAM,WAAW,mBAAmB;IAChC,aAAa,EAAE,MAAM,CAAC;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,MAAM,CAAC;CACjB;AAEC,eAAO,MAAM,UAAU,GAAI,OAAO,MAAM,EAAE,YAAW,MAAM,GAAG,IAAW,EAAE,YAAW,QAAQ,GAAG,QAAQ,GAAG,KAAgB,KAAG,MAO9H,CAAA;AAED,eAAO,MAAM,aAAa,GAAU,aAAa,MAAM,EAAE,cAAc,MAAM,iBAG5E,CAAA;AAED,eAAO,MAAM,YAAY,GAAU,UAAU,MAAM,EAAE,aAAY,MAA0B,KAAG,OAAO,CAAC,MAAM,CAE3G,CAAA;AAED,eAAO,MAAM,wBAAwB,GAAI,OAAM,MAAW,WAKzD,CAAA;AAED,eAAO,MAAM,2BAA2B,GACpC,YAAY,MAAM,EAClB,YAAY,MAAM,GAAG,SAAS,EAC9B,UAAS,OAAiB,EAC1B,YAAW,SAAiB,KAC7B,MAWJ,CAAA;AAEH,eAAO,MAAM,WAAW,GAAI,MAAM,MAAM,EAAE,eAAe,MAAM,KAAG,mBAmBjE,CAAA;AAED,eAAO,MAAM,WAAW,GAAI,qBAAqB,mBAAmB,EAAE,eAAe,MAAM,KAAG,MAgB7F,CAAA"}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.decryptData = exports.encryptData = exports.generateDecryptedPrivateKey = exports.generatePseudoRandomData = exports.hashPassword = exports.checkMatching = exports.hashString = void 0;
|
|
37
|
+
const crypto = __importStar(require("crypto"));
|
|
38
|
+
const crypto_1 = require("crypto");
|
|
39
|
+
const bcrypt = require('bcryptjs');
|
|
40
|
+
const defaultSaltRounds = 10;
|
|
41
|
+
const hashString = (input, maxLength = null, algorithm = 'sha256') => {
|
|
42
|
+
// Generate a hash of the input string
|
|
43
|
+
let hash = crypto.createHash(algorithm).update(input).digest('hex');
|
|
44
|
+
if (typeof maxLength === 'number' && hash.length > maxLength) {
|
|
45
|
+
hash = hash.substring(0, maxLength);
|
|
46
|
+
}
|
|
47
|
+
return hash;
|
|
48
|
+
};
|
|
49
|
+
exports.hashString = hashString;
|
|
50
|
+
const checkMatching = async (plainString, hashedString) => {
|
|
51
|
+
const match = await bcrypt.compare(plainString, hashedString);
|
|
52
|
+
return match;
|
|
53
|
+
};
|
|
54
|
+
exports.checkMatching = checkMatching;
|
|
55
|
+
const hashPassword = async (password, saltRounds = defaultSaltRounds) => {
|
|
56
|
+
return await bcrypt.hash(password, saltRounds);
|
|
57
|
+
};
|
|
58
|
+
exports.hashPassword = hashPassword;
|
|
59
|
+
const generatePseudoRandomData = (size = 32) => {
|
|
60
|
+
// Convert the byte array into a hexadecimal string
|
|
61
|
+
let salt = (0, crypto_1.randomBytes)(size).toString('hex');
|
|
62
|
+
return salt;
|
|
63
|
+
};
|
|
64
|
+
exports.generatePseudoRandomData = generatePseudoRandomData;
|
|
65
|
+
const generateDecryptedPrivateKey = (privateKey, passphrase, keyType = 'pkcs8', keyFormat = 'pem') => {
|
|
66
|
+
const decryptedPrivateKey = crypto.createPrivateKey({
|
|
67
|
+
key: privateKey,
|
|
68
|
+
format: keyFormat,
|
|
69
|
+
type: keyType,
|
|
70
|
+
passphrase: passphrase,
|
|
71
|
+
});
|
|
72
|
+
return decryptedPrivateKey.export({ format: keyFormat, type: keyType }).toString();
|
|
73
|
+
};
|
|
74
|
+
exports.generateDecryptedPrivateKey = generateDecryptedPrivateKey;
|
|
75
|
+
const encryptData = (data, encryptionKey) => {
|
|
76
|
+
try {
|
|
77
|
+
const key = Buffer.from(encryptionKey, 'hex');
|
|
78
|
+
const iv = crypto.randomBytes(16);
|
|
79
|
+
const cipher = crypto.createCipheriv('aes-256-gcm', key, iv);
|
|
80
|
+
let encryptedData = cipher.update(data, 'utf8', 'hex');
|
|
81
|
+
encryptedData += cipher.final('hex');
|
|
82
|
+
const authTag = cipher.getAuthTag().toString('hex');
|
|
83
|
+
return {
|
|
84
|
+
encryptedData,
|
|
85
|
+
iv: iv.toString('hex'),
|
|
86
|
+
authTag
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
catch (error) {
|
|
90
|
+
throw new Error('Error encrypting data: ' + error.message);
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
exports.encryptData = encryptData;
|
|
94
|
+
const decryptData = (encryptedDataObject, encryptionKey) => {
|
|
95
|
+
try {
|
|
96
|
+
const key = Buffer.from(encryptionKey, 'hex');
|
|
97
|
+
const ivBuffer = Buffer.from(encryptedDataObject.iv, 'hex');
|
|
98
|
+
const authTagBuffer = Buffer.from(encryptedDataObject.authTag, 'hex');
|
|
99
|
+
const decipher = crypto.createDecipheriv('aes-256-gcm', key, ivBuffer);
|
|
100
|
+
decipher.setAuthTag(authTagBuffer);
|
|
101
|
+
let decryptedData = decipher.update(encryptedDataObject.encryptedData, 'hex', 'utf8');
|
|
102
|
+
decryptedData += decipher.final('utf8');
|
|
103
|
+
return decryptedData;
|
|
104
|
+
}
|
|
105
|
+
catch (error) {
|
|
106
|
+
throw new Error('Error decrypting data: ' + error.message);
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
exports.decryptData = decryptData;
|
|
110
|
+
//# sourceMappingURL=crypto.functions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"crypto.functions.js","sourceRoot":"","sources":["../../../../src/shared-patterns/functions/crypto.functions.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Parses a comma-separated string into an array of strings.
|
|
3
|
+
*
|
|
4
|
+
* @param commaSeparatedString - The string to parse.
|
|
5
|
+
* @returns An array of trimmed, non-empty strings.
|
|
6
|
+
*/
|
|
7
|
+
export declare const parseCommaSeparatedStringToStringArray: (commaSeparatedString: string | null) => string[];
|
|
8
|
+
export declare const checkIfTokenIdIsUri: (tokenId: string | null) => boolean;
|
|
9
|
+
export declare const compareVersions: (version1: string, version2: string) => number;
|
|
10
|
+
//# sourceMappingURL=helper.functions.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helper.functions.d.ts","sourceRoot":"","sources":["../../../../src/shared-patterns/functions/helper.functions.ts"],"names":[],"mappings":"AAEA;;;;;KAKK;AACL,eAAO,MAAM,sCAAsC,GAAI,sBAAsB,MAAM,GAAG,IAAI,KAAG,MAAM,EAI9F,CAAA;AAGL,eAAO,MAAM,mBAAmB,GAAI,SAAS,MAAM,GAAG,IAAI,KAAG,OAM5D,CAAA;AAED,eAAO,MAAM,eAAe,GAAI,UAAU,MAAM,EAAE,UAAU,MAAM,KAAG,MAWpE,CAAA"}
|