@ripwords/myinvois-client 0.2.16 → 0.2.18

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 (70) hide show
  1. package/dist/api/documentManagement.d.ts +2 -2
  2. package/dist/api/documentSubmission.d.ts +2 -2
  3. package/dist/api/documentSubmission.js +1 -1
  4. package/dist/api/documentTypeManagement.d.ts +2 -2
  5. package/dist/api/notificationManagement.d.ts +2 -2
  6. package/dist/api/platformLogin.d.ts +2 -2
  7. package/dist/api/taxpayerValidation.d.ts +2 -2
  8. package/dist/{apiQueue-Csh8ru3S.js → apiQueue-BE3-DB1A.js} +14 -9
  9. package/dist/{apiQueue-CRyjAw52.cjs → apiQueue-DDXeQJDC.cjs} +15 -10
  10. package/dist/apiQueue-DDXeQJDC.cjs.map +1 -0
  11. package/dist/{documentSubmission-DG5pfaBQ.cjs → documentSubmission-6_5gC9YE.cjs} +3 -3
  12. package/dist/{documentSubmission-DG5pfaBQ.cjs.map → documentSubmission-6_5gC9YE.cjs.map} +1 -1
  13. package/dist/{documentSubmission-B45EflkR.js → documentSubmission-BoGTlQFb.js} +2 -2
  14. package/dist/{documents-DSZZujgx.d.cts → documents-BJPF2I_j.d.cts} +2 -2
  15. package/dist/{documents-CkoydYUK.d.ts → documents-WC-gApLM.d.ts} +1 -1
  16. package/dist/index.cjs +2 -2
  17. package/dist/index.d.ts +2 -2
  18. package/dist/index.js +2 -2
  19. package/dist/index10.cjs +187 -16
  20. package/dist/index10.cjs.map +1 -1
  21. package/dist/index12.cjs +16 -25
  22. package/dist/index12.cjs.map +1 -1
  23. package/dist/index13.cjs +0 -24
  24. package/dist/index15.cjs +29 -0
  25. package/dist/index15.cjs.map +1 -0
  26. package/dist/index16.cjs +25 -0
  27. package/dist/index16.cjs.map +1 -0
  28. package/dist/index17.cjs +0 -4
  29. package/dist/index18.cjs +30 -9
  30. package/dist/index18.cjs.map +1 -1
  31. package/dist/index19.cjs +23 -4
  32. package/dist/{index13.cjs.map → index19.cjs.map} +1 -1
  33. package/dist/index2.cjs +4 -61
  34. package/dist/index20.cjs +0 -20
  35. package/dist/index21.cjs +0 -3
  36. package/dist/index22.cjs +0 -3
  37. package/dist/index23.cjs +3 -329
  38. package/dist/index24.cjs +9 -189
  39. package/dist/index24.cjs.map +1 -1
  40. package/dist/index25.cjs +4 -4
  41. package/dist/index26.cjs +18 -5
  42. package/dist/index27.cjs +2 -4
  43. package/dist/index28.cjs +2 -2
  44. package/dist/index29.cjs +329 -2
  45. package/dist/{index23.cjs.map → index29.cjs.map} +1 -1
  46. package/dist/index3.cjs +6 -531
  47. package/dist/index30.cjs +192 -5
  48. package/dist/index30.cjs.map +1 -0
  49. package/dist/index4.cjs +4 -195
  50. package/dist/index5.cjs +3 -0
  51. package/dist/index6.cjs +2 -24
  52. package/dist/index7.cjs +6 -0
  53. package/dist/index8.cjs +62 -0
  54. package/dist/{index2.cjs.map → index8.cjs.map} +1 -1
  55. package/dist/index9.cjs +526 -23
  56. package/dist/index9.cjs.map +1 -1
  57. package/dist/{taxpayer-szi2f7gT.d.ts → taxpayer-Bz-fJYfF.d.ts} +1 -1
  58. package/dist/{taxpayer-CYHwMpau.d.cts → taxpayer-DSozw22p.d.cts} +2 -2
  59. package/dist/types/documents.d.ts +1 -1
  60. package/dist/types/index.d.ts +2 -2
  61. package/dist/types/taxpayer.d.ts +2 -2
  62. package/dist/utils/apiQueue.js +1 -1
  63. package/dist/utils/document.d.ts +2 -2
  64. package/dist/utils/signature-diagnostics.d.ts +2 -2
  65. package/dist/utils/validation.d.ts +2 -2
  66. package/package.json +1 -1
  67. package/dist/apiQueue-CRyjAw52.cjs.map +0 -1
  68. package/dist/index3.cjs.map +0 -1
  69. package/dist/index4.cjs.map +0 -1
  70. package/dist/index6.cjs.map +0 -1
@@ -51,11 +51,11 @@ import "../YX-F34sJ7Ik.js";
51
51
  import "../ZX-CDQOfsHh.js";
52
52
  import "../XX-DOA-10JW.js";
53
53
  import "../unit-types-VgYXIwTT.js";
54
- import { DocumentStatus, DocumentSummary, DocumentValidationResult, DocumentValidationStepResult } from "../documents-CkoydYUK.js";
54
+ import { DocumentStatus, DocumentSummary, DocumentValidationResult, DocumentValidationStepResult } from "../documents-WC-gApLM.js";
55
55
  import "../payment-modes-g3DzLmWb.js";
56
56
  import "../signatures-CerHUrj3.js";
57
57
  import "../notifications-sFhgh3rJ.js";
58
- import "../taxpayer-szi2f7gT.js";
58
+ import "../taxpayer-Bz-fJYfF.js";
59
59
  import { Fetch } from "../utils-C4FoVKLq.js";
60
60
  import "../index-CygwSf0x.js";
61
61
 
@@ -51,11 +51,11 @@ import "../YX-F34sJ7Ik.js";
51
51
  import "../ZX-CDQOfsHh.js";
52
52
  import "../XX-DOA-10JW.js";
53
53
  import "../unit-types-VgYXIwTT.js";
54
- import { AllDocumentsV1_1, DocumentSummary, SigningCredentials, StandardError, SubmissionResponse, SubmissionStatus } from "../documents-CkoydYUK.js";
54
+ import { AllDocumentsV1_1, DocumentSummary, SigningCredentials, StandardError, SubmissionResponse, SubmissionStatus } from "../documents-WC-gApLM.js";
55
55
  import "../payment-modes-g3DzLmWb.js";
56
56
  import "../signatures-CerHUrj3.js";
57
57
  import "../notifications-sFhgh3rJ.js";
58
- import "../taxpayer-szi2f7gT.js";
58
+ import "../taxpayer-Bz-fJYfF.js";
59
59
  import { Fetch } from "../utils-C4FoVKLq.js";
60
60
  import "../index-CygwSf0x.js";
61
61
 
@@ -1,5 +1,5 @@
1
1
  import "../formatIdValue-qTxJqj9o.js";
2
2
  import "../document-SQQDNoI-.js";
3
- import { getSubmissionStatus, performDocumentAction, submitDocument } from "../documentSubmission-B45EflkR.js";
3
+ import { getSubmissionStatus, performDocumentAction, submitDocument } from "../documentSubmission-BoGTlQFb.js";
4
4
 
5
5
  export { getSubmissionStatus, performDocumentAction, submitDocument };
@@ -51,11 +51,11 @@ import "../YX-F34sJ7Ik.js";
51
51
  import "../ZX-CDQOfsHh.js";
52
52
  import "../XX-DOA-10JW.js";
53
53
  import "../unit-types-VgYXIwTT.js";
54
- import { DocumentTypeResponse, DocumentTypeVersionResponse, DocumentTypesResponse } from "../documents-CkoydYUK.js";
54
+ import { DocumentTypeResponse, DocumentTypeVersionResponse, DocumentTypesResponse } from "../documents-WC-gApLM.js";
55
55
  import "../payment-modes-g3DzLmWb.js";
56
56
  import "../signatures-CerHUrj3.js";
57
57
  import "../notifications-sFhgh3rJ.js";
58
- import "../taxpayer-szi2f7gT.js";
58
+ import "../taxpayer-Bz-fJYfF.js";
59
59
  import { Fetch } from "../utils-C4FoVKLq.js";
60
60
  import "../index-CygwSf0x.js";
61
61
 
@@ -51,11 +51,11 @@ import "../YX-F34sJ7Ik.js";
51
51
  import "../ZX-CDQOfsHh.js";
52
52
  import "../XX-DOA-10JW.js";
53
53
  import "../unit-types-VgYXIwTT.js";
54
- import "../documents-CkoydYUK.js";
54
+ import "../documents-WC-gApLM.js";
55
55
  import "../payment-modes-g3DzLmWb.js";
56
56
  import "../signatures-CerHUrj3.js";
57
57
  import { NotificationResponse, NotificationSearchParams } from "../notifications-sFhgh3rJ.js";
58
- import "../taxpayer-szi2f7gT.js";
58
+ import "../taxpayer-Bz-fJYfF.js";
59
59
  import { Fetch } from "../utils-C4FoVKLq.js";
60
60
  import "../index-CygwSf0x.js";
61
61
 
@@ -51,11 +51,11 @@ import "../YX-F34sJ7Ik.js";
51
51
  import "../ZX-CDQOfsHh.js";
52
52
  import "../XX-DOA-10JW.js";
53
53
  import "../unit-types-VgYXIwTT.js";
54
- import "../documents-CkoydYUK.js";
54
+ import "../documents-WC-gApLM.js";
55
55
  import "../payment-modes-g3DzLmWb.js";
56
56
  import "../signatures-CerHUrj3.js";
57
57
  import "../notifications-sFhgh3rJ.js";
58
- import "../taxpayer-szi2f7gT.js";
58
+ import "../taxpayer-Bz-fJYfF.js";
59
59
  import "../utils-C4FoVKLq.js";
60
60
  import { ClientCredentials } from "../index-CygwSf0x.js";
61
61
 
@@ -51,11 +51,11 @@ import "../YX-F34sJ7Ik.js";
51
51
  import "../ZX-CDQOfsHh.js";
52
52
  import "../XX-DOA-10JW.js";
53
53
  import "../unit-types-VgYXIwTT.js";
54
- import { RegistrationType } from "../documents-CkoydYUK.js";
54
+ import { RegistrationType } from "../documents-WC-gApLM.js";
55
55
  import "../payment-modes-g3DzLmWb.js";
56
56
  import "../signatures-CerHUrj3.js";
57
57
  import "../notifications-sFhgh3rJ.js";
58
- import { TaxpayerQRCodeResponse, TinSearchParams, TinSearchResponse } from "../taxpayer-szi2f7gT.js";
58
+ import { TaxpayerQRCodeResponse, TinSearchParams, TinSearchResponse } from "../taxpayer-Bz-fJYfF.js";
59
59
  import { Fetch } from "../utils-C4FoVKLq.js";
60
60
  import "../index-CygwSf0x.js";
61
61
 
@@ -55,34 +55,39 @@ const RATE_LIMITS = {
55
55
  }
56
56
  };
57
57
  /**
58
- * A very small sliding-window rate-limiter with queuing.
59
- * Each category gets its own instance so limits are isolated.
58
+ * A very small token-bucket style rate-limiter with queuing.
59
+ * Instead of allowing a full-window burst (which could trigger a 429),
60
+ * requests are spaced evenly so the throughput stays within the
61
+ * <limit>/<window> budget at all times. Each category gets its own
62
+ * instance so limits remain isolated.
60
63
  */
61
64
  var RateLimiter = class {
62
65
  limit;
63
66
  windowMs;
67
+ minInterval;
64
68
  queue = [];
65
- timestamps = [];
69
+ nextAvailable = 0;
66
70
  timer = null;
67
71
  constructor(config) {
68
72
  this.limit = config.limit;
69
73
  this.windowMs = config.windowMs;
74
+ const baseInterval = Math.ceil(this.windowMs / this.limit);
75
+ const isTestEnv = process.env.NODE_ENV === "test";
76
+ const forceReal = process.env.APIQUEUE_REAL_INTERVAL === "true";
77
+ this.minInterval = isTestEnv && !forceReal ? 0 : baseInterval;
70
78
  }
71
79
  drainQueue() {
72
80
  if (this.queue.length === 0) return;
73
81
  const now = Date.now();
74
- this.timestamps = this.timestamps.filter((ts) => now - ts < this.windowMs);
75
- if (this.timestamps.length >= this.limit) {
76
- const earliest = this.timestamps[0];
77
- const delay = this.windowMs - (now - earliest) + 1;
82
+ if (now < this.nextAvailable) {
78
83
  if (!this.timer) this.timer = setTimeout(() => {
79
84
  this.timer = null;
80
85
  this.drainQueue();
81
- }, delay);
86
+ }, this.nextAvailable - now);
82
87
  return;
83
88
  }
84
89
  const next = this.queue.shift();
85
- this.timestamps.push(now);
90
+ this.nextAvailable = Date.now() + this.minInterval;
86
91
  next();
87
92
  this.drainQueue();
88
93
  }
@@ -56,34 +56,39 @@ const RATE_LIMITS = {
56
56
  }
57
57
  };
58
58
  /**
59
- * A very small sliding-window rate-limiter with queuing.
60
- * Each category gets its own instance so limits are isolated.
59
+ * A very small token-bucket style rate-limiter with queuing.
60
+ * Instead of allowing a full-window burst (which could trigger a 429),
61
+ * requests are spaced evenly so the throughput stays within the
62
+ * <limit>/<window> budget at all times. Each category gets its own
63
+ * instance so limits remain isolated.
61
64
  */
62
65
  var RateLimiter = class {
63
66
  limit;
64
67
  windowMs;
68
+ minInterval;
65
69
  queue = [];
66
- timestamps = [];
70
+ nextAvailable = 0;
67
71
  timer = null;
68
72
  constructor(config) {
69
73
  this.limit = config.limit;
70
74
  this.windowMs = config.windowMs;
75
+ const baseInterval = Math.ceil(this.windowMs / this.limit);
76
+ const isTestEnv = process.env.NODE_ENV === "test";
77
+ const forceReal = process.env.APIQUEUE_REAL_INTERVAL === "true";
78
+ this.minInterval = isTestEnv && !forceReal ? 0 : baseInterval;
71
79
  }
72
80
  drainQueue() {
73
81
  if (this.queue.length === 0) return;
74
82
  const now = Date.now();
75
- this.timestamps = this.timestamps.filter((ts) => now - ts < this.windowMs);
76
- if (this.timestamps.length >= this.limit) {
77
- const earliest = this.timestamps[0];
78
- const delay = this.windowMs - (now - earliest) + 1;
83
+ if (now < this.nextAvailable) {
79
84
  if (!this.timer) this.timer = setTimeout(() => {
80
85
  this.timer = null;
81
86
  this.drainQueue();
82
- }, delay);
87
+ }, this.nextAvailable - now);
83
88
  return;
84
89
  }
85
90
  const next = this.queue.shift();
86
- this.timestamps.push(now);
91
+ this.nextAvailable = Date.now() + this.minInterval;
87
92
  next();
88
93
  this.drainQueue();
89
94
  }
@@ -161,4 +166,4 @@ Object.defineProperty(exports, 'queueRequest', {
161
166
  return queueRequest;
162
167
  }
163
168
  });
164
- //# sourceMappingURL=apiQueue-CRyjAw52.cjs.map
169
+ //# sourceMappingURL=apiQueue-DDXeQJDC.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiQueue-DDXeQJDC.cjs","names":["RATE_LIMITS: Record<ApiCategory, RateLimitConfig>","config: RateLimitConfig","fn: () => Promise<T>","debug: boolean","category?: ApiCategory","category: ApiCategory","path: string","method: string"],"sources":["../src/utils/apiQueue.ts"],"sourcesContent":["// A very small utility that provides per-endpoint request queuing with fixed-window rate-limits.\n// The goal is to make sure that we never exceed the vendor-defined limits while also ensuring\n// that every request is eventually executed.\n//\n// NOTE: This is intentionally minimal – no external dependencies are introduced.\n// If you need more advanced features (persistence, jitter, etc.) consider a library such as `bottleneck`.\n\n/*\nRate-limit specification (per 60-second window)\n----------------------------------------------\nLogin as Taxpayer System : 12\nLogin as Intermediary System : 12\nSubmit Documents : 100\nGet Submission : 300\nCancel Document : 12\nReject Document : 12\nGet Document : 60\nGet Document Details : 125\nGet Recent Documents : 12\nSearch Documents : 12\nSearch Taxpayer's TIN : 60\nTaxpayer's QR Code : 60\n*/\n\nexport type ApiCategory =\n | 'loginTaxpayer'\n | 'loginIntermediary'\n | 'submitDocuments'\n | 'getSubmission'\n | 'cancelDocument'\n | 'rejectDocument'\n | 'getDocument'\n | 'getDocumentDetails'\n | 'getRecentDocuments'\n | 'searchDocuments'\n | 'searchTin'\n | 'taxpayerQr'\n | 'default'\n\ninterface RateLimitConfig {\n limit: number\n windowMs: number\n}\n\nconst WINDOW = 60_000 // 60 seconds\n\n// Hard-coded limits based on the specification above.\nconst RATE_LIMITS: Record<ApiCategory, RateLimitConfig> = {\n loginTaxpayer: { limit: 12, windowMs: WINDOW },\n loginIntermediary: { limit: 12, windowMs: WINDOW },\n submitDocuments: { limit: 100, windowMs: WINDOW },\n getSubmission: { limit: 300, windowMs: WINDOW },\n cancelDocument: { limit: 12, windowMs: WINDOW },\n rejectDocument: { limit: 12, windowMs: WINDOW },\n getDocument: { limit: 60, windowMs: WINDOW },\n getDocumentDetails: { limit: 125, windowMs: WINDOW },\n getRecentDocuments: { limit: 12, windowMs: WINDOW },\n searchDocuments: { limit: 12, windowMs: WINDOW },\n searchTin: { limit: 60, windowMs: WINDOW },\n taxpayerQr: { limit: 60, windowMs: WINDOW },\n default: { limit: 10_000, windowMs: WINDOW }, // effectively no limit\n}\n\n/**\n * A very small token-bucket style rate-limiter with queuing.\n * Instead of allowing a full-window burst (which could trigger a 429),\n * requests are spaced evenly so the throughput stays within the\n * <limit>/<window> budget at all times. Each category gets its own\n * instance so limits remain isolated.\n */\nclass RateLimiter {\n private readonly limit: number\n private readonly windowMs: number\n private readonly minInterval: number\n\n private queue: Array<() => void> = []\n private nextAvailable = 0 // timestamp (ms) when the next request can be executed\n private timer: NodeJS.Timeout | null = null\n\n constructor(config: RateLimitConfig) {\n this.limit = config.limit\n this.windowMs = config.windowMs\n const baseInterval = Math.ceil(this.windowMs / this.limit)\n const isTestEnv = process.env.NODE_ENV === 'test'\n const forceReal = process.env.APIQUEUE_REAL_INTERVAL === 'true'\n // In unit-test envs we collapse spacing unless explicitly forced back on.\n this.minInterval = isTestEnv && !forceReal ? 0 : baseInterval\n }\n\n private drainQueue() {\n if (this.queue.length === 0) {\n return\n }\n\n const now = Date.now()\n if (now < this.nextAvailable) {\n // Too early – schedule when we're allowed to execute next\n if (!this.timer) {\n this.timer = setTimeout(() => {\n this.timer = null\n this.drainQueue()\n }, this.nextAvailable - now)\n }\n return\n }\n\n // Execute the next queued task\n const next = this.queue.shift()!\n this.nextAvailable = Date.now() + this.minInterval\n next()\n\n // Attempt to drain further (may schedule another run if cannot execute immediately)\n this.drainQueue()\n }\n\n get queueSize() {\n return this.queue.length\n }\n\n schedule<T>(\n fn: () => Promise<T>,\n debug: boolean = false,\n category?: ApiCategory,\n ): Promise<T> {\n return new Promise((resolve, reject) => {\n const execute = () => {\n if (debug && category) {\n console.log(\n `[apiQueue] ▶️ Executing request (${category}). Remaining queue: ${this.queue.length}`,\n )\n }\n try {\n const result = fn()\n if (result && typeof (result as any).then === 'function') {\n ;(result as Promise<T>).then(resolve).catch(reject)\n } else {\n resolve(result as T)\n }\n } catch (err) {\n reject(err)\n }\n }\n\n if (debug && category) {\n console.log(\n `[apiQueue] ⏳ Queued request (${category}). Queue length before push: ${this.queue.length}`,\n )\n }\n\n this.queue.push(execute)\n this.drainQueue()\n })\n }\n}\n\n// A shared registry of limiters keyed by category\nconst limiterRegistry = new Map<ApiCategory, RateLimiter>()\n\nfunction getLimiter(category: ApiCategory): RateLimiter {\n if (!limiterRegistry.has(category)) {\n limiterRegistry.set(category, new RateLimiter(RATE_LIMITS[category]))\n }\n // Non-null because we just set it if missing.\n return limiterRegistry.get(category) as RateLimiter\n}\n\n/**\n * Public helper to schedule a request according to the category's limits.\n */\nexport function queueRequest<T>(\n category: ApiCategory,\n fn: () => Promise<T>,\n debug: boolean = false,\n): Promise<T> {\n const limiter = getLimiter(category)\n return limiter.schedule(fn, debug, category)\n}\n\n/**\n * Very naive path-based category detection. If no matcher fits, the `default` category\n * (effectively unlimited) is returned. Adjust these heuristics as your API surface evolves.\n */\nexport function categorizeRequest(\n path: string,\n method: string = 'GET',\n): ApiCategory {\n const cleanPath = path.toLowerCase()\n const isPost = method?.toUpperCase() === 'POST'\n\n if (cleanPath.includes('/documentsubmissions')) {\n return isPost ? 'submitDocuments' : 'getSubmission'\n }\n\n if (cleanPath.includes('/documentmanagement')) {\n if (cleanPath.endsWith('/cancel')) return 'cancelDocument'\n if (cleanPath.endsWith('/reject')) return 'rejectDocument'\n if (cleanPath.endsWith('/details')) return 'getDocumentDetails'\n if (cleanPath.includes('/recent')) return 'getRecentDocuments'\n // Fallbacks inside document management\n return method === 'GET' ? 'getDocument' : 'searchDocuments'\n }\n\n if (cleanPath.includes('/searchtin')) return 'searchTin'\n if (cleanPath.includes('/qrcode')) return 'taxpayerQr'\n if (cleanPath.includes('/connect/token')) {\n // Distinguish between taxpayer & intermediary based on path hint if possible\n return 'loginTaxpayer'\n }\n\n // -----------------------------\n // New path matchers (v1.0 endpoints)\n // -----------------------------\n\n // Search Documents\n if (cleanPath.includes('/documents/search')) {\n return 'searchDocuments'\n }\n\n // Document raw content\n if (/\\/documents\\/[^/]+\\/raw$/.test(cleanPath)) {\n return 'getDocument'\n }\n\n // Document details\n if (/\\/documents\\/[^/]+\\/details$/.test(cleanPath)) {\n return 'getDocumentDetails'\n }\n\n // Document state actions (cancel/reject)\n if (cleanPath.includes('/documents/state/')) {\n return isPost ? 'cancelDocument' : 'getDocument'\n }\n\n // Taxpayer TIN search & validation share same limit bucket\n if (cleanPath.includes('/taxpayer/search/tin')) return 'searchTin'\n if (cleanPath.includes('/taxpayer/validate/')) return 'searchTin'\n\n // Taxpayer QR code info\n if (cleanPath.includes('/taxpayer/qrcode')) return 'taxpayerQr'\n\n return 'default'\n}\n"],"mappings":"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"}
@@ -89,7 +89,7 @@ async function getSubmissionStatus(context, submissionUid, pollInterval = 1e3, m
89
89
  return await getSubmissionStatus(context, submissionUid, pollInterval, maxRetries - 1);
90
90
  }
91
91
  return {
92
- status: "Invalid",
92
+ status: "TimedOut",
93
93
  error: {
94
94
  code: "Timeout",
95
95
  message: "Submission timed out",
@@ -104,7 +104,7 @@ async function getSubmissionStatus(context, submissionUid, pollInterval = 1e3, m
104
104
  return await getSubmissionStatus(context, submissionUid, pollInterval, maxRetries - 1);
105
105
  }
106
106
  return {
107
- status: "Invalid",
107
+ status: "TimedOut",
108
108
  error: {
109
109
  code: "Timeout",
110
110
  message: "Submission timed out after request errors",
@@ -145,4 +145,4 @@ Object.defineProperty(exports, 'submitDocument', {
145
145
  return submitDocument;
146
146
  }
147
147
  });
148
- //# sourceMappingURL=documentSubmission-DG5pfaBQ.cjs.map
148
+ //# sourceMappingURL=documentSubmission-6_5gC9YE.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"documentSubmission-DG5pfaBQ.cjs","names":["context: SubmissionContext","documents: AllDocumentsV1_1[]","context: Pick<SubmissionContext, 'fetch' | 'debug'>","submissionUid: string","pollInterval: number","maxRetries: number","documentUid: string","status: 'rejected' | 'cancelled'","reason: string"],"sources":["../src/api/documentSubmission.ts"],"sourcesContent":["import type {\n AllDocumentsV1_1,\n SubmissionResponse,\n SigningCredentials,\n SubmissionStatus,\n DocumentSummary,\n Fetch,\n StandardError,\n} from '../types'\nimport { generateCompleteDocument } from '../utils/document'\n\ninterface SubmissionContext {\n fetch: Fetch\n debug: boolean\n signingCredentials: SigningCredentials\n}\n\nexport async function submitDocument(\n context: SubmissionContext,\n documents: AllDocumentsV1_1[],\n): Promise<{\n data: SubmissionResponse\n status: number\n}> {\n const { fetch, debug, signingCredentials } = context\n\n // 🔒 Hard enforcement of platform submission limits\n if (documents.length > 100) {\n throw new Error(\n 'Submission rejected: Cannot submit more than 100 documents at once',\n )\n }\n\n if (debug) {\n console.log(`📦 Preparing to submit ${documents.length} document(s)...`)\n }\n\n // For batch submission, each document must be signed and encoded separately\n // Build the submission payload according to MyInvois API format\n const crypto = await import('crypto')\n\n const submissionPayload = {\n documents: await Promise.all(\n documents.map(async doc => {\n // 1️⃣ Sign the single document (generateCompleteDocument expects an array)\n const signedDocument = generateCompleteDocument(\n [doc],\n signingCredentials,\n )\n\n // 2️⃣ Serialize\n const docJson = JSON.stringify(signedDocument)\n\n // 3️⃣ Hash\n const docHash = crypto\n .createHash('sha256')\n .update(docJson, 'utf8')\n .digest('hex')\n\n // 4️⃣ Base64 encode\n const docBase64 = Buffer.from(docJson, 'utf8').toString('base64')\n\n // 🚨 Enforce 300 KB per-document limit\n const rawSize = Buffer.byteLength(docBase64, 'base64')\n if (rawSize > 300 * 1024) {\n throw new Error(\n `Submission rejected: Document ${doc.eInvoiceCodeOrNumber} is ${rawSize} bytes – exceeds 300KB limit`,\n )\n }\n\n if (debug) {\n console.log('—'.repeat(60))\n console.log(`📄 Prepared document: ${doc.eInvoiceCodeOrNumber}`)\n console.log(` • JSON size : ${docJson.length} bytes`)\n console.log(` • Base64 size: ${docBase64.length} bytes`)\n }\n\n return {\n format: 'JSON',\n document: docBase64,\n documentHash: docHash,\n codeNumber: doc.eInvoiceCodeOrNumber,\n }\n }),\n ),\n }\n\n const payloadSize = Buffer.byteLength(JSON.stringify(submissionPayload))\n\n if (payloadSize > 5 * 1024 * 1024) {\n throw new Error(\n `Submission rejected: Payload is ${payloadSize} bytes – exceeds 5MB limit`,\n )\n }\n\n if (debug) {\n console.log('🚀 Submission payload structure:')\n console.log('- Format: JSON')\n console.log('- Documents count:', submissionPayload.documents.length)\n console.log('- Total payload size:', payloadSize, 'bytes')\n }\n\n // Submit to MyInvois API with proper headers\n const response = await fetch('/api/v1.0/documentsubmissions', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(submissionPayload),\n })\n\n const responseData = (await response.json()) as SubmissionResponse\n\n if (debug) {\n console.log(`📡 API Response status: ${response.status}`)\n\n if (responseData.rejectedDocuments?.length > 0) {\n responseData.rejectedDocuments.forEach((doc, index) => {\n console.log(` Document ${index + 1}:`, doc.invoiceCodeNumber)\n if (doc.error) {\n console.log(` Error:`, doc.error.message)\n if (doc.error.details) {\n doc.error.details.forEach((detail, detailIndex) => {\n console.log(` Detail ${detailIndex + 1}:`, detail.message)\n })\n }\n }\n })\n }\n }\n\n const data = responseData as SubmissionResponse\n\n if (debug) {\n if (response.status !== 202) {\n console.error('❌ Submission failed with status:', response.status)\n console.error('❌ Response data:', JSON.stringify(data, null, 2))\n } else {\n console.log('✅ Submission successful!')\n console.log(`📋 Submission UID: ${data.submissionUid}`)\n console.log(\n `✅ Accepted documents: ${data.acceptedDocuments?.length || 0}`,\n )\n console.log(\n `❌ Rejected documents: ${data.rejectedDocuments?.length || 0}`,\n )\n }\n }\n\n return {\n data,\n status: response.status,\n }\n}\n\nexport async function getSubmissionStatus(\n context: Pick<SubmissionContext, 'fetch' | 'debug'>,\n submissionUid: string,\n pollInterval: number = 1000,\n maxRetries: number = 10,\n): Promise<{\n status: SubmissionStatus\n documentSummary?: DocumentSummary[]\n error?: {\n code: string\n message: string | null\n target: string\n details: {\n code: string\n message: string\n target: string\n }[]\n }\n}> {\n const { fetch, debug } = context\n\n try {\n const response = await fetch(\n `/api/v1.0/documentsubmissions/${submissionUid}`,\n )\n\n const data = await response.json()\n\n if (debug) {\n console.log('Submission:', data)\n if (data.error) {\n console.log('Submission error details:', data.error.details)\n }\n }\n\n // If we have a successful response and status is completed, return success\n if (data.overallStatus === 'Valid') {\n return {\n status: data.overallStatus,\n documentSummary: data.documentSummary,\n }\n }\n if (data.overallStatus === 'Invalid') {\n return {\n status: 'Invalid',\n documentSummary: data.documentSummary,\n }\n }\n\n // If we have retries left, continue polling for any non-completed status or errors\n if (maxRetries > 0) {\n await new Promise(resolve => setTimeout(resolve, pollInterval))\n return await getSubmissionStatus(\n context,\n submissionUid,\n pollInterval,\n maxRetries - 1,\n )\n }\n\n // No retries left - return timeout\n return {\n status: 'Invalid',\n error: {\n code: 'Timeout',\n message: 'Submission timed out',\n target: 'submission',\n details: [],\n },\n }\n } catch (error) {\n // Handle any request errors by retrying if we have retries left\n if (maxRetries > 0) {\n if (debug) {\n console.log('Request error, retrying...', error)\n }\n await new Promise(resolve => setTimeout(resolve, pollInterval))\n return await getSubmissionStatus(\n context,\n submissionUid,\n pollInterval,\n maxRetries - 1,\n )\n }\n\n // No retries left - return timeout\n return {\n status: 'Invalid',\n error: {\n code: 'Timeout',\n message: 'Submission timed out after request errors',\n target: 'submission',\n details: [],\n },\n }\n }\n}\n\nexport async function performDocumentAction(\n documentUid: string,\n status: 'rejected' | 'cancelled',\n reason: string,\n): Promise<{\n uuid: string\n status: string\n error: StandardError\n}> {\n const response = await fetch(\n `/api/v1.0/documents/state/${documentUid}/state`,\n {\n method: 'POST',\n body: JSON.stringify({\n status,\n reason,\n }),\n },\n )\n\n const data = (await response.json()) as {\n uuid: string\n status: string\n error: StandardError\n }\n\n return data\n}\n"],"mappings":";;;AAiBA,eAAsB,eACpBA,SACAC,WAIC;CACD,MAAM,EAAE,gBAAO,OAAO,oBAAoB,GAAG;AAG7C,KAAI,UAAU,SAAS,IACrB,OAAM,IAAI,MACR;AAIJ,KAAI,MACF,SAAQ,KAAK,yBAAyB,UAAU,OAAO,iBAAiB;CAK1E,MAAM,SAAS,MAAM,OAAO;CAE5B,MAAM,oBAAoB,EACxB,WAAW,MAAM,QAAQ,IACvB,UAAU,IAAI,OAAM,QAAO;EAEzB,MAAM,iBAAiB,0CACrB,CAAC,GAAI,GACL,mBACD;EAGD,MAAM,UAAU,KAAK,UAAU,eAAe;EAG9C,MAAM,UAAU,OACb,WAAW,SAAS,CACpB,OAAO,SAAS,OAAO,CACvB,OAAO,MAAM;EAGhB,MAAM,YAAY,OAAO,KAAK,SAAS,OAAO,CAAC,SAAS,SAAS;EAGjE,MAAM,UAAU,OAAO,WAAW,WAAW,SAAS;AACtD,MAAI,UAAU,MAAM,KAClB,OAAM,IAAI,OACP,gCAAgC,IAAI,qBAAqB,MAAM,QAAQ;AAI5E,MAAI,OAAO;AACT,WAAQ,IAAI,IAAI,OAAO,GAAG,CAAC;AAC3B,WAAQ,KAAK,wBAAwB,IAAI,qBAAqB,EAAE;AAChE,WAAQ,KAAK,mBAAmB,QAAQ,OAAO,QAAQ;AACvD,WAAQ,KAAK,oBAAoB,UAAU,OAAO,QAAQ;EAC3D;AAED,SAAO;GACL,QAAQ;GACR,UAAU;GACV,cAAc;GACd,YAAY,IAAI;EACjB;CACF,EAAC,CACH,CACF;CAED,MAAM,cAAc,OAAO,WAAW,KAAK,UAAU,kBAAkB,CAAC;AAExE,KAAI,cAAc,IAAI,OAAO,KAC3B,OAAM,IAAI,OACP,kCAAkC,YAAY;AAInD,KAAI,OAAO;AACT,UAAQ,IAAI,mCAAmC;AAC/C,UAAQ,IAAI,iBAAiB;AAC7B,UAAQ,IAAI,sBAAsB,kBAAkB,UAAU,OAAO;AACrE,UAAQ,IAAI,yBAAyB,aAAa,QAAQ;CAC3D;CAGD,MAAM,WAAW,MAAM,QAAM,iCAAiC;EAC5D,QAAQ;EACR,SAAS,EACP,gBAAgB,mBACjB;EACD,MAAM,KAAK,UAAU,kBAAkB;CACxC,EAAC;CAEF,MAAM,eAAgB,MAAM,SAAS,MAAM;AAE3C,KAAI,OAAO;AACT,UAAQ,KAAK,0BAA0B,SAAS,OAAO,EAAE;AAEzD,MAAI,aAAa,mBAAmB,SAAS,EAC3C,cAAa,kBAAkB,QAAQ,CAAC,KAAK,UAAU;AACrD,WAAQ,KAAK,aAAa,QAAQ,EAAE,IAAI,IAAI,kBAAkB;AAC9D,OAAI,IAAI,OAAO;AACb,YAAQ,KAAK,aAAa,IAAI,MAAM,QAAQ;AAC5C,QAAI,IAAI,MAAM,QACZ,KAAI,MAAM,QAAQ,QAAQ,CAAC,QAAQ,gBAAgB;AACjD,aAAQ,KAAK,eAAe,cAAc,EAAE,IAAI,OAAO,QAAQ;IAChE,EAAC;GAEL;EACF,EAAC;CAEL;CAED,MAAM,OAAO;AAEb,KAAI,MACF,KAAI,SAAS,WAAW,KAAK;AAC3B,UAAQ,MAAM,oCAAoC,SAAS,OAAO;AAClE,UAAQ,MAAM,oBAAoB,KAAK,UAAU,MAAM,MAAM,EAAE,CAAC;CACjE,OAAM;AACL,UAAQ,IAAI,2BAA2B;AACvC,UAAQ,KAAK,qBAAqB,KAAK,cAAc,EAAE;AACvD,UAAQ,KACL,wBAAwB,KAAK,mBAAmB,UAAU,EAAE,EAC9D;AACD,UAAQ,KACL,wBAAwB,KAAK,mBAAmB,UAAU,EAAE,EAC9D;CACF;AAGH,QAAO;EACL;EACA,QAAQ,SAAS;CAClB;AACF;AAED,eAAsB,oBACpBC,SACAC,eACAC,eAAuB,KACvBC,aAAqB,IAcpB;CACD,MAAM,EAAE,gBAAO,OAAO,GAAG;AAEzB,KAAI;EACF,MAAM,WAAW,MAAM,SACpB,gCAAgC,cAAc,EAChD;EAED,MAAM,OAAO,MAAM,SAAS,MAAM;AAElC,MAAI,OAAO;AACT,WAAQ,IAAI,eAAe,KAAK;AAChC,OAAI,KAAK,MACP,SAAQ,IAAI,6BAA6B,KAAK,MAAM,QAAQ;EAE/D;AAGD,MAAI,KAAK,kBAAkB,QACzB,QAAO;GACL,QAAQ,KAAK;GACb,iBAAiB,KAAK;EACvB;AAEH,MAAI,KAAK,kBAAkB,UACzB,QAAO;GACL,QAAQ;GACR,iBAAiB,KAAK;EACvB;AAIH,MAAI,aAAa,GAAG;AAClB,SAAM,IAAI,QAAQ,aAAW,WAAW,SAAS,aAAa;AAC9D,UAAO,MAAM,oBACX,SACA,eACA,cACA,aAAa,EACd;EACF;AAGD,SAAO;GACL,QAAQ;GACR,OAAO;IACL,MAAM;IACN,SAAS;IACT,QAAQ;IACR,SAAS,CAAE;GACZ;EACF;CACF,SAAQ,OAAO;AAEd,MAAI,aAAa,GAAG;AAClB,OAAI,MACF,SAAQ,IAAI,8BAA8B,MAAM;AAElD,SAAM,IAAI,QAAQ,aAAW,WAAW,SAAS,aAAa;AAC9D,UAAO,MAAM,oBACX,SACA,eACA,cACA,aAAa,EACd;EACF;AAGD,SAAO;GACL,QAAQ;GACR,OAAO;IACL,MAAM;IACN,SAAS;IACT,QAAQ;IACR,SAAS,CAAE;GACZ;EACF;CACF;AACF;AAED,eAAsB,sBACpBC,aACAC,QACAC,QAKC;CACD,MAAM,WAAW,MAAM,OACpB,4BAA4B,YAAY,SACzC;EACE,QAAQ;EACR,MAAM,KAAK,UAAU;GACnB;GACA;EACD,EAAC;CACH,EACF;CAED,MAAM,OAAQ,MAAM,SAAS,MAAM;AAMnC,QAAO;AACR"}
1
+ {"version":3,"file":"documentSubmission-6_5gC9YE.cjs","names":["context: SubmissionContext","documents: AllDocumentsV1_1[]","context: Pick<SubmissionContext, 'fetch' | 'debug'>","submissionUid: string","pollInterval: number","maxRetries: number","documentUid: string","status: 'rejected' | 'cancelled'","reason: string"],"sources":["../src/api/documentSubmission.ts"],"sourcesContent":["import type {\n AllDocumentsV1_1,\n SubmissionResponse,\n SigningCredentials,\n SubmissionStatus,\n DocumentSummary,\n Fetch,\n StandardError,\n} from '../types'\nimport { generateCompleteDocument } from '../utils/document'\n\ninterface SubmissionContext {\n fetch: Fetch\n debug: boolean\n signingCredentials: SigningCredentials\n}\n\nexport async function submitDocument(\n context: SubmissionContext,\n documents: AllDocumentsV1_1[],\n): Promise<{\n data: SubmissionResponse\n status: number\n}> {\n const { fetch, debug, signingCredentials } = context\n\n // 🔒 Hard enforcement of platform submission limits\n if (documents.length > 100) {\n throw new Error(\n 'Submission rejected: Cannot submit more than 100 documents at once',\n )\n }\n\n if (debug) {\n console.log(`📦 Preparing to submit ${documents.length} document(s)...`)\n }\n\n // For batch submission, each document must be signed and encoded separately\n // Build the submission payload according to MyInvois API format\n const crypto = await import('crypto')\n\n const submissionPayload = {\n documents: await Promise.all(\n documents.map(async doc => {\n // 1️⃣ Sign the single document (generateCompleteDocument expects an array)\n const signedDocument = generateCompleteDocument(\n [doc],\n signingCredentials,\n )\n\n // 2️⃣ Serialize\n const docJson = JSON.stringify(signedDocument)\n\n // 3️⃣ Hash\n const docHash = crypto\n .createHash('sha256')\n .update(docJson, 'utf8')\n .digest('hex')\n\n // 4️⃣ Base64 encode\n const docBase64 = Buffer.from(docJson, 'utf8').toString('base64')\n\n // 🚨 Enforce 300 KB per-document limit\n const rawSize = Buffer.byteLength(docBase64, 'base64')\n if (rawSize > 300 * 1024) {\n throw new Error(\n `Submission rejected: Document ${doc.eInvoiceCodeOrNumber} is ${rawSize} bytes – exceeds 300KB limit`,\n )\n }\n\n if (debug) {\n console.log('—'.repeat(60))\n console.log(`📄 Prepared document: ${doc.eInvoiceCodeOrNumber}`)\n console.log(` • JSON size : ${docJson.length} bytes`)\n console.log(` • Base64 size: ${docBase64.length} bytes`)\n }\n\n return {\n format: 'JSON',\n document: docBase64,\n documentHash: docHash,\n codeNumber: doc.eInvoiceCodeOrNumber,\n }\n }),\n ),\n }\n\n const payloadSize = Buffer.byteLength(JSON.stringify(submissionPayload))\n\n if (payloadSize > 5 * 1024 * 1024) {\n throw new Error(\n `Submission rejected: Payload is ${payloadSize} bytes – exceeds 5MB limit`,\n )\n }\n\n if (debug) {\n console.log('🚀 Submission payload structure:')\n console.log('- Format: JSON')\n console.log('- Documents count:', submissionPayload.documents.length)\n console.log('- Total payload size:', payloadSize, 'bytes')\n }\n\n // Submit to MyInvois API with proper headers\n const response = await fetch('/api/v1.0/documentsubmissions', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(submissionPayload),\n })\n\n const responseData = (await response.json()) as SubmissionResponse\n\n if (debug) {\n console.log(`📡 API Response status: ${response.status}`)\n\n if (responseData.rejectedDocuments?.length > 0) {\n responseData.rejectedDocuments.forEach((doc, index) => {\n console.log(` Document ${index + 1}:`, doc.invoiceCodeNumber)\n if (doc.error) {\n console.log(` Error:`, doc.error.message)\n if (doc.error.details) {\n doc.error.details.forEach((detail, detailIndex) => {\n console.log(` Detail ${detailIndex + 1}:`, detail.message)\n })\n }\n }\n })\n }\n }\n\n const data = responseData as SubmissionResponse\n\n if (debug) {\n if (response.status !== 202) {\n console.error('❌ Submission failed with status:', response.status)\n console.error('❌ Response data:', JSON.stringify(data, null, 2))\n } else {\n console.log('✅ Submission successful!')\n console.log(`📋 Submission UID: ${data.submissionUid}`)\n console.log(\n `✅ Accepted documents: ${data.acceptedDocuments?.length || 0}`,\n )\n console.log(\n `❌ Rejected documents: ${data.rejectedDocuments?.length || 0}`,\n )\n }\n }\n\n return {\n data,\n status: response.status,\n }\n}\n\nexport async function getSubmissionStatus(\n context: Pick<SubmissionContext, 'fetch' | 'debug'>,\n submissionUid: string,\n pollInterval: number = 1000,\n maxRetries: number = 10,\n): Promise<{\n status: SubmissionStatus\n documentSummary?: DocumentSummary[]\n error?: {\n code: string\n message: string | null\n target: string\n details: {\n code: string\n message: string\n target: string\n }[]\n }\n}> {\n const { fetch, debug } = context\n\n try {\n const response = await fetch(\n `/api/v1.0/documentsubmissions/${submissionUid}`,\n )\n\n const data = await response.json()\n\n if (debug) {\n console.log('Submission:', data)\n if (data.error) {\n console.log('Submission error details:', data.error.details)\n }\n }\n\n // If we have a successful response and status is completed, return success\n if (data.overallStatus === 'Valid') {\n return {\n status: data.overallStatus,\n documentSummary: data.documentSummary,\n }\n }\n if (data.overallStatus === 'Invalid') {\n return {\n status: 'Invalid',\n documentSummary: data.documentSummary,\n }\n }\n\n // If we have retries left, continue polling for any non-completed status or errors\n if (maxRetries > 0) {\n await new Promise(resolve => setTimeout(resolve, pollInterval))\n return await getSubmissionStatus(\n context,\n submissionUid,\n pollInterval,\n maxRetries - 1,\n )\n }\n\n // No retries left - return timeout\n return {\n status: 'TimedOut',\n error: {\n code: 'Timeout',\n message: 'Submission timed out',\n target: 'submission',\n details: [],\n },\n }\n } catch (error) {\n // Handle any request errors by retrying if we have retries left\n if (maxRetries > 0) {\n if (debug) {\n console.log('Request error, retrying...', error)\n }\n await new Promise(resolve => setTimeout(resolve, pollInterval))\n return await getSubmissionStatus(\n context,\n submissionUid,\n pollInterval,\n maxRetries - 1,\n )\n }\n\n // No retries left - return timeout\n return {\n status: 'TimedOut',\n error: {\n code: 'Timeout',\n message: 'Submission timed out after request errors',\n target: 'submission',\n details: [],\n },\n }\n }\n}\n\nexport async function performDocumentAction(\n documentUid: string,\n status: 'rejected' | 'cancelled',\n reason: string,\n): Promise<{\n uuid: string\n status: string\n error: StandardError\n}> {\n const response = await fetch(\n `/api/v1.0/documents/state/${documentUid}/state`,\n {\n method: 'POST',\n body: JSON.stringify({\n status,\n reason,\n }),\n },\n )\n\n const data = (await response.json()) as {\n uuid: string\n status: string\n error: StandardError\n }\n\n return data\n}\n"],"mappings":"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"}
@@ -89,7 +89,7 @@ async function getSubmissionStatus(context, submissionUid, pollInterval = 1e3, m
89
89
  return await getSubmissionStatus(context, submissionUid, pollInterval, maxRetries - 1);
90
90
  }
91
91
  return {
92
- status: "Invalid",
92
+ status: "TimedOut",
93
93
  error: {
94
94
  code: "Timeout",
95
95
  message: "Submission timed out",
@@ -104,7 +104,7 @@ async function getSubmissionStatus(context, submissionUid, pollInterval = 1e3, m
104
104
  return await getSubmissionStatus(context, submissionUid, pollInterval, maxRetries - 1);
105
105
  }
106
106
  return {
107
- status: "Invalid",
107
+ status: "TimedOut",
108
108
  error: {
109
109
  code: "Timeout",
110
110
  message: "Submission timed out after request errors",
@@ -463,7 +463,7 @@ interface SelfBilledRefundNoteV1_1 {
463
463
  taxTotal: TaxTotal;
464
464
  }
465
465
  type AllDocumentsV1_1 = InvoiceV1_1 | CreditNoteV1_1 | DebitNoteV1_1 | RefundNoteV1_1 | SelfBilledInvoiceV1_1 | SelfBilledCreditNoteV1_1 | SelfBilledRefundNoteV1_1;
466
- type SubmissionStatus = 'InProgress' | 'Valid' | 'PartiallyValid' | 'Invalid';
466
+ type SubmissionStatus = 'InProgress' | 'Valid' | 'PartiallyValid' | 'Invalid' | 'TimedOut';
467
467
  type DocumentStatus = 'Valid' | 'Invalid' | 'Cancelled' | 'Submitted';
468
468
  type StandardError = {
469
469
  code: string;
@@ -1124,4 +1124,4 @@ interface DocumentTypeVersionResponse {
1124
1124
  }
1125
1125
  //#endregion
1126
1126
  export { Address, AllDocumentsV1_1, Buyer, CompleteInvoice, CreditNoteV1_1, DebitNoteV1_1, DocumentStatus, DocumentSummary, DocumentTypeResponse, DocumentTypeVersion, DocumentTypeVersionResponse, DocumentTypesResponse, DocumentValidationResult, DocumentValidationStepResult, FinalDocumentData, GetSubmissionResponse, InvoiceLineItem, InvoiceSubmission, InvoiceV1_1, LegalMonetaryTotal, RefundNoteV1_1, RegistrationType, ResponseDocument, SelfBilledCreditNoteV1_1, SelfBilledInvoiceV1_1, SelfBilledRefundNoteV1_1, SignedInfoObject, SignedInvoiceSubmission, SignedPropertiesData, SignedPropertiesObject, SigningCredentials, StandardError, SubmissionResponse, SubmissionStatus, Supplier, TaxCategory, TaxSubtotal, TaxTotal, UBLDocument, WorkflowParameter };
1127
- //# sourceMappingURL=documents-DSZZujgx.d.cts.map
1127
+ //# sourceMappingURL=documents-BJPF2I_j.d.cts.map
@@ -463,7 +463,7 @@ interface SelfBilledRefundNoteV1_1 {
463
463
  taxTotal: TaxTotal;
464
464
  }
465
465
  type AllDocumentsV1_1 = InvoiceV1_1 | CreditNoteV1_1 | DebitNoteV1_1 | RefundNoteV1_1 | SelfBilledInvoiceV1_1 | SelfBilledCreditNoteV1_1 | SelfBilledRefundNoteV1_1;
466
- type SubmissionStatus = 'InProgress' | 'Valid' | 'PartiallyValid' | 'Invalid';
466
+ type SubmissionStatus = 'InProgress' | 'Valid' | 'PartiallyValid' | 'Invalid' | 'TimedOut';
467
467
  type DocumentStatus = 'Valid' | 'Invalid' | 'Cancelled' | 'Submitted';
468
468
  type StandardError = {
469
469
  code: string;
package/dist/index.cjs CHANGED
@@ -1,14 +1,14 @@
1
1
  const require_documentManagement = require('./documentManagement-DQ7JEcBq.cjs');
2
2
  require('./formatIdValue-i67o4kyD.cjs');
3
3
  require('./document-CiBQaJ0c.cjs');
4
- const require_documentSubmission = require('./documentSubmission-DG5pfaBQ.cjs');
4
+ const require_documentSubmission = require('./documentSubmission-6_5gC9YE.cjs');
5
5
  const require_documentTypeManagement = require('./documentTypeManagement-D_-LiQVg.cjs');
6
6
  const require_notificationManagement = require('./notificationManagement-DLBDn77E.cjs');
7
7
  const require_platformLogin = require('./platformLogin-Ch6hFKoU.cjs');
8
8
  const require_taxpayerValidation = require('./taxpayerValidation-D_jGaVty.cjs');
9
9
  const require_certificate = require('./certificate-CWmfCPdt.cjs');
10
10
  const require_getBaseUrl = require('./getBaseUrl-D0G4GZmp.cjs');
11
- const require_apiQueue = require('./apiQueue-CRyjAw52.cjs');
11
+ const require_apiQueue = require('./apiQueue-DDXeQJDC.cjs');
12
12
 
13
13
  //#region src/index.ts
14
14
  var MyInvoisClient = class MyInvoisClient {
package/dist/index.d.ts CHANGED
@@ -51,11 +51,11 @@ import "./YX-F34sJ7Ik.js";
51
51
  import "./ZX-CDQOfsHh.js";
52
52
  import "./XX-DOA-10JW.js";
53
53
  import { UnitType, UnitTypeCode } from "./unit-types-VgYXIwTT.js";
54
- import { Address, AllDocumentsV1_1, Buyer, CompleteInvoice, CreditNoteV1_1, DebitNoteV1_1, DocumentStatus, DocumentSummary, DocumentTypeResponse, DocumentTypeVersion, DocumentTypeVersionResponse, DocumentTypesResponse, DocumentValidationResult, DocumentValidationStepResult, FinalDocumentData, GetSubmissionResponse, InvoiceLineItem, InvoiceSubmission, InvoiceV1_1, LegalMonetaryTotal, RefundNoteV1_1, RegistrationType, ResponseDocument, SelfBilledCreditNoteV1_1, SelfBilledInvoiceV1_1, SelfBilledRefundNoteV1_1, SignedInfoObject, SignedInvoiceSubmission, SignedPropertiesData, SignedPropertiesObject, SigningCredentials, StandardError, SubmissionResponse, SubmissionStatus, Supplier, TaxCategory, TaxSubtotal, TaxTotal, UBLDocument, WorkflowParameter } from "./documents-CkoydYUK.js";
54
+ import { Address, AllDocumentsV1_1, Buyer, CompleteInvoice, CreditNoteV1_1, DebitNoteV1_1, DocumentStatus, DocumentSummary, DocumentTypeResponse, DocumentTypeVersion, DocumentTypeVersionResponse, DocumentTypesResponse, DocumentValidationResult, DocumentValidationStepResult, FinalDocumentData, GetSubmissionResponse, InvoiceLineItem, InvoiceSubmission, InvoiceV1_1, LegalMonetaryTotal, RefundNoteV1_1, RegistrationType, ResponseDocument, SelfBilledCreditNoteV1_1, SelfBilledInvoiceV1_1, SelfBilledRefundNoteV1_1, SignedInfoObject, SignedInvoiceSubmission, SignedPropertiesData, SignedPropertiesObject, SigningCredentials, StandardError, SubmissionResponse, SubmissionStatus, Supplier, TaxCategory, TaxSubtotal, TaxTotal, UBLDocument, WorkflowParameter } from "./documents-WC-gApLM.js";
55
55
  import { PaymentMode, PaymentModeCode, PaymentModeCodeEnum } from "./payment-modes-g3DzLmWb.js";
56
56
  import { CanonicalizationMethod, Cert, CertDigest, DigestMethod, IssuerDigitalSignature, IssuerSerial, KeyInfo, QualifyingProperties, Reference, SignatureMethod, SignedInfo, SignedProperties, SignedSignatureProperties, SigningCertificate, Transform, X509Data } from "./signatures-CerHUrj3.js";
57
57
  import { Notification, NotificationDeliveryAttempt, NotificationMetadata, NotificationResponse, NotificationSearchParams, NotificationStatus, NotificationStatusEnum, NotificationType, NotificationTypeEnum } from "./notifications-sFhgh3rJ.js";
58
- import { TaxpayerQRCodeResponse, TinSearchParams, TinSearchResponse } from "./taxpayer-szi2f7gT.js";
58
+ import { TaxpayerQRCodeResponse, TinSearchParams, TinSearchResponse } from "./taxpayer-Bz-fJYfF.js";
59
59
  import { Fetch } from "./utils-C4FoVKLq.js";
60
60
  import { ClientCredentials, TokenResponse } from "./index-CygwSf0x.js";
61
61
 
package/dist/index.js CHANGED
@@ -1,14 +1,14 @@
1
1
  import { getDocument, getDocumentDetails, searchDocuments } from "./documentManagement-CIQPkmyb.js";
2
2
  import "./formatIdValue-qTxJqj9o.js";
3
3
  import "./document-SQQDNoI-.js";
4
- import { getSubmissionStatus, performDocumentAction, submitDocument } from "./documentSubmission-B45EflkR.js";
4
+ import { getSubmissionStatus, performDocumentAction, submitDocument } from "./documentSubmission-BoGTlQFb.js";
5
5
  import { getDocumentType, getDocumentTypeVersion, getDocumentTypes } from "./documentTypeManagement-cBtVCOY3.js";
6
6
  import { getNotifications } from "./notificationManagement-n4Z5e-My.js";
7
7
  import { platformLogin } from "./platformLogin-CqI9OLYP.js";
8
8
  import { taxpayerQRCode, tinSearch, verifyTin } from "./taxpayerValidation-y6P-Es0S.js";
9
9
  import { extractCertificateInfo, getPemFromP12, validateKeyPair } from "./certificate-COwqszxD.js";
10
10
  import { getBaseUrl } from "./getBaseUrl-D7nUmoYb.js";
11
- import { categorizeRequest, queueRequest } from "./apiQueue-Csh8ru3S.js";
11
+ import { categorizeRequest, queueRequest } from "./apiQueue-BE3-DB1A.js";
12
12
 
13
13
  //#region src/index.ts
14
14
  var MyInvoisClient = class MyInvoisClient {
package/dist/index10.cjs CHANGED
@@ -1,25 +1,196 @@
1
1
 
2
- //#region src/types/payment-modes.d.ts
2
+ //#region src/types/currencies.d.ts
3
3
  /**
4
- * Enum representing the allowed payment mode codes with descriptive names.
5
- * Provides a more readable way to reference payment modes.
4
+ * Enum representing the allowed ISO-4217 3-letter currency codes.
5
+ * Provides a more readable way to reference currency codes.
6
6
  *
7
7
  * @example
8
- * const mode = PaymentModeCodeEnum.Cash;
9
- * console.log(mode); // Output: "01"
8
+ * const currency = CurrencyCodeEnum.MYR;
9
+ * console.log(currency); // Output: "MYR"
10
10
  */
11
- let PaymentModeCodeEnum = /* @__PURE__ */ function(PaymentModeCodeEnum$1) {
12
- PaymentModeCodeEnum$1["Cash"] = "01";
13
- PaymentModeCodeEnum$1["Cheque"] = "02";
14
- PaymentModeCodeEnum$1["BankTransfer"] = "03";
15
- PaymentModeCodeEnum$1["CreditCard"] = "04";
16
- PaymentModeCodeEnum$1["DebitCard"] = "05";
17
- PaymentModeCodeEnum$1["EWalletDigitalWallet"] = "06";
18
- PaymentModeCodeEnum$1["DigitalBank"] = "07";
19
- PaymentModeCodeEnum$1["Others"] = "08";
20
- return PaymentModeCodeEnum$1;
11
+ let CurrencyCodeEnum = /* @__PURE__ */ function(CurrencyCodeEnum$1) {
12
+ CurrencyCodeEnum$1["AED"] = "AED";
13
+ CurrencyCodeEnum$1["AFN"] = "AFN";
14
+ CurrencyCodeEnum$1["ALL"] = "ALL";
15
+ CurrencyCodeEnum$1["AMD"] = "AMD";
16
+ CurrencyCodeEnum$1["ANG"] = "ANG";
17
+ CurrencyCodeEnum$1["AOA"] = "AOA";
18
+ CurrencyCodeEnum$1["ARS"] = "ARS";
19
+ CurrencyCodeEnum$1["AUD"] = "AUD";
20
+ CurrencyCodeEnum$1["AWG"] = "AWG";
21
+ CurrencyCodeEnum$1["AZN"] = "AZN";
22
+ CurrencyCodeEnum$1["BAM"] = "BAM";
23
+ CurrencyCodeEnum$1["BBD"] = "BBD";
24
+ CurrencyCodeEnum$1["BDT"] = "BDT";
25
+ CurrencyCodeEnum$1["BGN"] = "BGN";
26
+ CurrencyCodeEnum$1["BHD"] = "BHD";
27
+ CurrencyCodeEnum$1["BIF"] = "BIF";
28
+ CurrencyCodeEnum$1["BMD"] = "BMD";
29
+ CurrencyCodeEnum$1["BND"] = "BND";
30
+ CurrencyCodeEnum$1["BOB"] = "BOB";
31
+ CurrencyCodeEnum$1["BOV"] = "BOV";
32
+ CurrencyCodeEnum$1["BRL"] = "BRL";
33
+ CurrencyCodeEnum$1["BSD"] = "BSD";
34
+ CurrencyCodeEnum$1["BTN"] = "BTN";
35
+ CurrencyCodeEnum$1["BWP"] = "BWP";
36
+ CurrencyCodeEnum$1["BYN"] = "BYN";
37
+ CurrencyCodeEnum$1["BZD"] = "BZD";
38
+ CurrencyCodeEnum$1["CAD"] = "CAD";
39
+ CurrencyCodeEnum$1["CDF"] = "CDF";
40
+ CurrencyCodeEnum$1["CHE"] = "CHE";
41
+ CurrencyCodeEnum$1["CHF"] = "CHF";
42
+ CurrencyCodeEnum$1["CHW"] = "CHW";
43
+ CurrencyCodeEnum$1["CLF"] = "CLF";
44
+ CurrencyCodeEnum$1["CLP"] = "CLP";
45
+ CurrencyCodeEnum$1["CNY"] = "CNY";
46
+ CurrencyCodeEnum$1["COP"] = "COP";
47
+ CurrencyCodeEnum$1["COU"] = "COU";
48
+ CurrencyCodeEnum$1["CRC"] = "CRC";
49
+ CurrencyCodeEnum$1["CUC"] = "CUC";
50
+ CurrencyCodeEnum$1["CUP"] = "CUP";
51
+ CurrencyCodeEnum$1["CVE"] = "CVE";
52
+ CurrencyCodeEnum$1["CZK"] = "CZK";
53
+ CurrencyCodeEnum$1["DJF"] = "DJF";
54
+ CurrencyCodeEnum$1["DKK"] = "DKK";
55
+ CurrencyCodeEnum$1["DOP"] = "DOP";
56
+ CurrencyCodeEnum$1["DZD"] = "DZD";
57
+ CurrencyCodeEnum$1["EGP"] = "EGP";
58
+ CurrencyCodeEnum$1["ERN"] = "ERN";
59
+ CurrencyCodeEnum$1["ETB"] = "ETB";
60
+ CurrencyCodeEnum$1["EUR"] = "EUR";
61
+ CurrencyCodeEnum$1["FJD"] = "FJD";
62
+ CurrencyCodeEnum$1["FKP"] = "FKP";
63
+ CurrencyCodeEnum$1["GBP"] = "GBP";
64
+ CurrencyCodeEnum$1["GEL"] = "GEL";
65
+ CurrencyCodeEnum$1["GHS"] = "GHS";
66
+ CurrencyCodeEnum$1["GIP"] = "GIP";
67
+ CurrencyCodeEnum$1["GMD"] = "GMD";
68
+ CurrencyCodeEnum$1["GNF"] = "GNF";
69
+ CurrencyCodeEnum$1["GTQ"] = "GTQ";
70
+ CurrencyCodeEnum$1["GYD"] = "GYD";
71
+ CurrencyCodeEnum$1["HKD"] = "HKD";
72
+ CurrencyCodeEnum$1["HNL"] = "HNL";
73
+ CurrencyCodeEnum$1["HRK"] = "HRK";
74
+ CurrencyCodeEnum$1["HTG"] = "HTG";
75
+ CurrencyCodeEnum$1["HUF"] = "HUF";
76
+ CurrencyCodeEnum$1["IDR"] = "IDR";
77
+ CurrencyCodeEnum$1["ILS"] = "ILS";
78
+ CurrencyCodeEnum$1["INR"] = "INR";
79
+ CurrencyCodeEnum$1["IQD"] = "IQD";
80
+ CurrencyCodeEnum$1["IRR"] = "IRR";
81
+ CurrencyCodeEnum$1["ISK"] = "ISK";
82
+ CurrencyCodeEnum$1["JMD"] = "JMD";
83
+ CurrencyCodeEnum$1["JOD"] = "JOD";
84
+ CurrencyCodeEnum$1["JPY"] = "JPY";
85
+ CurrencyCodeEnum$1["KES"] = "KES";
86
+ CurrencyCodeEnum$1["KGS"] = "KGS";
87
+ CurrencyCodeEnum$1["KHR"] = "KHR";
88
+ CurrencyCodeEnum$1["KMF"] = "KMF";
89
+ CurrencyCodeEnum$1["KPW"] = "KPW";
90
+ CurrencyCodeEnum$1["KRW"] = "KRW";
91
+ CurrencyCodeEnum$1["KWD"] = "KWD";
92
+ CurrencyCodeEnum$1["KYD"] = "KYD";
93
+ CurrencyCodeEnum$1["KZT"] = "KZT";
94
+ CurrencyCodeEnum$1["LAK"] = "LAK";
95
+ CurrencyCodeEnum$1["LBP"] = "LBP";
96
+ CurrencyCodeEnum$1["LKR"] = "LKR";
97
+ CurrencyCodeEnum$1["LRD"] = "LRD";
98
+ CurrencyCodeEnum$1["LSL"] = "LSL";
99
+ CurrencyCodeEnum$1["LYD"] = "LYD";
100
+ CurrencyCodeEnum$1["MAD"] = "MAD";
101
+ CurrencyCodeEnum$1["MDL"] = "MDL";
102
+ CurrencyCodeEnum$1["MGA"] = "MGA";
103
+ CurrencyCodeEnum$1["MKD"] = "MKD";
104
+ CurrencyCodeEnum$1["MMK"] = "MMK";
105
+ CurrencyCodeEnum$1["MNT"] = "MNT";
106
+ CurrencyCodeEnum$1["MOP"] = "MOP";
107
+ CurrencyCodeEnum$1["MRU"] = "MRU";
108
+ CurrencyCodeEnum$1["MUR"] = "MUR";
109
+ CurrencyCodeEnum$1["MVR"] = "MVR";
110
+ CurrencyCodeEnum$1["MWK"] = "MWK";
111
+ CurrencyCodeEnum$1["MXN"] = "MXN";
112
+ CurrencyCodeEnum$1["MXV"] = "MXV";
113
+ CurrencyCodeEnum$1["MYR"] = "MYR";
114
+ CurrencyCodeEnum$1["MZN"] = "MZN";
115
+ CurrencyCodeEnum$1["NAD"] = "NAD";
116
+ CurrencyCodeEnum$1["NGN"] = "NGN";
117
+ CurrencyCodeEnum$1["NIO"] = "NIO";
118
+ CurrencyCodeEnum$1["NOK"] = "NOK";
119
+ CurrencyCodeEnum$1["NPR"] = "NPR";
120
+ CurrencyCodeEnum$1["NZD"] = "NZD";
121
+ CurrencyCodeEnum$1["OMR"] = "OMR";
122
+ CurrencyCodeEnum$1["PAB"] = "PAB";
123
+ CurrencyCodeEnum$1["PEN"] = "PEN";
124
+ CurrencyCodeEnum$1["PGK"] = "PGK";
125
+ CurrencyCodeEnum$1["PHP"] = "PHP";
126
+ CurrencyCodeEnum$1["PKR"] = "PKR";
127
+ CurrencyCodeEnum$1["PLN"] = "PLN";
128
+ CurrencyCodeEnum$1["PYG"] = "PYG";
129
+ CurrencyCodeEnum$1["QAR"] = "QAR";
130
+ CurrencyCodeEnum$1["RON"] = "RON";
131
+ CurrencyCodeEnum$1["RSD"] = "RSD";
132
+ CurrencyCodeEnum$1["RUB"] = "RUB";
133
+ CurrencyCodeEnum$1["RWF"] = "RWF";
134
+ CurrencyCodeEnum$1["SAR"] = "SAR";
135
+ CurrencyCodeEnum$1["SBD"] = "SBD";
136
+ CurrencyCodeEnum$1["SCR"] = "SCR";
137
+ CurrencyCodeEnum$1["SDG"] = "SDG";
138
+ CurrencyCodeEnum$1["SEK"] = "SEK";
139
+ CurrencyCodeEnum$1["SGD"] = "SGD";
140
+ CurrencyCodeEnum$1["SHP"] = "SHP";
141
+ CurrencyCodeEnum$1["SLL"] = "SLL";
142
+ CurrencyCodeEnum$1["SOS"] = "SOS";
143
+ CurrencyCodeEnum$1["SRD"] = "SRD";
144
+ CurrencyCodeEnum$1["SSP"] = "SSP";
145
+ CurrencyCodeEnum$1["STN"] = "STN";
146
+ CurrencyCodeEnum$1["SVC"] = "SVC";
147
+ CurrencyCodeEnum$1["SYP"] = "SYP";
148
+ CurrencyCodeEnum$1["SZL"] = "SZL";
149
+ CurrencyCodeEnum$1["THB"] = "THB";
150
+ CurrencyCodeEnum$1["TJS"] = "TJS";
151
+ CurrencyCodeEnum$1["TMT"] = "TMT";
152
+ CurrencyCodeEnum$1["TND"] = "TND";
153
+ CurrencyCodeEnum$1["TOP"] = "TOP";
154
+ CurrencyCodeEnum$1["TRY"] = "TRY";
155
+ CurrencyCodeEnum$1["TTD"] = "TTD";
156
+ CurrencyCodeEnum$1["TWD"] = "TWD";
157
+ CurrencyCodeEnum$1["TZS"] = "TZS";
158
+ CurrencyCodeEnum$1["UAH"] = "UAH";
159
+ CurrencyCodeEnum$1["UGX"] = "UGX";
160
+ CurrencyCodeEnum$1["USD"] = "USD";
161
+ CurrencyCodeEnum$1["USN"] = "USN";
162
+ CurrencyCodeEnum$1["UYI"] = "UYI";
163
+ CurrencyCodeEnum$1["UYU"] = "UYU";
164
+ CurrencyCodeEnum$1["UYW"] = "UYW";
165
+ CurrencyCodeEnum$1["UZS"] = "UZS";
166
+ CurrencyCodeEnum$1["VED"] = "VED";
167
+ CurrencyCodeEnum$1["VES"] = "VES";
168
+ CurrencyCodeEnum$1["VND"] = "VND";
169
+ CurrencyCodeEnum$1["VUV"] = "VUV";
170
+ CurrencyCodeEnum$1["WST"] = "WST";
171
+ CurrencyCodeEnum$1["XAF"] = "XAF";
172
+ CurrencyCodeEnum$1["XAG"] = "XAG";
173
+ CurrencyCodeEnum$1["XAU"] = "XAU";
174
+ CurrencyCodeEnum$1["XBA"] = "XBA";
175
+ CurrencyCodeEnum$1["XBB"] = "XBB";
176
+ CurrencyCodeEnum$1["XBC"] = "XBC";
177
+ CurrencyCodeEnum$1["XBD"] = "XBD";
178
+ CurrencyCodeEnum$1["XCD"] = "XCD";
179
+ CurrencyCodeEnum$1["XDR"] = "XDR";
180
+ CurrencyCodeEnum$1["XOF"] = "XOF";
181
+ CurrencyCodeEnum$1["XPD"] = "XPD";
182
+ CurrencyCodeEnum$1["XPF"] = "XPF";
183
+ CurrencyCodeEnum$1["XPT"] = "XPT";
184
+ CurrencyCodeEnum$1["XSU"] = "XSU";
185
+ CurrencyCodeEnum$1["XUA"] = "XUA";
186
+ CurrencyCodeEnum$1["XXX"] = "XXX";
187
+ CurrencyCodeEnum$1["YER"] = "YER";
188
+ CurrencyCodeEnum$1["ZAR"] = "ZAR";
189
+ CurrencyCodeEnum$1["ZMW"] = "ZMW";
190
+ CurrencyCodeEnum$1["ZWL"] = "ZWL";
191
+ return CurrencyCodeEnum$1;
21
192
  }({});
22
193
 
23
194
  //#endregion
24
- exports.PaymentModeCodeEnum = PaymentModeCodeEnum;
195
+ exports.CurrencyCodeEnum = CurrencyCodeEnum;
25
196
  //# sourceMappingURL=index10.cjs.map