@ripwords/myinvois-client 0.1.4 → 0.1.6

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 (337) hide show
  1. package/CHANGELOG.md +25 -0
  2. package/bun.lock +460 -0
  3. package/dist/0X-CTIq3y3a.d.ts +210 -0
  4. package/dist/0X-Cr3M7hci.d.cts +211 -0
  5. package/dist/1X-Bu4oiv8D.d.ts +111 -0
  6. package/dist/1X-BywXCqtn.d.ts +19 -0
  7. package/dist/1X-CWwmfCzo.d.cts +112 -0
  8. package/dist/1X-ClnJ79HH.d.cts +20 -0
  9. package/dist/2X-3fSEGIuE.d.ts +39 -0
  10. package/dist/2X-CV9eYhog.d.cts +40 -0
  11. package/dist/2X-DNtkJ0tj.d.cts +140 -0
  12. package/dist/2X-DnG3FY1f.d.ts +139 -0
  13. package/dist/3X--VWVsC84.d.cts +21 -0
  14. package/dist/3X-BOxfatu3.d.cts +62 -0
  15. package/dist/3X-CLdmoel1.d.ts +61 -0
  16. package/dist/3X-Ynjfgoll.d.ts +20 -0
  17. package/dist/4X-B5ePdMky.d.ts +30 -0
  18. package/dist/4X-BTG6o1Gn.d.ts +264 -0
  19. package/dist/4X-By9PzHaY.d.cts +31 -0
  20. package/dist/4X-C7fzDWJ_.d.cts +265 -0
  21. package/dist/5X-B5M0Cv_K.d.cts +22 -0
  22. package/dist/5X-CNAFsDm2.d.cts +77 -0
  23. package/dist/5X-CjSz1zxJ.d.ts +76 -0
  24. package/dist/5X-dhP6fyou.d.ts +21 -0
  25. package/dist/6X-B9KP_vEn.d.ts +104 -0
  26. package/dist/6X-BHaY0TCf.d.ts +15 -0
  27. package/dist/6X-C3elgd-n.d.cts +16 -0
  28. package/dist/6X-uObUP4VG.d.cts +105 -0
  29. package/dist/7X-BifJnY24.d.cts +71 -0
  30. package/dist/7X-C4eX_tAk.d.ts +15 -0
  31. package/dist/7X-D3idQBl9.d.cts +16 -0
  32. package/dist/7X-DtkQutx2.d.ts +70 -0
  33. package/dist/8X-5n9seY3z.d.ts +109 -0
  34. package/dist/8X-C6UMFvQW.d.cts +19 -0
  35. package/dist/8X-D6HTLShY.d.ts +18 -0
  36. package/dist/8X-DioBXCJ0.d.cts +110 -0
  37. package/dist/9X-BjffnXuq.d.cts +98 -0
  38. package/dist/9X-CHZKsIdD.d.ts +14 -0
  39. package/dist/9X-CJjPJgIG.d.cts +15 -0
  40. package/dist/9X-Cpb6V4JC.d.ts +97 -0
  41. package/dist/AX-C0w_r3PA.d.ts +110 -0
  42. package/dist/AX-DrEd2Ov6.d.cts +111 -0
  43. package/dist/BX-C5jc6myN.d.cts +115 -0
  44. package/dist/BX-RadlZ-6m.d.ts +114 -0
  45. package/dist/CX-CT1Zzb9D.d.ts +127 -0
  46. package/dist/CX-oSgvmn3h.d.cts +128 -0
  47. package/dist/DX-CtUeTKMM.d.ts +114 -0
  48. package/dist/DX-ZIG0enmK.d.cts +115 -0
  49. package/dist/EX-084Yu7Wt.d.ts +106 -0
  50. package/dist/EX-BpWZ5ADq.d.cts +107 -0
  51. package/dist/FX-BrbQM0CW.d.ts +126 -0
  52. package/dist/FX-CvYBEc51.d.cts +127 -0
  53. package/dist/GX-CU8PZy0G.d.cts +136 -0
  54. package/dist/GX-gKj8iAAh.d.ts +135 -0
  55. package/dist/HX-9D-ZXTy5.d.ts +125 -0
  56. package/dist/HX-DoEErDeE.d.cts +126 -0
  57. package/dist/IX-DR4Fc92A.d.ts +22 -0
  58. package/dist/IX-jLAUHe8i.d.cts +23 -0
  59. package/dist/JX-DIKa9ma-.d.ts +103 -0
  60. package/dist/JX-DX8BjYQC.d.cts +104 -0
  61. package/dist/KX-DpsJ_unT.d.ts +150 -0
  62. package/dist/KX-fZb4_vhw.d.cts +151 -0
  63. package/dist/LX-D_mI1bk-.d.cts +123 -0
  64. package/dist/LX-DeXPPWUX.d.ts +122 -0
  65. package/dist/MX-CKMjg_zK.d.ts +152 -0
  66. package/dist/MX-DlYZhpkT.d.cts +153 -0
  67. package/dist/NX-DELEEbad.d.cts +122 -0
  68. package/dist/NX-oYdb4NDo.d.ts +121 -0
  69. package/dist/OX-Bid9es3D.d.ts +25 -0
  70. package/dist/OX-CKPyrIFf.d.cts +26 -0
  71. package/dist/PX-D7jy9CFk.d.ts +120 -0
  72. package/dist/PX-SP6NxBtG.d.cts +121 -0
  73. package/dist/QX-BFWOR4g3.d.ts +58 -0
  74. package/dist/QX-QZA7E2O-.d.cts +59 -0
  75. package/dist/RX-DBcgbdeE.d.cts +23 -0
  76. package/dist/RX-XHgCyMV1.d.ts +22 -0
  77. package/dist/SX-Cl8RN8oH.d.ts +39 -0
  78. package/dist/SX-DmiJeCMN.d.cts +40 -0
  79. package/dist/TX-C1SoDobK.d.cts +31 -0
  80. package/dist/TX-ZymoIbtr.d.ts +30 -0
  81. package/dist/UX-D-Ndd1ov.d.ts +17 -0
  82. package/dist/UX-DFVynFhQ.d.cts +18 -0
  83. package/dist/VX-B-1b34r7.d.ts +16 -0
  84. package/dist/VX-DsRum5k3.d.cts +17 -0
  85. package/dist/WX-0GuMjPNZ.d.ts +25 -0
  86. package/dist/WX-VReU5R5M.d.cts +26 -0
  87. package/dist/XX-CF2NANsy.d.ts +827 -0
  88. package/dist/XX-ChAviUMj.d.cts +828 -0
  89. package/dist/YX-B51BbNSg.d.ts +19 -0
  90. package/dist/YX-QfzeMEKx.d.cts +20 -0
  91. package/dist/ZX-BMJS1iAv.d.ts +21 -0
  92. package/dist/ZX-Ca2E726a.d.cts +22 -0
  93. package/dist/api/platform/platformLogin.d.ts +65 -0
  94. package/dist/api/platform/platformLogin.js +3 -0
  95. package/dist/certificate-DFK-788s.cjs +62 -0
  96. package/dist/certificate-DFK-788s.cjs.map +1 -0
  97. package/dist/certificate-aooIRf9A.js +49 -0
  98. package/dist/chunk-CUT6urMc.cjs +30 -0
  99. package/dist/classification-codes-B15PbWxz.d.cts +118 -0
  100. package/dist/classification-codes-BKxV-rO9.d.ts +117 -0
  101. package/dist/country-code-CQuaiQm2.d.ts +542 -0
  102. package/dist/country-code-DPeNFMMi.d.cts +543 -0
  103. package/dist/currencies-BYJK-m6v.d.ts +207 -0
  104. package/dist/currencies-S5g1gzBU.d.cts +208 -0
  105. package/dist/document-CARHiGdp.cjs +472 -0
  106. package/dist/document-CARHiGdp.cjs.map +1 -0
  107. package/dist/document-D6VKMAtx.js +405 -0
  108. package/dist/documents-CQy_uB6C.d.cts +858 -0
  109. package/dist/documents-i5EV868Y.d.ts +857 -0
  110. package/dist/e-invoice-BuwtFnlI.d.cts +44 -0
  111. package/dist/e-invoice-CmbLQkHw.d.ts +43 -0
  112. package/dist/getBaseUrl-CO7Jp27d.cjs +14 -0
  113. package/dist/getBaseUrl-CO7Jp27d.cjs.map +1 -0
  114. package/dist/getBaseUrl-R3IdgCu3.js +7 -0
  115. package/dist/index-0-EvC6Nv.d.ts +15 -0
  116. package/dist/index-D2_HVwCz.d.cts +16 -0
  117. package/dist/index.cjs +309 -0
  118. package/dist/index.cjs.map +1 -0
  119. package/dist/index.d.ts +233 -0
  120. package/dist/index.js +308 -0
  121. package/dist/index10.cjs +0 -0
  122. package/dist/index11.cjs +34 -0
  123. package/dist/index11.cjs.map +1 -0
  124. package/dist/index12.cjs +24 -0
  125. package/dist/index12.cjs.map +1 -0
  126. package/dist/index13.cjs +0 -0
  127. package/dist/index14.cjs +13 -0
  128. package/dist/index14.cjs.map +1 -0
  129. package/dist/index15.cjs +4 -0
  130. package/dist/index16.cjs +13 -0
  131. package/dist/index17.cjs +3 -0
  132. package/dist/index18.cjs +340 -0
  133. package/dist/index18.cjs.map +1 -0
  134. package/dist/index19.cjs +329 -0
  135. package/dist/index19.cjs.map +1 -0
  136. package/dist/index2.cjs +62 -0
  137. package/dist/index2.cjs.map +1 -0
  138. package/dist/index20.cjs +140 -0
  139. package/dist/index20.cjs.map +1 -0
  140. package/dist/index21.cjs +3 -0
  141. package/dist/index22.cjs +208 -0
  142. package/dist/index22.cjs.map +1 -0
  143. package/dist/index23.cjs +109 -0
  144. package/dist/index23.cjs.map +1 -0
  145. package/dist/index24.cjs +137 -0
  146. package/dist/index24.cjs.map +1 -0
  147. package/dist/index25.cjs +64 -0
  148. package/dist/index25.cjs.map +1 -0
  149. package/dist/index26.cjs +267 -0
  150. package/dist/index26.cjs.map +1 -0
  151. package/dist/index27.cjs +79 -0
  152. package/dist/index27.cjs.map +1 -0
  153. package/dist/index28.cjs +107 -0
  154. package/dist/index28.cjs.map +1 -0
  155. package/dist/index29.cjs +73 -0
  156. package/dist/index29.cjs.map +1 -0
  157. package/dist/index3.cjs +532 -0
  158. package/dist/index3.cjs.map +1 -0
  159. package/dist/index30.cjs +112 -0
  160. package/dist/index30.cjs.map +1 -0
  161. package/dist/index31.cjs +100 -0
  162. package/dist/index31.cjs.map +1 -0
  163. package/dist/index32.cjs +18 -0
  164. package/dist/index32.cjs.map +1 -0
  165. package/dist/index33.cjs +38 -0
  166. package/dist/index33.cjs.map +1 -0
  167. package/dist/index34.cjs +19 -0
  168. package/dist/index34.cjs.map +1 -0
  169. package/dist/index35.cjs +29 -0
  170. package/dist/index35.cjs.map +1 -0
  171. package/dist/index36.cjs +20 -0
  172. package/dist/index36.cjs.map +1 -0
  173. package/dist/index37.cjs +14 -0
  174. package/dist/index37.cjs.map +1 -0
  175. package/dist/index38.cjs +14 -0
  176. package/dist/index38.cjs.map +1 -0
  177. package/dist/index39.cjs +17 -0
  178. package/dist/index39.cjs.map +1 -0
  179. package/dist/index4.cjs +196 -0
  180. package/dist/index4.cjs.map +1 -0
  181. package/dist/index40.cjs +13 -0
  182. package/dist/index40.cjs.map +1 -0
  183. package/dist/index41.cjs +108 -0
  184. package/dist/index41.cjs.map +1 -0
  185. package/dist/index42.cjs +113 -0
  186. package/dist/index42.cjs.map +1 -0
  187. package/dist/index43.cjs +126 -0
  188. package/dist/index43.cjs.map +1 -0
  189. package/dist/index44.cjs +113 -0
  190. package/dist/index44.cjs.map +1 -0
  191. package/dist/index45.cjs +105 -0
  192. package/dist/index45.cjs.map +1 -0
  193. package/dist/index46.cjs +125 -0
  194. package/dist/index46.cjs.map +1 -0
  195. package/dist/index47.cjs +134 -0
  196. package/dist/index47.cjs.map +1 -0
  197. package/dist/index48.cjs +124 -0
  198. package/dist/index48.cjs.map +1 -0
  199. package/dist/index49.cjs +21 -0
  200. package/dist/index49.cjs.map +1 -0
  201. package/dist/index5.cjs +0 -0
  202. package/dist/index50.cjs +102 -0
  203. package/dist/index50.cjs.map +1 -0
  204. package/dist/index51.cjs +149 -0
  205. package/dist/index51.cjs.map +1 -0
  206. package/dist/index52.cjs +121 -0
  207. package/dist/index52.cjs.map +1 -0
  208. package/dist/index53.cjs +151 -0
  209. package/dist/index53.cjs.map +1 -0
  210. package/dist/index54.cjs +120 -0
  211. package/dist/index54.cjs.map +1 -0
  212. package/dist/index55.cjs +24 -0
  213. package/dist/index55.cjs.map +1 -0
  214. package/dist/index56.cjs +119 -0
  215. package/dist/index56.cjs.map +1 -0
  216. package/dist/index57.cjs +54 -0
  217. package/dist/index57.cjs.map +1 -0
  218. package/dist/index58.cjs +21 -0
  219. package/dist/index58.cjs.map +1 -0
  220. package/dist/index58.cts.map +1 -0
  221. package/dist/index59.cjs +35 -0
  222. package/dist/index59.cjs.map +1 -0
  223. package/dist/index59.cts.map +1 -0
  224. package/dist/index6.cjs +25 -0
  225. package/dist/index6.cjs.map +1 -0
  226. package/dist/index60.cjs +29 -0
  227. package/dist/index60.cjs.map +1 -0
  228. package/dist/index60.cts.map +1 -0
  229. package/dist/index61.cjs +16 -0
  230. package/dist/index61.cjs.map +1 -0
  231. package/dist/index61.cts.map +1 -0
  232. package/dist/index62.cjs +15 -0
  233. package/dist/index62.cjs.map +1 -0
  234. package/dist/index62.cts.map +1 -0
  235. package/dist/index63.cjs +24 -0
  236. package/dist/index63.cjs.map +1 -0
  237. package/dist/index63.cts.map +1 -0
  238. package/dist/index64.cjs +419 -0
  239. package/dist/index64.cjs.map +1 -0
  240. package/dist/index64.cts.map +1 -0
  241. package/dist/index65.cjs +15 -0
  242. package/dist/index65.cjs.map +1 -0
  243. package/dist/index65.cts.map +1 -0
  244. package/dist/index66.cjs +16 -0
  245. package/dist/index66.cjs.map +1 -0
  246. package/dist/index66.cts.map +1 -0
  247. package/dist/index7.cjs +0 -0
  248. package/dist/index8.cjs +0 -0
  249. package/dist/index9.cjs +25 -0
  250. package/dist/index9.cjs.map +1 -0
  251. package/dist/msic-codes-C8PJVOaA.d.ts +25 -0
  252. package/dist/msic-codes-CIKdPqag.d.cts +26 -0
  253. package/dist/payment-modes-BOTSRC_X.d.ts +43 -0
  254. package/dist/payment-modes-ghFEXnUl.d.cts +44 -0
  255. package/dist/platformLogin-PGzMhw1X.cjs +37 -0
  256. package/dist/platformLogin-PGzMhw1X.cjs.map +1 -0
  257. package/dist/platformLogin-f0bNAoZI.js +30 -0
  258. package/dist/signatures-W-_brwdb.d.ts +172 -0
  259. package/dist/signatures-hFbt_std.d.cts +173 -0
  260. package/dist/state-codes-BlILGZ9d.d.cts +62 -0
  261. package/dist/state-codes-oeFKlwXZ.d.ts +61 -0
  262. package/dist/tax-types-B5sQ8UyN.d.cts +42 -0
  263. package/dist/tax-types-CsQ76JMf.d.ts +41 -0
  264. package/dist/types/classification-codes.d.ts +2 -0
  265. package/dist/types/country-code.d.ts +2 -0
  266. package/dist/types/currencies.d.ts +2 -0
  267. package/dist/types/documents.d.ts +18 -0
  268. package/dist/types/e-invoice.d.ts +2 -0
  269. package/dist/types/index.d.ts +58 -0
  270. package/dist/types/msic/0X.d.ts +2 -0
  271. package/dist/types/msic/1X.d.ts +2 -0
  272. package/dist/types/msic/2X.d.ts +2 -0
  273. package/dist/types/msic/3X.d.ts +2 -0
  274. package/dist/types/msic/4X.d.ts +2 -0
  275. package/dist/types/msic/5X.d.ts +2 -0
  276. package/dist/types/msic/6X.d.ts +2 -0
  277. package/dist/types/msic/7X.d.ts +2 -0
  278. package/dist/types/msic/8X.d.ts +2 -0
  279. package/dist/types/msic/9X.d.ts +2 -0
  280. package/dist/types/msic-codes.d.ts +12 -0
  281. package/dist/types/payment-modes.d.ts +2 -0
  282. package/dist/types/signatures.d.ts +2 -0
  283. package/dist/types/state-codes.d.ts +2 -0
  284. package/dist/types/tax-types.d.ts +2 -0
  285. package/dist/types/unit/1X.d.ts +2 -0
  286. package/dist/types/unit/2X.d.ts +2 -0
  287. package/dist/types/unit/3X.d.ts +2 -0
  288. package/dist/types/unit/4X.d.ts +2 -0
  289. package/dist/types/unit/5X.d.ts +2 -0
  290. package/dist/types/unit/6X.d.ts +2 -0
  291. package/dist/types/unit/7X.d.ts +2 -0
  292. package/dist/types/unit/8X.d.ts +2 -0
  293. package/dist/types/unit/9X.d.ts +2 -0
  294. package/dist/types/unit/AX.d.ts +2 -0
  295. package/dist/types/unit/BX.d.ts +2 -0
  296. package/dist/types/unit/CX.d.ts +2 -0
  297. package/dist/types/unit/DX.d.ts +2 -0
  298. package/dist/types/unit/EX.d.ts +2 -0
  299. package/dist/types/unit/FX.d.ts +2 -0
  300. package/dist/types/unit/GX.d.ts +2 -0
  301. package/dist/types/unit/HX.d.ts +2 -0
  302. package/dist/types/unit/IX.d.ts +2 -0
  303. package/dist/types/unit/JX.d.ts +2 -0
  304. package/dist/types/unit/KX.d.ts +2 -0
  305. package/dist/types/unit/LX.d.ts +2 -0
  306. package/dist/types/unit/MX.d.ts +2 -0
  307. package/dist/types/unit/NX.d.ts +2 -0
  308. package/dist/types/unit/OX.d.ts +2 -0
  309. package/dist/types/unit/PX.d.ts +2 -0
  310. package/dist/types/unit/QX.d.ts +2 -0
  311. package/dist/types/unit/RX.d.ts +2 -0
  312. package/dist/types/unit/SX.d.ts +2 -0
  313. package/dist/types/unit/TX.d.ts +2 -0
  314. package/dist/types/unit/UX.d.ts +2 -0
  315. package/dist/types/unit/VX.d.ts +2 -0
  316. package/dist/types/unit/WX.d.ts +2 -0
  317. package/dist/types/unit/XX.d.ts +2 -0
  318. package/dist/types/unit/YX.d.ts +2 -0
  319. package/dist/types/unit/ZX.d.ts +2 -0
  320. package/dist/types/unit-types.d.ts +37 -0
  321. package/dist/unit-types-B41YFOLT.d.ts +55 -0
  322. package/dist/unit-types-CjWNk2wS.d.cts +56 -0
  323. package/dist/utils/base64.d.ts +5 -0
  324. package/dist/utils/base64.js +10 -0
  325. package/dist/utils/certificate.d.ts +22 -0
  326. package/dist/utils/certificate.js +3 -0
  327. package/dist/utils/document.d.ts +135 -0
  328. package/dist/utils/document.js +3 -0
  329. package/dist/utils/getBaseUrl.d.ts +4 -0
  330. package/dist/utils/getBaseUrl.js +3 -0
  331. package/dist/utils/helpers.d.ts +271 -0
  332. package/dist/utils/helpers.js +330 -0
  333. package/dist/utils/signature-diagnostics.d.ts +93 -0
  334. package/dist/utils/signature-diagnostics.js +326 -0
  335. package/dist/utils/validation.d.ts +46 -0
  336. package/dist/utils/validation.js +134 -0
  337. package/package.json +4 -4
@@ -0,0 +1,472 @@
1
+ const require_chunk = require('./chunk-CUT6urMc.cjs');
2
+ const crypto = require_chunk.__toESM(require("crypto"));
3
+
4
+ //#region src/utils/document.ts
5
+ /**
6
+ * MyInvois v1.1 Document Generation and Signing Utilities
7
+ * Strictly follows: https://sdk.myinvois.hasil.gov.my/documents/invoice-v1-1
8
+ * JSON Signature Guide: https://sdk.myinvois.hasil.gov.my/signature-creation-json/
9
+ */
10
+ /**
11
+ * Helper function to recursively sort object keys for JSON canonicalization
12
+ */
13
+ function sortObjectKeys(obj) {
14
+ if (obj === null || typeof obj !== "object") return obj;
15
+ if (Array.isArray(obj)) return obj.map(sortObjectKeys);
16
+ const sortedObj = {};
17
+ const keys = Object.keys(obj).sort();
18
+ for (const key of keys) sortedObj[key] = sortObjectKeys(obj[key]);
19
+ return sortedObj;
20
+ }
21
+ /**
22
+ * Enhanced canonicalization following MyInvois specification exactly
23
+ * Key changes: ensure consistent ordering and formatting
24
+ */
25
+ const canonicalizeJSON = (obj) => {
26
+ const sortedObj = sortObjectKeys(obj);
27
+ return JSON.stringify(sortedObj, null, 0);
28
+ };
29
+ /**
30
+ * Generates a clean invoice object following MyInvois v1.1 specification exactly
31
+ * This is the base invoice structure WITHOUT signature elements (for hash calculation)
32
+ *
33
+ * Key requirements from working documents:
34
+ * - All mandatory fields must be present
35
+ * - Many optional fields must be present even if empty
36
+ * - Specific field ordering and structure
37
+ * - Correct listID values (e.g., "3166-1" not "ISO3166-1")
38
+ */
39
+ const generateCleanInvoiceObject = (invoice) => {
40
+ return {
41
+ ID: [{ _: invoice.eInvoiceCodeOrNumber }],
42
+ IssueDate: [{ _: invoice.eInvoiceDate }],
43
+ IssueTime: [{ _: invoice.eInvoiceTime }],
44
+ InvoiceTypeCode: [{
45
+ _: invoice.eInvoiceTypeCode,
46
+ listVersionID: invoice.eInvoiceVersion || "1.1"
47
+ }],
48
+ DocumentCurrencyCode: [{ _: invoice.invoiceCurrencyCode }],
49
+ AccountingSupplierParty: [{ Party: [{
50
+ IndustryClassificationCode: [{
51
+ _: invoice.supplier.industryClassificationCode,
52
+ name: invoice.supplier.industryClassificationDescription
53
+ }],
54
+ PartyIdentification: [{ ID: [{
55
+ _: invoice.supplier.tin,
56
+ schemeID: "TIN"
57
+ }] }, { ID: [{
58
+ _: invoice.supplier.registrationNumber,
59
+ schemeID: invoice.supplier.registrationType || "NRIC"
60
+ }] }],
61
+ PostalAddress: [{
62
+ CityName: [{ _: invoice.supplier.address.cityName }],
63
+ CountrySubentityCode: [{ _: invoice.supplier.address.state }],
64
+ AddressLine: [{ Line: [{ _: invoice.supplier.address.addressLine0 }] }],
65
+ Country: [{ IdentificationCode: [{
66
+ _: invoice.supplier.address.country || "MYS",
67
+ listID: "3166-1",
68
+ listAgencyID: "ISO"
69
+ }] }]
70
+ }],
71
+ PartyLegalEntity: [{ RegistrationName: [{ _: invoice.supplier.name }] }],
72
+ Contact: [{ Telephone: [{ _: invoice.supplier.contactNumber || "" }] }]
73
+ }] }],
74
+ AccountingCustomerParty: [{ Party: [{
75
+ PartyIdentification: [
76
+ { ID: [{
77
+ _: invoice.buyer.tin,
78
+ schemeID: "TIN"
79
+ }] },
80
+ { ID: [{
81
+ _: invoice.buyer.registrationNumber,
82
+ schemeID: invoice.buyer.registrationType || "NRIC"
83
+ }] },
84
+ { ID: [{
85
+ _: invoice.buyer.sstRegistrationNumber || "NA",
86
+ schemeID: "SST"
87
+ }] }
88
+ ],
89
+ PostalAddress: [{
90
+ CityName: [{ _: invoice.buyer.address.cityName }],
91
+ CountrySubentityCode: [{ _: invoice.buyer.address.state }],
92
+ AddressLine: [{ Line: [{ _: invoice.buyer.address.addressLine0 }] }],
93
+ Country: [{ IdentificationCode: [{
94
+ _: invoice.buyer.address.country || "MYS",
95
+ listID: "3166-1",
96
+ listAgencyID: "ISO"
97
+ }] }]
98
+ }],
99
+ PartyLegalEntity: [{ RegistrationName: [{ _: invoice.buyer.name }] }],
100
+ Contact: [{ Telephone: [{ _: invoice.buyer.contactNumber || "" }] }]
101
+ }] }],
102
+ TaxTotal: [{
103
+ TaxAmount: [{
104
+ _: invoice.taxTotal.taxAmount,
105
+ currencyID: invoice.invoiceCurrencyCode
106
+ }],
107
+ TaxSubtotal: [{
108
+ TaxableAmount: [{
109
+ _: invoice.legalMonetaryTotal.taxExclusiveAmount,
110
+ currencyID: invoice.invoiceCurrencyCode
111
+ }],
112
+ TaxAmount: [{
113
+ _: invoice.taxTotal.taxAmount,
114
+ currencyID: invoice.invoiceCurrencyCode
115
+ }],
116
+ TaxCategory: [{
117
+ ID: [{ _: invoice.invoiceLineItems[0]?.taxType || "01" }],
118
+ TaxScheme: [{ ID: [{
119
+ _: "OTH",
120
+ schemeAgencyID: "6",
121
+ schemeID: "UN/ECE 5153"
122
+ }] }]
123
+ }]
124
+ }]
125
+ }],
126
+ LegalMonetaryTotal: [{
127
+ LineExtensionAmount: [{
128
+ _: invoice.legalMonetaryTotal.taxExclusiveAmount,
129
+ currencyID: invoice.invoiceCurrencyCode
130
+ }],
131
+ TaxExclusiveAmount: [{
132
+ _: invoice.legalMonetaryTotal.taxExclusiveAmount,
133
+ currencyID: invoice.invoiceCurrencyCode
134
+ }],
135
+ TaxInclusiveAmount: [{
136
+ _: invoice.legalMonetaryTotal.taxInclusiveAmount,
137
+ currencyID: invoice.invoiceCurrencyCode
138
+ }],
139
+ PayableAmount: [{
140
+ _: invoice.legalMonetaryTotal.payableAmount,
141
+ currencyID: invoice.invoiceCurrencyCode
142
+ }]
143
+ }],
144
+ InvoiceLine: invoice.invoiceLineItems.map((item, index) => ({
145
+ ID: [{ _: (index + 1).toString() }],
146
+ Item: [{
147
+ CommodityClassification: [{ ItemClassificationCode: [{
148
+ _: item.itemClassificationCode,
149
+ listID: "CLASS"
150
+ }] }],
151
+ Description: [{ _: item.itemDescription }]
152
+ }],
153
+ ItemPriceExtension: [{ Amount: [{
154
+ _: item.totalTaxableAmountPerLine,
155
+ currencyID: invoice.invoiceCurrencyCode
156
+ }] }],
157
+ LineExtensionAmount: [{
158
+ _: item.totalTaxableAmountPerLine,
159
+ currencyID: invoice.invoiceCurrencyCode
160
+ }],
161
+ Price: [{ PriceAmount: [{
162
+ _: item.unitPrice,
163
+ currencyID: invoice.invoiceCurrencyCode
164
+ }] }],
165
+ TaxTotal: [{
166
+ TaxAmount: [{
167
+ _: item.taxAmount,
168
+ currencyID: invoice.invoiceCurrencyCode
169
+ }],
170
+ TaxSubtotal: [{
171
+ TaxableAmount: [{
172
+ _: item.totalTaxableAmountPerLine,
173
+ currencyID: invoice.invoiceCurrencyCode
174
+ }],
175
+ TaxAmount: [{
176
+ _: item.taxAmount,
177
+ currencyID: invoice.invoiceCurrencyCode
178
+ }],
179
+ TaxCategory: [{
180
+ ID: [{ _: item.taxType }],
181
+ TaxScheme: [{ ID: [{
182
+ _: "OTH",
183
+ schemeAgencyID: "6",
184
+ schemeID: "UN/ECE 5153"
185
+ }] }]
186
+ }]
187
+ }]
188
+ }]
189
+ })),
190
+ TaxExchangeRate: invoice.currencyExchangeRate ? [{
191
+ SourceCurrencyCode: [{ _: invoice.invoiceCurrencyCode }],
192
+ TargetCurrencyCode: [{ _: "MYR" }],
193
+ CalculationRate: [{ _: invoice.currencyExchangeRate }]
194
+ }] : void 0
195
+ };
196
+ };
197
+ /**
198
+ * Generates the complete UBL document structure with namespace declarations
199
+ */
200
+ const generateCleanUBLDocument = (invoices) => {
201
+ return {
202
+ _D: "urn:oasis:names:specification:ubl:schema:xsd:Invoice-2",
203
+ _A: "urn:oasis:names:specification:ubl:schema:xsd:CommonAggregateComponents-2",
204
+ _B: "urn:oasis:names:specification:ubl:schema:xsd:CommonBasicComponents-2",
205
+ Invoice: invoices.map(generateCleanInvoiceObject)
206
+ };
207
+ };
208
+ /**
209
+ * Step 2: Calculate Document Digest
210
+ * FIXED: Remove UBLExtensions and Signature before hashing (DS322)
211
+ * Based on working implementation pattern
212
+ */
213
+ const calculateDocumentDigest = (invoices) => {
214
+ const cleanDocument = generateCleanUBLDocument(invoices);
215
+ const documentForHashing = JSON.parse(JSON.stringify(cleanDocument));
216
+ if (documentForHashing.Invoice && Array.isArray(documentForHashing.Invoice)) documentForHashing.Invoice.forEach((invoice) => {
217
+ delete invoice.UBLExtensions;
218
+ delete invoice.Signature;
219
+ });
220
+ const documentString = JSON.stringify(documentForHashing);
221
+ const hash = crypto.default.createHash("sha256");
222
+ hash.update(documentString, "utf8");
223
+ return hash.digest("base64");
224
+ };
225
+ /**
226
+ * Step 4: Calculate Certificate Digest
227
+ * Enhanced to handle certificate content properly
228
+ */
229
+ const calculateCertificateDigest = (certificatePem) => {
230
+ const certificateContent = certificatePem.replace(/-----BEGIN CERTIFICATE-----/g, "").replace(/-----END CERTIFICATE-----/g, "").replace(/\s+/g, "");
231
+ const certificateBinary = Buffer.from(certificateContent, "base64");
232
+ const hash = crypto.default.createHash("sha256");
233
+ hash.update(certificateBinary);
234
+ return hash.digest("base64");
235
+ };
236
+ /**
237
+ * Enhanced certificate info extraction with better error handling
238
+ * FIXED: Normalize issuer name format to match MyInvois expectations (DS326)
239
+ */
240
+ const extractCertificateInfo = (certificatePem) => {
241
+ try {
242
+ const cert = new crypto.X509Certificate(certificatePem);
243
+ const serialNumberHex = cert.serialNumber;
244
+ const normalizeDistinguishedName = (dn) => {
245
+ const normalized = dn.split("\n").map((line) => line.trim()).filter((line) => line.length > 0).join(", ");
246
+ return normalized.replace(/\s*=\s*/g, "=").replace(/,\s+/g, ", ").replace(/\r/g, "").replace(/\s{2,}/g, " ").trim();
247
+ };
248
+ const formatSerialNumber = (serialHex) => {
249
+ const decimal = BigInt("0x" + serialHex).toString();
250
+ return decimal;
251
+ };
252
+ return {
253
+ issuerName: normalizeDistinguishedName(cert.issuer),
254
+ serialNumber: formatSerialNumber(serialNumberHex),
255
+ subjectName: normalizeDistinguishedName(cert.subject)
256
+ };
257
+ } catch (error) {
258
+ throw new Error(`Failed to extract certificate info: ${error instanceof Error ? error.message : String(error)}`);
259
+ }
260
+ };
261
+ /**
262
+ * Step 5: Create SignedProperties with enhanced structure
263
+ * FIXED: Simplified structure to match MyInvois expectations (DS320)
264
+ * Following MyInvois JSON signature specification exactly
265
+ */
266
+ const createSignedProperties = (certificateDigest, signingTime, issuerName, serialNumber) => {
267
+ return { SignedProperties: [{
268
+ Id: "id-xades-signed-props",
269
+ SignedSignatureProperties: [{
270
+ SigningTime: [{ _: signingTime }],
271
+ SigningCertificate: [{ Cert: [{
272
+ CertDigest: [{
273
+ DigestMethod: [{ Algorithm: "http://www.w3.org/2001/04/xmlenc#sha256" }],
274
+ DigestValue: [{ _: certificateDigest }]
275
+ }],
276
+ IssuerSerial: [{
277
+ X509IssuerName: [{ _: issuerName }],
278
+ X509SerialNumber: [{ _: serialNumber }]
279
+ }]
280
+ }] }]
281
+ }]
282
+ }] };
283
+ };
284
+ /**
285
+ * Step 6: Calculate SignedProperties Digest
286
+ * FIXED: Add Target wrapper and use direct JSON stringify (DS320)
287
+ * Based on working implementation pattern
288
+ */
289
+ const calculateSignedPropertiesDigest = (signedProperties) => {
290
+ const signedPropertiesWithTarget = {
291
+ Target: "signature",
292
+ SignedProperties: signedProperties.SignedProperties
293
+ };
294
+ const signedPropertiesString = JSON.stringify(signedPropertiesWithTarget);
295
+ const hash = crypto.default.createHash("sha256");
296
+ hash.update(signedPropertiesString, "utf8");
297
+ return hash.digest("base64");
298
+ };
299
+ /**
300
+ * Step 3: Create SignedInfo and calculate signature
301
+ * Enhanced with better structure and signature generation
302
+ */
303
+ const createSignedInfoAndSign = (docDigest, propsDigest, privateKeyPem) => {
304
+ const signedInfo = {
305
+ CanonicalizationMethod: [{
306
+ _: "",
307
+ Algorithm: "http://www.w3.org/2006/12/xml-c14n11"
308
+ }],
309
+ SignatureMethod: [{
310
+ _: "",
311
+ Algorithm: "http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"
312
+ }],
313
+ Reference: [{
314
+ Id: "id-doc-signed-data",
315
+ Type: "",
316
+ URI: "",
317
+ DigestMethod: [{
318
+ _: "",
319
+ Algorithm: "http://www.w3.org/2001/04/xmlenc#sha256"
320
+ }],
321
+ DigestValue: [{ _: docDigest }]
322
+ }, {
323
+ Id: "id-xades-signed-props",
324
+ Type: "http://uri.etsi.org/01903/v1.3.2#SignedProperties",
325
+ URI: "#id-xades-signed-props",
326
+ DigestMethod: [{
327
+ _: "",
328
+ Algorithm: "http://www.w3.org/2001/04/xmlenc#sha256"
329
+ }],
330
+ DigestValue: [{ _: propsDigest }]
331
+ }]
332
+ };
333
+ const signedInfoString = JSON.stringify(signedInfo);
334
+ try {
335
+ const signer = crypto.default.createSign("RSA-SHA256");
336
+ signer.update(signedInfoString, "utf8");
337
+ const signatureValue = signer.sign(privateKeyPem, "base64");
338
+ return {
339
+ signedInfo,
340
+ signatureValue
341
+ };
342
+ } catch (error) {
343
+ throw new Error(`Signature generation failed: ${error instanceof Error ? error.message : String(error)}`);
344
+ }
345
+ };
346
+ /**
347
+ * Complete document generation with signatures
348
+ * Follows the complete MyInvois JSON signature creation process (Steps 1-7)
349
+ */
350
+ const generateCompleteDocument = (invoices, signingCredentials) => {
351
+ try {
352
+ const docDigest = calculateDocumentDigest(invoices);
353
+ const signingTime = (/* @__PURE__ */ new Date()).toISOString();
354
+ const certInfo = extractCertificateInfo(signingCredentials.certificatePem);
355
+ const certificateDigest = calculateCertificateDigest(signingCredentials.certificatePem);
356
+ const signedProperties = createSignedProperties(certificateDigest, signingTime, certInfo.issuerName, certInfo.serialNumber);
357
+ const propsDigest = calculateSignedPropertiesDigest(signedProperties);
358
+ const { signedInfo, signatureValue } = createSignedInfoAndSign(docDigest, propsDigest, signingCredentials.privateKeyPem);
359
+ const certificate = signingCredentials.certificatePem.replace(/-----BEGIN CERTIFICATE-----/g, "").replace(/-----END CERTIFICATE-----/g, "").replace(/\s+/g, "");
360
+ const signedInvoices = invoices.map((invoice) => {
361
+ const cleanInvoice = generateCleanInvoiceObject(invoice);
362
+ return {
363
+ ...cleanInvoice,
364
+ UBLExtensions: [{ UBLExtension: [{
365
+ ExtensionURI: [{ _: "urn:oasis:names:specification:ubl:dsig:enveloped:xades" }],
366
+ ExtensionContent: [{ UBLDocumentSignatures: [{ SignatureInformation: [{
367
+ ID: [{ _: "urn:oasis:names:specification:ubl:signature:1" }],
368
+ ReferencedSignatureID: [{ _: "urn:oasis:names:specification:ubl:signature:Invoice" }],
369
+ Signature: [{
370
+ Id: "signature",
371
+ Object: [{ QualifyingProperties: [{
372
+ Target: "signature",
373
+ SignedProperties: signedProperties.SignedProperties
374
+ }] }],
375
+ KeyInfo: [{ X509Data: [{
376
+ X509Certificate: [{ _: certificate }],
377
+ X509SubjectName: [{ _: certInfo.subjectName }],
378
+ X509IssuerSerial: [{
379
+ X509IssuerName: [{ _: certInfo.issuerName }],
380
+ X509SerialNumber: [{ _: certInfo.serialNumber }]
381
+ }]
382
+ }] }],
383
+ SignatureValue: [{ _: signatureValue }],
384
+ SignedInfo: [signedInfo]
385
+ }]
386
+ }] }] }]
387
+ }] }],
388
+ Signature: [{
389
+ ID: [{ _: "urn:oasis:names:specification:ubl:signature:Invoice" }],
390
+ SignatureMethod: [{ _: "urn:oasis:names:specification:ubl:dsig:enveloped:xades" }]
391
+ }]
392
+ };
393
+ });
394
+ return {
395
+ _D: "urn:oasis:names:specification:ubl:schema:xsd:Invoice-2",
396
+ _A: "urn:oasis:names:specification:ubl:schema:xsd:CommonAggregateComponents-2",
397
+ _B: "urn:oasis:names:specification:ubl:schema:xsd:CommonBasicComponents-2",
398
+ Invoice: signedInvoices
399
+ };
400
+ } catch (error) {
401
+ throw new Error(`Document generation failed: ${error instanceof Error ? error.message : String(error)}`);
402
+ }
403
+ };
404
+
405
+ //#endregion
406
+ Object.defineProperty(exports, 'calculateCertificateDigest', {
407
+ enumerable: true,
408
+ get: function () {
409
+ return calculateCertificateDigest;
410
+ }
411
+ });
412
+ Object.defineProperty(exports, 'calculateDocumentDigest', {
413
+ enumerable: true,
414
+ get: function () {
415
+ return calculateDocumentDigest;
416
+ }
417
+ });
418
+ Object.defineProperty(exports, 'calculateSignedPropertiesDigest', {
419
+ enumerable: true,
420
+ get: function () {
421
+ return calculateSignedPropertiesDigest;
422
+ }
423
+ });
424
+ Object.defineProperty(exports, 'canonicalizeJSON', {
425
+ enumerable: true,
426
+ get: function () {
427
+ return canonicalizeJSON;
428
+ }
429
+ });
430
+ Object.defineProperty(exports, 'createSignedInfoAndSign', {
431
+ enumerable: true,
432
+ get: function () {
433
+ return createSignedInfoAndSign;
434
+ }
435
+ });
436
+ Object.defineProperty(exports, 'createSignedProperties', {
437
+ enumerable: true,
438
+ get: function () {
439
+ return createSignedProperties;
440
+ }
441
+ });
442
+ Object.defineProperty(exports, 'extractCertificateInfo', {
443
+ enumerable: true,
444
+ get: function () {
445
+ return extractCertificateInfo;
446
+ }
447
+ });
448
+ Object.defineProperty(exports, 'generateCleanInvoiceObject', {
449
+ enumerable: true,
450
+ get: function () {
451
+ return generateCleanInvoiceObject;
452
+ }
453
+ });
454
+ Object.defineProperty(exports, 'generateCleanUBLDocument', {
455
+ enumerable: true,
456
+ get: function () {
457
+ return generateCleanUBLDocument;
458
+ }
459
+ });
460
+ Object.defineProperty(exports, 'generateCompleteDocument', {
461
+ enumerable: true,
462
+ get: function () {
463
+ return generateCompleteDocument;
464
+ }
465
+ });
466
+ Object.defineProperty(exports, 'sortObjectKeys', {
467
+ enumerable: true,
468
+ get: function () {
469
+ return sortObjectKeys;
470
+ }
471
+ });
472
+ //# sourceMappingURL=document-CARHiGdp.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"document-CARHiGdp.cjs","names":["obj: unknown","sortedObj: Record<string, unknown>","invoice: InvoiceV1_1","invoices: InvoiceV1_1[]","invoice: any","certificatePem: string","X509Certificate","dn: string","serialHex: string","error: unknown","certificateDigest: string","signingTime: string","issuerName: string","serialNumber: string","signedProperties: SignedPropertiesObject","docDigest: string","propsDigest: string","privateKeyPem: string","signingCredentials: SigningCredentials"],"sources":["../src/utils/document.ts"],"sourcesContent":["import crypto, { X509Certificate } from 'crypto'\nimport {\n InvoiceSubmission,\n InvoiceV1_1,\n SigningCredentials,\n SignedPropertiesObject,\n UBLDocument,\n CompleteInvoice,\n SignedInfoObject,\n} from '../types'\n\n/**\n * MyInvois v1.1 Document Generation and Signing Utilities\n * Strictly follows: https://sdk.myinvois.hasil.gov.my/documents/invoice-v1-1\n * JSON Signature Guide: https://sdk.myinvois.hasil.gov.my/signature-creation-json/\n */\n\n/**\n * Helper function to recursively sort object keys for JSON canonicalization\n */\nexport function sortObjectKeys(obj: unknown): unknown {\n if (obj === null || typeof obj !== 'object') {\n return obj\n }\n\n if (Array.isArray(obj)) {\n return obj.map(sortObjectKeys)\n }\n\n const sortedObj: Record<string, unknown> = {}\n const keys = Object.keys(obj as Record<string, unknown>).sort()\n\n for (const key of keys) {\n sortedObj[key] = sortObjectKeys((obj as Record<string, unknown>)[key])\n }\n\n return sortedObj\n}\n\n/**\n * Enhanced canonicalization following MyInvois specification exactly\n * Key changes: ensure consistent ordering and formatting\n */\nexport const canonicalizeJSON = (obj: unknown): string => {\n const sortedObj = sortObjectKeys(obj)\n // Use compact JSON with no extra whitespace\n return JSON.stringify(sortedObj, null, 0)\n}\n\n/**\n * Generates a clean invoice object following MyInvois v1.1 specification exactly\n * This is the base invoice structure WITHOUT signature elements (for hash calculation)\n *\n * Key requirements from working documents:\n * - All mandatory fields must be present\n * - Many optional fields must be present even if empty\n * - Specific field ordering and structure\n * - Correct listID values (e.g., \"3166-1\" not \"ISO3166-1\")\n */\nexport const generateCleanInvoiceObject = (\n invoice: InvoiceV1_1,\n): InvoiceSubmission => {\n return {\n // === MANDATORY CORE FIELDS ===\n ID: [{ _: invoice.eInvoiceCodeOrNumber }],\n IssueDate: [{ _: invoice.eInvoiceDate }],\n IssueTime: [{ _: invoice.eInvoiceTime }],\n InvoiceTypeCode: [\n {\n _: invoice.eInvoiceTypeCode,\n listVersionID: invoice.eInvoiceVersion || '1.1',\n },\n ],\n DocumentCurrencyCode: [{ _: invoice.invoiceCurrencyCode }],\n\n // === SUPPLIER PARTY (AccountingSupplierParty) ===\n AccountingSupplierParty: [\n {\n Party: [\n {\n // Industry Classification - required field\n IndustryClassificationCode: [\n {\n _: invoice.supplier.industryClassificationCode,\n name: invoice.supplier.industryClassificationDescription,\n },\n ],\n\n // Party Identifications\n PartyIdentification: [\n {\n ID: [\n {\n _: invoice.supplier.tin,\n schemeID: 'TIN',\n },\n ],\n },\n {\n ID: [\n {\n _: invoice.supplier.registrationNumber,\n schemeID: invoice.supplier.registrationType || 'NRIC',\n },\n ],\n },\n ],\n\n // Postal Address - FIXED listID format\n PostalAddress: [\n {\n CityName: [{ _: invoice.supplier.address.cityName }],\n CountrySubentityCode: [{ _: invoice.supplier.address.state }],\n AddressLine: [\n {\n Line: [{ _: invoice.supplier.address.addressLine0 }],\n },\n ],\n Country: [\n {\n IdentificationCode: [\n {\n _: invoice.supplier.address.country || 'MYS',\n listID: '3166-1', // FIXED: was \"ISO3166-1\"\n listAgencyID: 'ISO',\n },\n ],\n },\n ],\n },\n ],\n\n // Party Legal Entity\n PartyLegalEntity: [\n {\n RegistrationName: [{ _: invoice.supplier.name }],\n },\n ],\n\n // Contact Information\n Contact: [\n {\n Telephone: [{ _: invoice.supplier.contactNumber || '' }],\n },\n ],\n },\n ],\n },\n ],\n\n // === BUYER PARTY (AccountingCustomerParty) ===\n AccountingCustomerParty: [\n {\n Party: [\n {\n // Party Identifications\n PartyIdentification: [\n {\n ID: [\n {\n _: invoice.buyer.tin,\n schemeID: 'TIN',\n },\n ],\n },\n {\n ID: [\n {\n _: invoice.buyer.registrationNumber,\n schemeID: invoice.buyer.registrationType || 'NRIC',\n },\n ],\n },\n {\n ID: [\n {\n _: invoice.buyer.sstRegistrationNumber || 'NA',\n schemeID: 'SST',\n },\n ],\n },\n ],\n\n // Postal Address - FIXED listID format\n PostalAddress: [\n {\n CityName: [{ _: invoice.buyer.address.cityName }],\n CountrySubentityCode: [{ _: invoice.buyer.address.state }],\n AddressLine: [\n {\n Line: [{ _: invoice.buyer.address.addressLine0 }],\n },\n ],\n Country: [\n {\n IdentificationCode: [\n {\n _: invoice.buyer.address.country || 'MYS',\n listID: '3166-1', // FIXED: was \"ISO3166-1\"\n listAgencyID: 'ISO',\n },\n ],\n },\n ],\n },\n ],\n\n // Party Legal Entity\n PartyLegalEntity: [\n {\n RegistrationName: [{ _: invoice.buyer.name }],\n },\n ],\n\n // Contact Information\n Contact: [\n {\n Telephone: [{ _: invoice.buyer.contactNumber || '' }],\n },\n ],\n },\n ],\n },\n ],\n\n // === TAX TOTAL ===\n TaxTotal: [\n {\n TaxAmount: [\n {\n _: invoice.taxTotal.taxAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxSubtotal: [\n // Generate basic tax subtotal from invoice line items\n {\n TaxableAmount: [\n {\n _: invoice.legalMonetaryTotal.taxExclusiveAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxAmount: [\n {\n _: invoice.taxTotal.taxAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxCategory: [\n {\n ID: [{ _: invoice.invoiceLineItems[0]?.taxType || '01' }],\n TaxScheme: [\n {\n ID: [\n {\n _: 'OTH',\n schemeAgencyID: '6',\n schemeID: 'UN/ECE 5153',\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n\n // === LEGAL MONETARY TOTAL ===\n LegalMonetaryTotal: [\n {\n LineExtensionAmount: [\n {\n _: invoice.legalMonetaryTotal.taxExclusiveAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxExclusiveAmount: [\n {\n _: invoice.legalMonetaryTotal.taxExclusiveAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxInclusiveAmount: [\n {\n _: invoice.legalMonetaryTotal.taxInclusiveAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n PayableAmount: [\n {\n _: invoice.legalMonetaryTotal.payableAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n },\n ],\n\n // === INVOICE LINES ===\n InvoiceLine: invoice.invoiceLineItems.map((item, index) => ({\n ID: [{ _: (index + 1).toString() }],\n\n // Item Information\n Item: [\n {\n CommodityClassification: [\n {\n ItemClassificationCode: [\n {\n _: item.itemClassificationCode,\n listID: 'CLASS',\n },\n ],\n },\n ],\n Description: [{ _: item.itemDescription }],\n },\n ],\n\n ItemPriceExtension: [\n {\n Amount: [\n {\n _: item.totalTaxableAmountPerLine,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n },\n ],\n\n LineExtensionAmount: [\n {\n _: item.totalTaxableAmountPerLine,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n\n // Price Information\n Price: [\n {\n PriceAmount: [\n {\n _: item.unitPrice,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n },\n ],\n\n // Tax Information for line\n TaxTotal: [\n {\n TaxAmount: [\n {\n _: item.taxAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxSubtotal: [\n {\n TaxableAmount: [\n {\n _: item.totalTaxableAmountPerLine,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxAmount: [\n {\n _: item.taxAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxCategory: [\n {\n ID: [{ _: item.taxType }],\n TaxScheme: [\n {\n ID: [\n {\n _: 'OTH',\n schemeAgencyID: '6',\n schemeID: 'UN/ECE 5153',\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n })),\n\n // === TAX EXCHANGE RATE (mandatory where applicable) ===\n TaxExchangeRate: invoice.currencyExchangeRate\n ? [\n {\n SourceCurrencyCode: [\n {\n _: invoice.invoiceCurrencyCode,\n },\n ],\n TargetCurrencyCode: [\n {\n _: 'MYR',\n },\n ],\n CalculationRate: [\n {\n _: invoice.currencyExchangeRate,\n },\n ],\n },\n ]\n : undefined,\n }\n}\n\n/**\n * Generates the complete UBL document structure with namespace declarations\n */\nexport const generateCleanUBLDocument = (\n invoices: InvoiceV1_1[],\n): UBLDocument => {\n return {\n _D: 'urn:oasis:names:specification:ubl:schema:xsd:Invoice-2',\n _A: 'urn:oasis:names:specification:ubl:schema:xsd:CommonAggregateComponents-2',\n _B: 'urn:oasis:names:specification:ubl:schema:xsd:CommonBasicComponents-2',\n Invoice: invoices.map(generateCleanInvoiceObject),\n }\n}\n\n/**\n * Step 2: Calculate Document Digest\n * FIXED: Remove UBLExtensions and Signature before hashing (DS322)\n * Based on working implementation pattern\n */\nexport const calculateDocumentDigest = (invoices: InvoiceV1_1[]): string => {\n // Generate clean UBL document structure\n const cleanDocument = generateCleanUBLDocument(invoices)\n\n // CRITICAL FIX: Remove UBLExtensions and Signature from each invoice before hashing\n const documentForHashing = JSON.parse(JSON.stringify(cleanDocument))\n if (documentForHashing.Invoice && Array.isArray(documentForHashing.Invoice)) {\n documentForHashing.Invoice.forEach((invoice: any) => {\n delete invoice.UBLExtensions\n delete invoice.Signature\n })\n }\n\n // Convert to string for hashing (no canonicalization - use direct JSON.stringify)\n const documentString = JSON.stringify(documentForHashing)\n\n // Calculate SHA-256 hash\n const hash = crypto.createHash('sha256')\n hash.update(documentString, 'utf8')\n\n // Return as Base64 (DocDigest)\n return hash.digest('base64')\n}\n\n/**\n * Step 4: Calculate Certificate Digest\n * Enhanced to handle certificate content properly\n */\nexport const calculateCertificateDigest = (certificatePem: string): string => {\n // Extract certificate content (Base64 without PEM headers/footers)\n const certificateContent = certificatePem\n .replace(/-----BEGIN CERTIFICATE-----/g, '')\n .replace(/-----END CERTIFICATE-----/g, '')\n .replace(/\\s+/g, '') // Remove all whitespace\n\n // Convert Base64 to binary\n const certificateBinary = Buffer.from(certificateContent, 'base64')\n\n // Calculate SHA-256 hash of binary content\n const hash = crypto.createHash('sha256')\n hash.update(certificateBinary)\n\n // Return as Base64\n return hash.digest('base64')\n}\n\n/**\n * Enhanced certificate info extraction with better error handling\n * FIXED: Normalize issuer name format to match MyInvois expectations (DS326)\n */\nexport const extractCertificateInfo = (\n certificatePem: string,\n): {\n issuerName: string\n serialNumber: string\n subjectName: string\n} => {\n try {\n const cert = new X509Certificate(certificatePem)\n\n // Extract serial number and convert to decimal string\n const serialNumberHex = cert.serialNumber\n\n // ENHANCED: Normalize distinguished name format (DS326)\n // Ensures MyInvois portal compatibility for X509IssuerName matching\n const normalizeDistinguishedName = (dn: string): string => {\n // Convert multi-line format to comma-separated RFC2253 format\n const normalized = dn\n .split('\\n')\n .map(line => line.trim())\n .filter(line => line.length > 0)\n .join(', ')\n\n // MyInvois-specific normalization to prevent DS326 errors\n return normalized\n .replace(/\\s*=\\s*/g, '=') // Remove spaces around equals (CRITICAL for portal)\n .replace(/,\\s+/g, ', ') // Ensure single space after commas\n .replace(/\\r/g, '') // Remove any carriage returns\n .replace(/\\s{2,}/g, ' ') // Replace multiple spaces with single space\n .trim() // Remove leading/trailing whitespace\n }\n\n // Enhanced serial number formatting\n const formatSerialNumber = (serialHex: string): string => {\n // Convert hex to decimal and ensure it's a string\n const decimal = BigInt('0x' + serialHex).toString()\n return decimal\n }\n\n return {\n issuerName: normalizeDistinguishedName(cert.issuer),\n serialNumber: formatSerialNumber(serialNumberHex),\n subjectName: normalizeDistinguishedName(cert.subject),\n }\n } catch (error: unknown) {\n throw new Error(\n `Failed to extract certificate info: ${error instanceof Error ? error.message : String(error)}`,\n )\n }\n}\n\n/**\n * Step 5: Create SignedProperties with enhanced structure\n * FIXED: Simplified structure to match MyInvois expectations (DS320)\n * Following MyInvois JSON signature specification exactly\n */\nexport const createSignedProperties = (\n certificateDigest: string,\n signingTime: string,\n issuerName: string,\n serialNumber: string,\n): SignedPropertiesObject => {\n return {\n SignedProperties: [\n {\n Id: 'id-xades-signed-props',\n SignedSignatureProperties: [\n {\n SigningTime: [{ _: signingTime }],\n SigningCertificate: [\n {\n Cert: [\n {\n CertDigest: [\n {\n DigestMethod: [\n {\n Algorithm:\n 'http://www.w3.org/2001/04/xmlenc#sha256',\n },\n ],\n DigestValue: [{ _: certificateDigest }],\n },\n ],\n IssuerSerial: [\n {\n X509IssuerName: [{ _: issuerName }],\n X509SerialNumber: [{ _: serialNumber }],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n }\n}\n\n/**\n * Step 6: Calculate SignedProperties Digest\n * FIXED: Add Target wrapper and use direct JSON stringify (DS320)\n * Based on working implementation pattern\n */\nexport const calculateSignedPropertiesDigest = (\n signedProperties: SignedPropertiesObject,\n): string => {\n // CRITICAL FIX: Wrap with Target as per working implementation\n const signedPropertiesWithTarget = {\n Target: 'signature',\n SignedProperties: signedProperties.SignedProperties,\n }\n\n // Convert to string for hashing (no canonicalization - use direct JSON.stringify)\n const signedPropertiesString = JSON.stringify(signedPropertiesWithTarget)\n\n // Calculate SHA-256 hash\n const hash = crypto.createHash('sha256')\n hash.update(signedPropertiesString, 'utf8')\n\n // Return as Base64 (PropsDigest)\n return hash.digest('base64')\n}\n\n/**\n * Step 3: Create SignedInfo and calculate signature\n * Enhanced with better structure and signature generation\n */\nexport const createSignedInfoAndSign = (\n docDigest: string,\n propsDigest: string,\n privateKeyPem: string,\n): { signedInfo: SignedInfoObject; signatureValue: string } => {\n // Create SignedInfo structure following specification exactly\n const signedInfo = {\n CanonicalizationMethod: [\n {\n _: '',\n Algorithm: 'http://www.w3.org/2006/12/xml-c14n11',\n },\n ],\n SignatureMethod: [\n {\n _: '',\n Algorithm: 'http://www.w3.org/2001/04/xmldsig-more#rsa-sha256',\n },\n ],\n Reference: [\n {\n Id: 'id-doc-signed-data',\n Type: '',\n URI: '',\n DigestMethod: [\n {\n _: '',\n Algorithm: 'http://www.w3.org/2001/04/xmlenc#sha256',\n },\n ],\n DigestValue: [{ _: docDigest }],\n },\n {\n Id: 'id-xades-signed-props',\n Type: 'http://uri.etsi.org/01903/v1.3.2#SignedProperties',\n URI: '#id-xades-signed-props',\n DigestMethod: [\n {\n _: '',\n Algorithm: 'http://www.w3.org/2001/04/xmlenc#sha256',\n },\n ],\n DigestValue: [{ _: propsDigest }],\n },\n ],\n }\n\n // FIXED: Use direct JSON.stringify instead of canonicalization (DS333)\n // Based on working implementation pattern\n const signedInfoString = JSON.stringify(signedInfo)\n\n // Sign with RSA-SHA256 directly (RSA-SHA256 handles hashing internally)\n // FIXED: Removed double-hashing bug that was causing DS333 errors\n try {\n const signer = crypto.createSign('RSA-SHA256')\n signer.update(signedInfoString, 'utf8')\n const signatureValue = signer.sign(privateKeyPem, 'base64')\n\n return { signedInfo, signatureValue }\n } catch (error) {\n throw new Error(\n `Signature generation failed: ${error instanceof Error ? error.message : String(error)}`,\n )\n }\n}\n\n/**\n * Complete document generation with signatures\n * Follows the complete MyInvois JSON signature creation process (Steps 1-7)\n */\nexport const generateCompleteDocument = (\n invoices: InvoiceV1_1[],\n signingCredentials: SigningCredentials,\n): CompleteInvoice => {\n try {\n // Step 1: Generate clean document (done in calculateDocumentDigest)\n // Step 2: Calculate document digest\n const docDigest = calculateDocumentDigest(invoices)\n\n // Generate signing time in proper ISO format\n const signingTime = new Date().toISOString()\n\n // Extract certificate information (enhanced)\n const certInfo = extractCertificateInfo(signingCredentials.certificatePem)\n\n // Step 4: Calculate certificate digest\n const certificateDigest = calculateCertificateDigest(\n signingCredentials.certificatePem,\n )\n\n // Step 5: Create SignedProperties using extracted cert info\n const signedProperties = createSignedProperties(\n certificateDigest,\n signingTime,\n certInfo.issuerName,\n certInfo.serialNumber,\n )\n\n // Step 6: Calculate SignedProperties digest\n const propsDigest = calculateSignedPropertiesDigest(signedProperties)\n\n // Step 3: Create SignedInfo and generate signature\n const { signedInfo, signatureValue } = createSignedInfoAndSign(\n docDigest,\n propsDigest,\n signingCredentials.privateKeyPem,\n )\n\n // Extract certificate content (Base64 without PEM headers)\n const certificate = signingCredentials.certificatePem\n .replace(/-----BEGIN CERTIFICATE-----/g, '')\n .replace(/-----END CERTIFICATE-----/g, '')\n .replace(/\\s+/g, '')\n\n // Step 7: Create final signed document\n const signedInvoices = invoices.map(invoice => {\n const cleanInvoice = generateCleanInvoiceObject(invoice)\n\n return {\n ...cleanInvoice,\n\n // Add UBLExtensions with complete signature structure\n UBLExtensions: [\n {\n UBLExtension: [\n {\n ExtensionURI: [\n {\n _: 'urn:oasis:names:specification:ubl:dsig:enveloped:xades',\n },\n ],\n ExtensionContent: [\n {\n UBLDocumentSignatures: [\n {\n SignatureInformation: [\n {\n ID: [\n {\n _: 'urn:oasis:names:specification:ubl:signature:1',\n },\n ],\n ReferencedSignatureID: [\n {\n _: 'urn:oasis:names:specification:ubl:signature:Invoice',\n },\n ],\n Signature: [\n {\n Id: 'signature',\n Object: [\n {\n QualifyingProperties: [\n {\n Target: 'signature',\n SignedProperties:\n signedProperties.SignedProperties,\n },\n ],\n },\n ],\n KeyInfo: [\n {\n X509Data: [\n {\n X509Certificate: [{ _: certificate }],\n X509SubjectName: [\n { _: certInfo.subjectName },\n ],\n X509IssuerSerial: [\n {\n X509IssuerName: [\n {\n _: certInfo.issuerName,\n },\n ],\n X509SerialNumber: [\n {\n _: certInfo.serialNumber,\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n SignatureValue: [{ _: signatureValue }],\n SignedInfo: [signedInfo],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n\n // Add simple Signature reference\n Signature: [\n {\n ID: [\n {\n _: 'urn:oasis:names:specification:ubl:signature:Invoice',\n },\n ],\n SignatureMethod: [\n {\n _: 'urn:oasis:names:specification:ubl:dsig:enveloped:xades',\n },\n ],\n },\n ],\n }\n })\n\n return {\n _D: 'urn:oasis:names:specification:ubl:schema:xsd:Invoice-2',\n _A: 'urn:oasis:names:specification:ubl:schema:xsd:CommonAggregateComponents-2',\n _B: 'urn:oasis:names:specification:ubl:schema:xsd:CommonBasicComponents-2',\n Invoice: signedInvoices,\n }\n } catch (error) {\n throw new Error(\n `Document generation failed: ${error instanceof Error ? error.message : String(error)}`,\n )\n }\n}\n"],"mappings":"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uB,CACrB,EACE,GAAG,sDACJ,CACF;MACD,WAAW,CACT;OACE,IAAI;OACJ,QAAQ,CACN,EACE,sBAAsB,CACpB;QACE,QAAQ;QACR,kBACE,iBAAiB;OACpB,CACF,EACF,CACF;OACD,SAAS,CACP,EACE,UAAU,CACR;QACE,iBAAiB,CAAC,EAAE,GAAG,YAAa,CAAC;QACrC,iBAAiB,CACf,EAAE,GAAG,SAAS,YAAa,CAC5B;QACD,kBAAkB,CAChB;SACE,gBAAgB,CACd,EACE,GAAG,SAAS,WACb,CACF;SACD,kBAAkB,CAChB,EACE,GAAG,SAAS,aACb,CACF;QACF,CACF;OACF,CACF,EACF,CACF;OACD,gBAAgB,CAAC,EAAE,GAAG,eAAgB,CAAC;OACvC,YAAY,CAAC,UAAW;MACzB,CACF;KACF,CACF,EACF,CACF,EACF,CACF;IACF,CACF,EACF,CACF;IAGD,WAAW,CACT;KACE,IAAI,CACF,EACE,GAAG,sDACJ,CACF;KACD,iBAAiB,CACf,EACE,GAAG,yDACJ,CACF;IACF,CACF;GACF;EACF,EAAC;AAEF,SAAO;GACL,IAAI;GACJ,IAAI;GACJ,IAAI;GACJ,SAAS;EACV;CACF,SAAQ,OAAO;AACd,QAAM,IAAI,OACP,8BAA8B,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM,CAAC;CAEzF;AACF"}