@explorins/pers-shared 2.1.9 → 2.1.11

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.
Files changed (230) hide show
  1. package/README.md +62 -13
  2. package/dist/cjs/dto/auth.dto.d.ts +2 -6
  3. package/dist/cjs/dto/auth.dto.d.ts.map +1 -1
  4. package/dist/cjs/dto/auth.dto.js +17 -23
  5. package/dist/cjs/dto/auth.dto.js.map +1 -1
  6. package/dist/cjs/index.d.ts +1 -3
  7. package/dist/cjs/index.d.ts.map +1 -1
  8. package/dist/cjs/index.js +0 -4
  9. package/dist/cjs/index.js.map +1 -1
  10. package/dist/cjs/interfaces/token-transaction-input-data.interface.d.ts +12 -3
  11. package/dist/cjs/interfaces/token-transaction-input-data.interface.d.ts.map +1 -1
  12. package/dist/cjs/internal/database/index.d.ts +6 -0
  13. package/dist/cjs/internal/database/index.d.ts.map +1 -0
  14. package/dist/cjs/internal/database/index.js +24 -0
  15. package/dist/cjs/internal/database/index.js.map +1 -0
  16. package/dist/cjs/internal/database/models/base.model.d.ts +7 -0
  17. package/dist/cjs/internal/database/models/base.model.d.ts.map +1 -0
  18. package/dist/cjs/internal/database/models/base.model.js +11 -0
  19. package/dist/cjs/internal/database/models/base.model.js.map +1 -0
  20. package/dist/cjs/internal/database/models/fixture.model.d.ts +4 -0
  21. package/dist/cjs/internal/database/models/fixture.model.d.ts.map +1 -0
  22. package/dist/cjs/internal/database/models/fixture.model.js +8 -0
  23. package/dist/cjs/internal/database/models/fixture.model.js.map +1 -0
  24. package/dist/cjs/internal/database/schemas/fixture-fields.schema.d.ts +5 -0
  25. package/dist/cjs/internal/database/schemas/fixture-fields.schema.d.ts.map +1 -0
  26. package/dist/cjs/internal/database/schemas/fixture-fields.schema.js +11 -0
  27. package/dist/cjs/internal/database/schemas/fixture-fields.schema.js.map +1 -0
  28. package/dist/cjs/internal/database/schemas/shared-fields.schema.d.ts +44 -0
  29. package/dist/cjs/internal/database/schemas/shared-fields.schema.d.ts.map +1 -0
  30. package/dist/cjs/internal/database/schemas/shared-fields.schema.js +64 -0
  31. package/dist/cjs/internal/database/schemas/shared-fields.schema.js.map +1 -0
  32. package/dist/cjs/internal/database/schemas/tenant-fields.schema.d.ts +51 -0
  33. package/dist/cjs/internal/database/schemas/tenant-fields.schema.d.ts.map +1 -0
  34. package/dist/cjs/internal/database/schemas/tenant-fields.schema.js +57 -0
  35. package/dist/cjs/internal/database/schemas/tenant-fields.schema.js.map +1 -0
  36. package/dist/cjs/internal/enums/lambda.enum.d.ts +28 -0
  37. package/dist/cjs/internal/enums/lambda.enum.d.ts.map +1 -0
  38. package/dist/cjs/internal/enums/lambda.enum.js +34 -0
  39. package/dist/cjs/internal/enums/lambda.enum.js.map +1 -0
  40. package/dist/cjs/internal/exceptions/base/error-classification-enums.d.ts +118 -0
  41. package/dist/cjs/internal/exceptions/base/error-classification-enums.d.ts.map +1 -0
  42. package/dist/cjs/internal/exceptions/base/error-classification-enums.js +111 -0
  43. package/dist/cjs/internal/exceptions/base/error-classification-enums.js.map +1 -0
  44. package/dist/cjs/internal/exceptions/base/error-classification.interface.d.ts +48 -0
  45. package/dist/cjs/internal/exceptions/base/error-classification.interface.d.ts.map +1 -0
  46. package/dist/cjs/internal/exceptions/base/error-classification.interface.js +6 -0
  47. package/dist/cjs/internal/exceptions/base/error-classification.interface.js.map +1 -0
  48. package/dist/cjs/internal/exceptions/base/error-classifier.d.ts +23 -0
  49. package/dist/cjs/internal/exceptions/base/error-classifier.d.ts.map +1 -0
  50. package/dist/cjs/internal/exceptions/base/error-classifier.js +149 -0
  51. package/dist/cjs/internal/exceptions/base/error-classifier.js.map +1 -0
  52. package/dist/cjs/internal/exceptions/index.d.ts +3 -0
  53. package/dist/cjs/internal/exceptions/index.d.ts.map +1 -0
  54. package/dist/cjs/internal/exceptions/index.js +24 -0
  55. package/dist/cjs/internal/exceptions/index.js.map +1 -0
  56. package/dist/cjs/internal/functions/crypto.functions.d.ts +16 -0
  57. package/dist/cjs/internal/functions/crypto.functions.d.ts.map +1 -0
  58. package/dist/cjs/internal/functions/crypto.functions.js +110 -0
  59. package/dist/cjs/internal/functions/crypto.functions.js.map +1 -0
  60. package/dist/cjs/internal/functions/helper.functions.d.ts +10 -0
  61. package/dist/cjs/internal/functions/helper.functions.d.ts.map +1 -0
  62. package/dist/cjs/internal/functions/helper.functions.js +38 -0
  63. package/dist/cjs/internal/functions/helper.functions.js.map +1 -0
  64. package/dist/cjs/internal/functions/index.d.ts +4 -0
  65. package/dist/cjs/internal/functions/index.d.ts.map +1 -0
  66. package/dist/cjs/internal/functions/index.js +21 -0
  67. package/dist/cjs/internal/functions/index.js.map +1 -0
  68. package/dist/cjs/internal/functions/request.functions.d.ts +14 -0
  69. package/dist/cjs/internal/functions/request.functions.d.ts.map +1 -0
  70. package/dist/cjs/internal/functions/request.functions.js +69 -0
  71. package/dist/cjs/internal/functions/request.functions.js.map +1 -0
  72. package/dist/cjs/internal/index.d.ts +14 -0
  73. package/dist/cjs/internal/index.d.ts.map +1 -0
  74. package/dist/cjs/internal/index.js +42 -0
  75. package/dist/cjs/internal/index.js.map +1 -0
  76. package/dist/cjs/internal/interfaces/index.d.ts +3 -0
  77. package/dist/cjs/internal/interfaces/index.d.ts.map +1 -0
  78. package/dist/cjs/internal/interfaces/index.js +19 -0
  79. package/dist/cjs/internal/interfaces/index.js.map +1 -0
  80. package/dist/cjs/internal/interfaces/request.interface.d.ts +21 -0
  81. package/dist/cjs/internal/interfaces/request.interface.d.ts.map +1 -0
  82. package/dist/cjs/internal/interfaces/request.interface.js +15 -0
  83. package/dist/cjs/internal/interfaces/request.interface.js.map +1 -0
  84. package/dist/cjs/internal/interfaces/stripe-payment-intent-metadata.interface.d.ts +9 -0
  85. package/dist/cjs/internal/interfaces/stripe-payment-intent-metadata.interface.d.ts.map +1 -0
  86. package/dist/cjs/internal/interfaces/stripe-payment-intent-metadata.interface.js +3 -0
  87. package/dist/cjs/internal/interfaces/stripe-payment-intent-metadata.interface.js.map +1 -0
  88. package/dist/cjs/internal/internal-index.d.ts +8 -0
  89. package/dist/cjs/internal/internal-index.d.ts.map +1 -0
  90. package/dist/cjs/internal/internal-index.js +33 -0
  91. package/dist/cjs/internal/internal-index.js.map +1 -0
  92. package/dist/cjs/internal/orchestrators/base-orchestrator.d.ts +90 -0
  93. package/dist/cjs/internal/orchestrators/base-orchestrator.d.ts.map +1 -0
  94. package/dist/cjs/internal/orchestrators/base-orchestrator.js +124 -0
  95. package/dist/cjs/internal/orchestrators/base-orchestrator.js.map +1 -0
  96. package/dist/cjs/internal/orchestrators/base-workflow.d.ts +50 -0
  97. package/dist/cjs/internal/orchestrators/base-workflow.d.ts.map +1 -0
  98. package/dist/cjs/internal/orchestrators/base-workflow.js +68 -0
  99. package/dist/cjs/internal/orchestrators/base-workflow.js.map +1 -0
  100. package/dist/cjs/internal/orchestrators/index.d.ts +26 -0
  101. package/dist/cjs/internal/orchestrators/index.d.ts.map +1 -0
  102. package/dist/cjs/internal/orchestrators/index.js +46 -0
  103. package/dist/cjs/internal/orchestrators/index.js.map +1 -0
  104. package/dist/cjs/internal/utils/index.d.ts +2 -0
  105. package/dist/cjs/internal/utils/index.d.ts.map +1 -0
  106. package/dist/cjs/internal/utils/index.js +19 -0
  107. package/dist/cjs/internal/utils/index.js.map +1 -0
  108. package/dist/cjs/internal/utils/validation.utils.d.ts +49 -0
  109. package/dist/cjs/internal/utils/validation.utils.d.ts.map +1 -0
  110. package/dist/cjs/internal/utils/validation.utils.js +76 -0
  111. package/dist/cjs/internal/utils/validation.utils.js.map +1 -0
  112. package/dist/cjs/value-objects/token-transaction-input.vo.d.ts +2 -3
  113. package/dist/cjs/value-objects/token-transaction-input.vo.d.ts.map +1 -1
  114. package/dist/cjs/value-objects/token-transaction-input.vo.js +12 -20
  115. package/dist/cjs/value-objects/token-transaction-input.vo.js.map +1 -1
  116. package/dist/esm/dto/auth.dto.d.ts +2 -6
  117. package/dist/esm/dto/auth.dto.d.ts.map +1 -1
  118. package/dist/esm/dto/auth.dto.js +14 -18
  119. package/dist/esm/dto/auth.dto.js.map +1 -1
  120. package/dist/esm/index.d.ts +1 -3
  121. package/dist/esm/index.d.ts.map +1 -1
  122. package/dist/esm/index.js +0 -4
  123. package/dist/esm/index.js.map +1 -1
  124. package/dist/esm/interfaces/token-transaction-input-data.interface.d.ts +12 -3
  125. package/dist/esm/interfaces/token-transaction-input-data.interface.d.ts.map +1 -1
  126. package/dist/esm/internal/database/index.d.ts +6 -0
  127. package/dist/esm/internal/database/index.d.ts.map +1 -0
  128. package/dist/esm/internal/database/index.js +8 -0
  129. package/dist/esm/internal/database/index.js.map +1 -0
  130. package/dist/esm/internal/database/models/base.model.d.ts +7 -0
  131. package/dist/esm/internal/database/models/base.model.d.ts.map +1 -0
  132. package/dist/esm/internal/database/models/base.model.js +7 -0
  133. package/dist/esm/internal/database/models/base.model.js.map +1 -0
  134. package/dist/esm/internal/database/models/fixture.model.d.ts +4 -0
  135. package/dist/esm/internal/database/models/fixture.model.d.ts.map +1 -0
  136. package/dist/esm/internal/database/models/fixture.model.js +4 -0
  137. package/dist/esm/internal/database/models/fixture.model.js.map +1 -0
  138. package/dist/esm/internal/database/schemas/fixture-fields.schema.d.ts +5 -0
  139. package/dist/esm/internal/database/schemas/fixture-fields.schema.d.ts.map +1 -0
  140. package/dist/esm/internal/database/schemas/fixture-fields.schema.js +8 -0
  141. package/dist/esm/internal/database/schemas/fixture-fields.schema.js.map +1 -0
  142. package/dist/esm/internal/database/schemas/shared-fields.schema.d.ts +44 -0
  143. package/dist/esm/internal/database/schemas/shared-fields.schema.d.ts.map +1 -0
  144. package/dist/esm/internal/database/schemas/shared-fields.schema.js +61 -0
  145. package/dist/esm/internal/database/schemas/shared-fields.schema.js.map +1 -0
  146. package/dist/esm/internal/database/schemas/tenant-fields.schema.d.ts +51 -0
  147. package/dist/esm/internal/database/schemas/tenant-fields.schema.d.ts.map +1 -0
  148. package/dist/esm/internal/database/schemas/tenant-fields.schema.js +54 -0
  149. package/dist/esm/internal/database/schemas/tenant-fields.schema.js.map +1 -0
  150. package/dist/esm/internal/enums/lambda.enum.d.ts +28 -0
  151. package/dist/esm/internal/enums/lambda.enum.d.ts.map +1 -0
  152. package/dist/esm/internal/enums/lambda.enum.js +31 -0
  153. package/dist/esm/internal/enums/lambda.enum.js.map +1 -0
  154. package/dist/esm/internal/exceptions/base/error-classification-enums.d.ts +118 -0
  155. package/dist/esm/internal/exceptions/base/error-classification-enums.d.ts.map +1 -0
  156. package/dist/esm/internal/exceptions/base/error-classification-enums.js +108 -0
  157. package/dist/esm/internal/exceptions/base/error-classification-enums.js.map +1 -0
  158. package/dist/esm/internal/exceptions/base/error-classification.interface.d.ts +48 -0
  159. package/dist/esm/internal/exceptions/base/error-classification.interface.d.ts.map +1 -0
  160. package/dist/esm/internal/exceptions/base/error-classification.interface.js +5 -0
  161. package/dist/esm/internal/exceptions/base/error-classification.interface.js.map +1 -0
  162. package/dist/esm/internal/exceptions/base/error-classifier.d.ts +23 -0
  163. package/dist/esm/internal/exceptions/base/error-classifier.d.ts.map +1 -0
  164. package/dist/esm/internal/exceptions/base/error-classifier.js +145 -0
  165. package/dist/esm/internal/exceptions/base/error-classifier.js.map +1 -0
  166. package/dist/esm/internal/exceptions/index.d.ts +3 -0
  167. package/dist/esm/internal/exceptions/index.d.ts.map +1 -0
  168. package/dist/esm/internal/exceptions/index.js +6 -0
  169. package/dist/esm/internal/exceptions/index.js.map +1 -0
  170. package/dist/esm/internal/functions/crypto.functions.d.ts +16 -0
  171. package/dist/esm/internal/functions/crypto.functions.d.ts.map +1 -0
  172. package/dist/esm/internal/functions/crypto.functions.js +67 -0
  173. package/dist/esm/internal/functions/crypto.functions.js.map +1 -0
  174. package/dist/esm/internal/functions/helper.functions.d.ts +10 -0
  175. package/dist/esm/internal/functions/helper.functions.d.ts.map +1 -0
  176. package/dist/esm/internal/functions/helper.functions.js +32 -0
  177. package/dist/esm/internal/functions/helper.functions.js.map +1 -0
  178. package/dist/esm/internal/functions/index.d.ts +4 -0
  179. package/dist/esm/internal/functions/index.d.ts.map +1 -0
  180. package/dist/esm/internal/functions/index.js +5 -0
  181. package/dist/esm/internal/functions/index.js.map +1 -0
  182. package/dist/esm/internal/functions/request.functions.d.ts +14 -0
  183. package/dist/esm/internal/functions/request.functions.d.ts.map +1 -0
  184. package/dist/esm/internal/functions/request.functions.js +61 -0
  185. package/dist/esm/internal/functions/request.functions.js.map +1 -0
  186. package/dist/esm/internal/index.d.ts +14 -0
  187. package/dist/esm/internal/index.d.ts.map +1 -0
  188. package/dist/esm/internal/index.js +26 -0
  189. package/dist/esm/internal/index.js.map +1 -0
  190. package/dist/esm/internal/interfaces/index.d.ts +3 -0
  191. package/dist/esm/internal/interfaces/index.d.ts.map +1 -0
  192. package/dist/esm/internal/interfaces/index.js +3 -0
  193. package/dist/esm/internal/interfaces/index.js.map +1 -0
  194. package/dist/esm/internal/interfaces/request.interface.d.ts +21 -0
  195. package/dist/esm/internal/interfaces/request.interface.d.ts.map +1 -0
  196. package/dist/esm/internal/interfaces/request.interface.js +11 -0
  197. package/dist/esm/internal/interfaces/request.interface.js.map +1 -0
  198. package/dist/esm/internal/interfaces/stripe-payment-intent-metadata.interface.d.ts +9 -0
  199. package/dist/esm/internal/interfaces/stripe-payment-intent-metadata.interface.d.ts.map +1 -0
  200. package/dist/esm/internal/interfaces/stripe-payment-intent-metadata.interface.js +2 -0
  201. package/dist/esm/internal/interfaces/stripe-payment-intent-metadata.interface.js.map +1 -0
  202. package/dist/esm/internal/internal-index.d.ts +8 -0
  203. package/dist/esm/internal/internal-index.d.ts.map +1 -0
  204. package/dist/esm/internal/internal-index.js +17 -0
  205. package/dist/esm/internal/internal-index.js.map +1 -0
  206. package/dist/esm/internal/orchestrators/base-orchestrator.d.ts +90 -0
  207. package/dist/esm/internal/orchestrators/base-orchestrator.d.ts.map +1 -0
  208. package/dist/esm/internal/orchestrators/base-orchestrator.js +116 -0
  209. package/dist/esm/internal/orchestrators/base-orchestrator.js.map +1 -0
  210. package/dist/esm/internal/orchestrators/base-workflow.d.ts +50 -0
  211. package/dist/esm/internal/orchestrators/base-workflow.d.ts.map +1 -0
  212. package/dist/esm/internal/orchestrators/base-workflow.js +64 -0
  213. package/dist/esm/internal/orchestrators/base-workflow.js.map +1 -0
  214. package/dist/esm/internal/orchestrators/index.d.ts +26 -0
  215. package/dist/esm/internal/orchestrators/index.d.ts.map +1 -0
  216. package/dist/esm/internal/orchestrators/index.js +30 -0
  217. package/dist/esm/internal/orchestrators/index.js.map +1 -0
  218. package/dist/esm/internal/utils/index.d.ts +2 -0
  219. package/dist/esm/internal/utils/index.d.ts.map +1 -0
  220. package/dist/esm/internal/utils/index.js +3 -0
  221. package/dist/esm/internal/utils/index.js.map +1 -0
  222. package/dist/esm/internal/utils/validation.utils.d.ts +49 -0
  223. package/dist/esm/internal/utils/validation.utils.d.ts.map +1 -0
  224. package/dist/esm/internal/utils/validation.utils.js +70 -0
  225. package/dist/esm/internal/utils/validation.utils.js.map +1 -0
  226. package/dist/esm/value-objects/token-transaction-input.vo.d.ts +2 -3
  227. package/dist/esm/value-objects/token-transaction-input.vo.d.ts.map +1 -1
  228. package/dist/esm/value-objects/token-transaction-input.vo.js +10 -18
  229. package/dist/esm/value-objects/token-transaction-input.vo.js.map +1 -1
  230. package/package.json +7 -1
@@ -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/internal/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,108 @@
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
+ // Note: ErrorCategory is now imported from @explorins/pers-shared
43
+ // This library contains only the detailed classification enums and interfaces
44
+ /**
45
+ * Error severity levels for prioritization and alerting
46
+ *
47
+ * Determines the urgency of response and escalation procedures:
48
+ * - Monitoring alert thresholds
49
+ * - On-call escalation policies
50
+ * - SLA response times
51
+ * - Business impact assessment
52
+ */
53
+ export var ErrorSeverity;
54
+ (function (ErrorSeverity) {
55
+ /**
56
+ * Low severity - Minor issues, degraded experience but service functional
57
+ * Examples: Optional feature failures, cosmetic issues, non-critical warnings
58
+ * Response Time: 24-48 hours
59
+ * Escalation: Development team during business hours
60
+ * Business Impact: Minimal
61
+ */
62
+ ErrorSeverity["LOW"] = "LOW";
63
+ /**
64
+ * Medium severity - Noticeable issues, some functionality impaired
65
+ * Examples: Performance degradation, secondary feature failures, data sync delays
66
+ * Response Time: 4-8 hours
67
+ * Escalation: Development team within same day
68
+ * Business Impact: Moderate
69
+ */
70
+ ErrorSeverity["MEDIUM"] = "MEDIUM";
71
+ /**
72
+ * High severity - Significant issues, core functionality impaired
73
+ * Examples: Payment failures, authentication issues, critical feature outages
74
+ * Response Time: 1-2 hours
75
+ * Escalation: Immediate development team notification
76
+ * Business Impact: High
77
+ */
78
+ ErrorSeverity["HIGH"] = "HIGH";
79
+ /**
80
+ * Critical severity - System down, major business impact
81
+ * Examples: Complete service outage, data corruption, security breaches
82
+ * Response Time: Immediate (< 15 minutes)
83
+ * Escalation: Page on-call engineer, notify leadership
84
+ * Business Impact: Severe
85
+ */
86
+ ErrorSeverity["CRITICAL"] = "CRITICAL";
87
+ })(ErrorSeverity || (ErrorSeverity = {}));
88
+ // Note: All interfaces moved to @explorins/pers-shared for proper data contract separation
89
+ /**
90
+ * HTTP Status codes used by our error classification system
91
+ *
92
+ * Centralized here to maintain consistency across error classification
93
+ * and avoid duplication with NestJS HttpStatus values.
94
+ */
95
+ export var ErrorHttpStatus;
96
+ (function (ErrorHttpStatus) {
97
+ ErrorHttpStatus[ErrorHttpStatus["BAD_REQUEST"] = 400] = "BAD_REQUEST";
98
+ ErrorHttpStatus[ErrorHttpStatus["UNAUTHORIZED"] = 401] = "UNAUTHORIZED";
99
+ ErrorHttpStatus[ErrorHttpStatus["FORBIDDEN"] = 403] = "FORBIDDEN";
100
+ ErrorHttpStatus[ErrorHttpStatus["NOT_FOUND"] = 404] = "NOT_FOUND";
101
+ ErrorHttpStatus[ErrorHttpStatus["CONFLICT"] = 409] = "CONFLICT";
102
+ ErrorHttpStatus[ErrorHttpStatus["UNPROCESSABLE_ENTITY"] = 422] = "UNPROCESSABLE_ENTITY";
103
+ ErrorHttpStatus[ErrorHttpStatus["TOO_MANY_REQUESTS"] = 429] = "TOO_MANY_REQUESTS";
104
+ ErrorHttpStatus[ErrorHttpStatus["INTERNAL_SERVER_ERROR"] = 500] = "INTERNAL_SERVER_ERROR";
105
+ ErrorHttpStatus[ErrorHttpStatus["SERVICE_UNAVAILABLE"] = 503] = "SERVICE_UNAVAILABLE";
106
+ ErrorHttpStatus[ErrorHttpStatus["GATEWAY_TIMEOUT"] = 504] = "GATEWAY_TIMEOUT";
107
+ })(ErrorHttpStatus || (ErrorHttpStatus = {}));
108
+ //# sourceMappingURL=error-classification-enums.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"error-classification-enums.js","sourceRoot":"","sources":["../../../../../src/internal/exceptions/base/error-classification-enums.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCG;AAEH,kEAAkE;AAClE,8EAA8E;AAE9E;;;;;;;;GAQG;AACH,MAAM,CAAN,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,KAAb,aAAa,QAoCxB;AAoBD,2FAA2F;AAE3F;;;;;GAKG;AACH,MAAM,CAAN,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,KAAf,eAAe,QAW1B"}
@@ -0,0 +1,48 @@
1
+ /**
2
+ * Error classification and response interfaces for domain-driven error handling
3
+ */
4
+ import { ErrorCategory } from '@explorins/pers-shared';
5
+ import { ErrorSeverity } from './error-classification-enums';
6
+ export interface ErrorClassificationResult {
7
+ category: ErrorCategory;
8
+ severity: ErrorSeverity;
9
+ retryable: boolean;
10
+ userFacing: boolean;
11
+ httpStatusCode: number;
12
+ }
13
+ export interface ApiErrorResponse {
14
+ code: string;
15
+ domain: string;
16
+ message: string;
17
+ developerMessage?: string;
18
+ action?: string;
19
+ timestamp: string;
20
+ category: string;
21
+ correlationId: string;
22
+ retryable?: boolean;
23
+ severity?: string;
24
+ }
25
+ export interface LoggingContext {
26
+ domain: string;
27
+ operation: string;
28
+ errorCode: string;
29
+ severity: ErrorSeverity;
30
+ additionalContext?: Record<string, any>;
31
+ }
32
+ /**
33
+ * Interface for self-classifying errors
34
+ */
35
+ export interface SelfClassifyingError {
36
+ classify(): ErrorClassificationResult;
37
+ toApiResponse(correlationId: string): ApiErrorResponse;
38
+ getLoggingContext(): LoggingContext;
39
+ }
40
+ /**
41
+ * Interface for domain-specific error classifiers
42
+ */
43
+ export interface DomainErrorClassifier {
44
+ canClassify(error: any): boolean;
45
+ classify(error: any): ErrorClassificationResult;
46
+ formatApiResponse(error: any, correlationId: string): ApiErrorResponse;
47
+ }
48
+ //# sourceMappingURL=error-classification.interface.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"error-classification.interface.d.ts","sourceRoot":"","sources":["../../../../../src/internal/exceptions/base/error-classification.interface.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAE7D,MAAM,WAAW,yBAAyB;IACxC,QAAQ,EAAE,aAAa,CAAC;IACxB,QAAQ,EAAE,aAAa,CAAC;IACxB,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,EAAE,OAAO,CAAC;IACpB,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,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,CAAC,EAAE,OAAO,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,aAAa,CAAC;IACxB,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CACzC;AAED;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,QAAQ,IAAI,yBAAyB,CAAC;IACtC,aAAa,CAAC,aAAa,EAAE,MAAM,GAAG,gBAAgB,CAAC;IACvD,iBAAiB,IAAI,cAAc,CAAC;CACrC;AAED;;GAEG;AACH,MAAM,WAAW,qBAAqB;IACpC,WAAW,CAAC,KAAK,EAAE,GAAG,GAAG,OAAO,CAAC;IACjC,QAAQ,CAAC,KAAK,EAAE,GAAG,GAAG,yBAAyB,CAAC;IAChD,iBAAiB,CAAC,KAAK,EAAE,GAAG,EAAE,aAAa,EAAE,MAAM,GAAG,gBAAgB,CAAC;CACxE"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Error classification and response interfaces for domain-driven error handling
3
+ */
4
+ export {};
5
+ //# sourceMappingURL=error-classification.interface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"error-classification.interface.js","sourceRoot":"","sources":["../../../../../src/internal/exceptions/base/error-classification.interface.ts"],"names":[],"mappings":"AAAA;;GAEG"}
@@ -0,0 +1,23 @@
1
+ import { StructuredError } from '@explorins/pers-shared';
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/internal/exceptions/base/error-classifier.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqD,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAG5G;;GAEG;AACH,qBAAa,eAAe;IAC1B;;;;;OAKG;IACH,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,GAAG,eAAe;IAyD5D;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAC,cAAc;IAgE7B;;OAEG;IACH,MAAM,CAAC,iBAAiB,CAAC,eAAe,EAAE,eAAe,GAAG,MAAM;CAkBnE"}
@@ -0,0 +1,145 @@
1
+ import { BusinessLogicError, TechnicalError, ErrorCategory } from '@explorins/pers-shared';
2
+ import { ErrorHttpStatus } from './error-classification-enums';
3
+ /**
4
+ * Error classification utilities with 3-path decision logic
5
+ */
6
+ export class ErrorClassifier {
7
+ /**
8
+ * Simplified error classification with 3-path logic
9
+ * 1. BusinessLogicError -> Preserve structure (fast path)
10
+ * 2. TechnicalError -> Preserve message (fast path)
11
+ * 3. Everything else -> Security-first fallback
12
+ */
13
+ static classify(error, domain) {
14
+ // Fast path 1: BusinessLogicError (already structured)
15
+ if (BusinessLogicError.isBusinessError(error)) {
16
+ const response = error.getResponse();
17
+ const responseObj = typeof response === 'object' ? response : {};
18
+ return {
19
+ category: ErrorCategory.DOMAIN_RULE,
20
+ code: responseObj.code || 'BUSINESS_ERROR',
21
+ message: responseObj.message || error.message,
22
+ userMessage: responseObj.message || error.message,
23
+ retryable: false
24
+ };
25
+ }
26
+ // Fast path 2: TechnicalError (preserve meaningful messages)
27
+ if (TechnicalError.isTechnicalError(error)) {
28
+ const response = error.getResponse();
29
+ const responseObj = typeof response === 'object' ? response : {};
30
+ return {
31
+ category: ErrorCategory.INFRASTRUCTURE,
32
+ code: 'TECHNICAL_ERROR',
33
+ message: responseObj.message || error.message,
34
+ userMessage: responseObj.message || error.message,
35
+ retryable: false
36
+ };
37
+ }
38
+ // Fast path 3: HttpExceptions with BUSINESS_LOGIC category (for backward compatibility)
39
+ if (typeof error.getStatus === 'function') {
40
+ const response = error.getResponse ? error.getResponse() : null;
41
+ if (typeof response === 'object' && response?.category === 'BUSINESS_LOGIC') {
42
+ const responseObj = response;
43
+ return {
44
+ category: ErrorCategory.DOMAIN_RULE,
45
+ code: responseObj.code || 'BUSINESS_ERROR',
46
+ message: responseObj.message || error.message,
47
+ userMessage: responseObj.message || error.message,
48
+ retryable: false
49
+ };
50
+ }
51
+ }
52
+ // Security-first fallback for everything else
53
+ const message = error.message || 'Unknown error';
54
+ // Check if error message is safe to expose to users
55
+ const isSafe = this.isSafeForUsers(message);
56
+ return {
57
+ category: ErrorCategory.UNKNOWN,
58
+ code: 'INTERNAL_ERROR',
59
+ message: isSafe ? message : 'Internal server error',
60
+ userMessage: isSafe ? message : 'An unexpected error occurred. Please try again.',
61
+ retryable: true
62
+ };
63
+ }
64
+ /**
65
+ * Determine if an error message is safe to expose to users
66
+ * Uses a balanced approach: block sensitive system data while allowing business messages
67
+ */
68
+ static isSafeForUsers(message) {
69
+ if (!message || message.length < 3 || message.length > 300)
70
+ return false;
71
+ // Allow common business error phrases that are safe for users
72
+ const safeBusinessPatterns = [
73
+ /cannot process payment/i,
74
+ /unable to complete transaction/i,
75
+ /insufficient (balance|funds)/i,
76
+ /user not found/i,
77
+ /token not active/i,
78
+ /wallet not found/i,
79
+ /invalid (amount|address|format)/i,
80
+ /transaction (failed|rejected|expired)/i,
81
+ /account (locked|inactive|suspended)/i,
82
+ /permission denied/i,
83
+ /rate limit exceeded/i,
84
+ /service temporarily unavailable/i
85
+ ];
86
+ // If it matches safe business patterns, allow it
87
+ if (safeBusinessPatterns.some(pattern => pattern.test(message))) {
88
+ return true;
89
+ }
90
+ // Block definitely unsafe patterns (system internals and sensitive data)
91
+ const unsafePatterns = [
92
+ // System internals with technical context
93
+ /internal server error/i,
94
+ /database connection (failed|lost|timeout)/i,
95
+ /sql (error|exception|syntax)/i,
96
+ /stack trace|stacktrace/i,
97
+ /undefined (property|method|function)/i,
98
+ /null pointer|reference error/i,
99
+ // Sensitive data indicators
100
+ /secret|password|private.?key|credential/i,
101
+ /jwt.?token|bearer.?token|api.?key/i,
102
+ /localhost|127\.0\.0\.1|192\.168\.|10\.\d+\./i,
103
+ /\.env|config\.json|\.xml|\.yml/i,
104
+ // Technical stack traces and system paths
105
+ /\/var\/|\/etc\/|\/home\/|\/usr\/bin|\/opt\//i,
106
+ /node_modules|package\.json|tsconfig/i,
107
+ /at Object\.|at Function\.|at async/i,
108
+ // Database and system queries
109
+ /SELECT.*FROM|INSERT.*INTO|UPDATE.*SET/i,
110
+ /mongodb|postgresql|redis|elasticsearch/i
111
+ ];
112
+ // Block if it matches unsafe patterns
113
+ if (unsafePatterns.some(pattern => pattern.test(message))) {
114
+ return false;
115
+ }
116
+ // For everything else, apply basic safety checks
117
+ // Allow if it looks like a user-friendly business message
118
+ const hasBusinessContext = /\b(user|account|transaction|payment|balance|wallet|token)\b/i.test(message);
119
+ const hasGenericWords = /\b(invalid|missing|required|expired|failed|rejected|denied)\b/i.test(message);
120
+ const noSystemJargon = !/\b(undefined|null|exception|stack|trace|object|function|method|class)\b/i.test(message);
121
+ return (hasBusinessContext || hasGenericWords) && noSystemJargon;
122
+ }
123
+ /**
124
+ * Convert structured error to HTTP status code
125
+ */
126
+ static getHttpStatusCode(structuredError) {
127
+ switch (structuredError.category) {
128
+ case ErrorCategory.VALIDATION:
129
+ return ErrorHttpStatus.BAD_REQUEST;
130
+ case ErrorCategory.DOMAIN_RULE:
131
+ return ErrorHttpStatus.UNPROCESSABLE_ENTITY;
132
+ case ErrorCategory.SECURITY:
133
+ return ErrorHttpStatus.FORBIDDEN;
134
+ case ErrorCategory.RATE_LIMIT:
135
+ return ErrorHttpStatus.TOO_MANY_REQUESTS;
136
+ case ErrorCategory.TIMEOUT:
137
+ return ErrorHttpStatus.GATEWAY_TIMEOUT;
138
+ case ErrorCategory.INFRASTRUCTURE:
139
+ return ErrorHttpStatus.SERVICE_UNAVAILABLE;
140
+ default:
141
+ return ErrorHttpStatus.INTERNAL_SERVER_ERROR;
142
+ }
143
+ }
144
+ }
145
+ //# sourceMappingURL=error-classifier.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"error-classifier.js","sourceRoot":"","sources":["../../../../../src/internal/exceptions/base/error-classifier.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export * from './base/error-classification-enums';
2
+ export { ErrorClassifier } from './base/error-classifier';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/internal/exceptions/index.ts"],"names":[],"mappings":"AACA,cAAc,mCAAmC,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC"}
@@ -0,0 +1,6 @@
1
+ // Error classification utilities (patterns-specific logic only)
2
+ export * from './base/error-classification-enums';
3
+ export { ErrorClassifier } from './base/error-classifier';
4
+ // Note: All error classes (BusinessLogicError, TechnicalError, domain errors) are exported from @explorins/pers-shared
5
+ // This library only contains error classification logic and patterns
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/internal/exceptions/index.ts"],"names":[],"mappings":"AAAA,gEAAgE;AAChE,cAAc,mCAAmC,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAE1D,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/internal/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,67 @@
1
+ import * as crypto from 'crypto';
2
+ import { randomBytes } from 'crypto';
3
+ const bcrypt = require('bcryptjs');
4
+ const defaultSaltRounds = 10;
5
+ export const hashString = (input, maxLength = null, algorithm = 'sha256') => {
6
+ // Generate a hash of the input string
7
+ let hash = crypto.createHash(algorithm).update(input).digest('hex');
8
+ if (typeof maxLength === 'number' && hash.length > maxLength) {
9
+ hash = hash.substring(0, maxLength);
10
+ }
11
+ return hash;
12
+ };
13
+ export const checkMatching = async (plainString, hashedString) => {
14
+ const match = await bcrypt.compare(plainString, hashedString);
15
+ return match;
16
+ };
17
+ export const hashPassword = async (password, saltRounds = defaultSaltRounds) => {
18
+ return await bcrypt.hash(password, saltRounds);
19
+ };
20
+ export const generatePseudoRandomData = (size = 32) => {
21
+ // Convert the byte array into a hexadecimal string
22
+ let salt = randomBytes(size).toString('hex');
23
+ return salt;
24
+ };
25
+ export const generateDecryptedPrivateKey = (privateKey, passphrase, keyType = 'pkcs8', keyFormat = 'pem') => {
26
+ const decryptedPrivateKey = crypto.createPrivateKey({
27
+ key: privateKey,
28
+ format: keyFormat,
29
+ type: keyType,
30
+ passphrase: passphrase,
31
+ });
32
+ return decryptedPrivateKey.export({ format: keyFormat, type: keyType }).toString();
33
+ };
34
+ export const encryptData = (data, encryptionKey) => {
35
+ try {
36
+ const key = Buffer.from(encryptionKey, 'hex');
37
+ const iv = crypto.randomBytes(16);
38
+ const cipher = crypto.createCipheriv('aes-256-gcm', key, iv);
39
+ let encryptedData = cipher.update(data, 'utf8', 'hex');
40
+ encryptedData += cipher.final('hex');
41
+ const authTag = cipher.getAuthTag().toString('hex');
42
+ return {
43
+ encryptedData,
44
+ iv: iv.toString('hex'),
45
+ authTag
46
+ };
47
+ }
48
+ catch (error) {
49
+ throw new Error('Error encrypting data: ' + error.message);
50
+ }
51
+ };
52
+ export const decryptData = (encryptedDataObject, encryptionKey) => {
53
+ try {
54
+ const key = Buffer.from(encryptionKey, 'hex');
55
+ const ivBuffer = Buffer.from(encryptedDataObject.iv, 'hex');
56
+ const authTagBuffer = Buffer.from(encryptedDataObject.authTag, 'hex');
57
+ const decipher = crypto.createDecipheriv('aes-256-gcm', key, ivBuffer);
58
+ decipher.setAuthTag(authTagBuffer);
59
+ let decryptedData = decipher.update(encryptedDataObject.encryptedData, 'hex', 'utf8');
60
+ decryptedData += decipher.final('utf8');
61
+ return decryptedData;
62
+ }
63
+ catch (error) {
64
+ throw new Error('Error decrypting data: ' + error.message);
65
+ }
66
+ };
67
+ //# sourceMappingURL=crypto.functions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"crypto.functions.js","sourceRoot":"","sources":["../../../../src/internal/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/internal/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"}
@@ -0,0 +1,32 @@
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 const parseCommaSeparatedStringToStringArray = (commaSeparatedString) => {
8
+ return commaSeparatedString
9
+ ? commaSeparatedString.split(',').map((s) => s.trim()).filter(Boolean)
10
+ : [];
11
+ };
12
+ export const checkIfTokenIdIsUri = (tokenId) => {
13
+ const uriRegex = /^(https?|ipfs):\/\/.*/;
14
+ if (!tokenId || !uriRegex.test(tokenId)) {
15
+ return false;
16
+ }
17
+ return true;
18
+ };
19
+ export const compareVersions = (version1, version2) => {
20
+ const v1 = version1.split('.').map(Number);
21
+ const v2 = version2.split('.').map(Number);
22
+ for (let i = 0; i < Math.max(v1.length, v2.length); i++) {
23
+ const num1 = v1[i] || 0;
24
+ const num2 = v2[i] || 0;
25
+ if (num1 > num2)
26
+ return 1;
27
+ if (num1 < num2)
28
+ return -1;
29
+ }
30
+ return 0;
31
+ };
32
+ //# sourceMappingURL=helper.functions.js.map