@ripwords/myinvois-client 0.1.0 → 0.1.3

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 (577) hide show
  1. package/CHANGELOG.md +111 -0
  2. package/README.md +128 -4
  3. package/bun.lock +59 -0
  4. package/dist/{0X-Yw7mZEro.d.cts → 0X-CTIq3y3a.d.ts} +1 -2
  5. package/dist/{0X-C4IRh_fJ.d.ts → 0X-Cr3M7hci.d.cts} +1 -1
  6. package/dist/{1X-D_aUVsuM.d.cts → 1X-Bu4oiv8D.d.ts} +1 -2
  7. package/dist/{1X-C-_KHV-Q.d.ts → 1X-BywXCqtn.d.ts} +1 -2
  8. package/dist/{1X-Brnls9Jh.d.ts → 1X-CWwmfCzo.d.cts} +1 -1
  9. package/dist/{1X-BwpSoT3o.d.cts → 1X-ClnJ79HH.d.cts} +1 -1
  10. package/dist/{2X-DkS1BoE5.d.ts → 2X-3fSEGIuE.d.ts} +1 -2
  11. package/dist/{2X-Bb6elyzV.d.cts → 2X-CV9eYhog.d.cts} +1 -1
  12. package/dist/{2X-UdQcQW24.d.ts → 2X-DNtkJ0tj.d.cts} +1 -1
  13. package/dist/{2X-hClUyw26.d.cts → 2X-DnG3FY1f.d.ts} +1 -2
  14. package/dist/{3X-C7VFD-n-.d.cts → 3X--VWVsC84.d.cts} +1 -1
  15. package/dist/{3X-CLMESDvz.d.cts → 3X-BOxfatu3.d.cts} +1 -1
  16. package/dist/{3X-DVDyspgb.d.ts → 3X-CLdmoel1.d.ts} +1 -2
  17. package/dist/{3X-DFI-4RQQ.d.ts → 3X-Ynjfgoll.d.ts} +1 -2
  18. package/dist/{4X-DIfvpU6V.d.cts → 4X-B5ePdMky.d.ts} +1 -2
  19. package/dist/{4X-CvScPJTf.d.cts → 4X-BTG6o1Gn.d.ts} +1 -2
  20. package/dist/{4X-CIJ2JJ2w.d.ts → 4X-By9PzHaY.d.cts} +1 -1
  21. package/dist/{4X-CUR8jlaZ.d.ts → 4X-C7fzDWJ_.d.cts} +1 -1
  22. package/dist/{5X-BOUxhadJ.d.cts → 5X-B5M0Cv_K.d.cts} +1 -1
  23. package/dist/{5X-C6db432h.d.ts → 5X-CNAFsDm2.d.cts} +1 -1
  24. package/dist/{5X-CkLu7Vyd.d.cts → 5X-CjSz1zxJ.d.ts} +1 -2
  25. package/dist/{5X-COsZHUaQ.d.ts → 5X-dhP6fyou.d.ts} +1 -2
  26. package/dist/{6X-Mf32k1d0.d.cts → 6X-B9KP_vEn.d.ts} +1 -2
  27. package/dist/{6X-DE7RJeV6.d.cts → 6X-BHaY0TCf.d.ts} +1 -2
  28. package/dist/{6X-ClZDKOTC.d.ts → 6X-C3elgd-n.d.cts} +1 -1
  29. package/dist/{6X-C_fFIcJC.d.ts → 6X-uObUP4VG.d.cts} +1 -1
  30. package/dist/{7X-DoCUcp-J.d.cts → 7X-BifJnY24.d.cts} +1 -1
  31. package/dist/{7X-Chtd6B66.d.cts → 7X-C4eX_tAk.d.ts} +1 -2
  32. package/dist/{7X-BZyesooz.d.ts → 7X-D3idQBl9.d.cts} +1 -1
  33. package/dist/{7X-kot_VccM.d.ts → 7X-DtkQutx2.d.ts} +1 -2
  34. package/dist/{8X-Dr9RunRw.d.cts → 8X-5n9seY3z.d.ts} +1 -2
  35. package/dist/{8X-DkuKAkHz.d.ts → 8X-C6UMFvQW.d.cts} +1 -1
  36. package/dist/{8X-DqZyMvyV.d.cts → 8X-D6HTLShY.d.ts} +1 -2
  37. package/dist/{8X-Df4DOBOe.d.ts → 8X-DioBXCJ0.d.cts} +1 -1
  38. package/dist/{9X-BaoZtjWF.d.cts → 9X-BjffnXuq.d.cts} +1 -1
  39. package/dist/{9X-BDgifncF.d.ts → 9X-CHZKsIdD.d.ts} +1 -2
  40. package/dist/{9X-BcAb6Uso.d.cts → 9X-CJjPJgIG.d.cts} +1 -1
  41. package/dist/{9X-BhBWlgxG.d.ts → 9X-Cpb6V4JC.d.ts} +1 -2
  42. package/dist/{AX-D6XHWdrY.d.ts → AX-C0w_r3PA.d.ts} +1 -2
  43. package/dist/{AX-BY72FohC.d.cts → AX-DrEd2Ov6.d.cts} +1 -1
  44. package/dist/{BX-D_0C8Qbd.d.ts → BX-C5jc6myN.d.cts} +1 -1
  45. package/dist/{BX-CA0OmrUZ.d.cts → BX-RadlZ-6m.d.ts} +1 -2
  46. package/dist/{CX-glpQSL8x.d.cts → CX-CT1Zzb9D.d.ts} +1 -2
  47. package/dist/{CX-HH4cSZRX.d.ts → CX-oSgvmn3h.d.cts} +1 -1
  48. package/dist/{DX-Dx22ax_I.d.ts → DX-CtUeTKMM.d.ts} +1 -2
  49. package/dist/{DX-DimL1MDM.d.cts → DX-ZIG0enmK.d.cts} +1 -1
  50. package/dist/{EX-BRWh1wFc.d.ts → EX-084Yu7Wt.d.ts} +1 -2
  51. package/dist/{EX-Cx87Ruxl.d.cts → EX-BpWZ5ADq.d.cts} +1 -1
  52. package/dist/{FX-RmjwAr40.d.ts → FX-BrbQM0CW.d.ts} +1 -2
  53. package/dist/{FX-D81UlxNN.d.cts → FX-CvYBEc51.d.cts} +1 -1
  54. package/dist/{GX-CJyo7oDp.d.ts → GX-CU8PZy0G.d.cts} +1 -1
  55. package/dist/{GX-9i7piP9G.d.cts → GX-gKj8iAAh.d.ts} +1 -2
  56. package/dist/{HX-XALBTdLA.d.ts → HX-9D-ZXTy5.d.ts} +1 -2
  57. package/dist/{HX-20GVJAvl.d.cts → HX-DoEErDeE.d.cts} +1 -1
  58. package/dist/{IX-D54NGPsc.d.cts → IX-DR4Fc92A.d.ts} +1 -2
  59. package/dist/{IX-6SZ55QKb.d.ts → IX-jLAUHe8i.d.cts} +1 -1
  60. package/dist/{JX-hQ1XRmLp.d.ts → JX-DIKa9ma-.d.ts} +1 -2
  61. package/dist/{JX-C1RYcwQX.d.cts → JX-DX8BjYQC.d.cts} +1 -1
  62. package/dist/{KX-BNwunEfn.d.ts → KX-DpsJ_unT.d.ts} +1 -2
  63. package/dist/{KX-gQHCIgtQ.d.cts → KX-fZb4_vhw.d.cts} +1 -1
  64. package/dist/{LX-CHYX3X3J.d.ts → LX-D_mI1bk-.d.cts} +1 -1
  65. package/dist/{LX-CPurJGIh.d.cts → LX-DeXPPWUX.d.ts} +1 -2
  66. package/dist/{MX-BnyW5eHf.d.cts → MX-CKMjg_zK.d.ts} +1 -2
  67. package/dist/{MX-BPGLWSUz.d.ts → MX-DlYZhpkT.d.cts} +1 -1
  68. package/dist/{NX-B11fQuco.d.cts → NX-DELEEbad.d.cts} +1 -1
  69. package/dist/{NX-RulN5Ml3.d.ts → NX-oYdb4NDo.d.ts} +1 -2
  70. package/dist/{OX-T-ydRXQS.d.cts → OX-Bid9es3D.d.ts} +1 -2
  71. package/dist/{OX-DgKVSp7I.d.ts → OX-CKPyrIFf.d.cts} +1 -1
  72. package/dist/{PX-DA4A2kEv.d.ts → PX-D7jy9CFk.d.ts} +1 -2
  73. package/dist/{PX-p0n1SzvU.d.cts → PX-SP6NxBtG.d.cts} +1 -1
  74. package/dist/{QX-DrFqsMEs.d.ts → QX-BFWOR4g3.d.ts} +1 -2
  75. package/dist/{QX-CI1NccIB.d.cts → QX-QZA7E2O-.d.cts} +1 -1
  76. package/dist/{RX-Cm7vFcFN.d.ts → RX-DBcgbdeE.d.cts} +1 -1
  77. package/dist/{RX-DnNKol22.d.cts → RX-XHgCyMV1.d.ts} +1 -2
  78. package/dist/{SX-CsPPTu-W.d.ts → SX-Cl8RN8oH.d.ts} +1 -2
  79. package/dist/{SX-BUjiWQYz.d.cts → SX-DmiJeCMN.d.cts} +1 -1
  80. package/dist/{TX-DCY25MdR.d.ts → TX-C1SoDobK.d.cts} +1 -1
  81. package/dist/{TX-DOEpsf05.d.cts → TX-ZymoIbtr.d.ts} +1 -2
  82. package/dist/{UX-DgUOnTFK.d.cts → UX-D-Ndd1ov.d.ts} +1 -2
  83. package/dist/{UX-DauyagHy.d.ts → UX-DFVynFhQ.d.cts} +1 -1
  84. package/dist/{VX-kUX6LM-3.d.cts → VX-B-1b34r7.d.ts} +1 -2
  85. package/dist/{VX-DD4scgCe.d.ts → VX-DsRum5k3.d.cts} +1 -1
  86. package/dist/{WX-DPfyPFFh.d.cts → WX-0GuMjPNZ.d.ts} +1 -2
  87. package/dist/{WX-CjkoppdY.d.ts → WX-VReU5R5M.d.cts} +1 -1
  88. package/dist/{XX-C4C1gQZH.d.cts → XX-CF2NANsy.d.ts} +1 -2
  89. package/dist/{XX-sbsIUOnA.d.ts → XX-ChAviUMj.d.cts} +1 -1
  90. package/dist/{YX-DUdO8mRC.d.ts → YX-B51BbNSg.d.ts} +1 -2
  91. package/dist/{YX-BeT-LsiA.d.cts → YX-QfzeMEKx.d.cts} +1 -1
  92. package/dist/{ZX-DwfcSA-D.d.ts → ZX-BMJS1iAv.d.ts} +1 -2
  93. package/dist/{ZX-BuVTTq-D.d.cts → ZX-Ca2E726a.d.cts} +1 -1
  94. package/dist/api/platform/platformLogin.d.ts +58 -60
  95. package/dist/api/platform/platformLogin.js +1 -1
  96. package/dist/certificate-DFK-788s.cjs +62 -0
  97. package/dist/certificate-DFK-788s.cjs.map +1 -0
  98. package/dist/certificate-aooIRf9A.js +49 -0
  99. package/dist/{classification-codes-C2X4xW5-.d.ts → classification-codes-BKxV-rO9.d.ts} +1 -2
  100. package/dist/{country-code-DsI8Mbzx.d.ts → country-code-CQuaiQm2.d.ts} +1 -2
  101. package/dist/{currencies-DKuDflOO.d.ts → currencies-BYJK-m6v.d.ts} +1 -2
  102. package/dist/document-CARHiGdp.cjs +472 -0
  103. package/dist/document-CARHiGdp.cjs.map +1 -0
  104. package/dist/document-D6VKMAtx.js +405 -0
  105. package/dist/documents-CJ8hqIGH.d.ts +858 -0
  106. package/dist/documents-MGs0EvXh.d.cts +859 -0
  107. package/dist/{e-invoice-C2TxhyrK.d.ts → e-invoice-CmbLQkHw.d.ts} +1 -2
  108. package/dist/{getBaseUrl-Dx6RDC8I.js → getBaseUrl-R3IdgCu3.js} +1 -2
  109. package/dist/{index-B1DSs-wd.d.cts → index-0-EvC6Nv.d.ts} +1 -2
  110. package/dist/{index-FTgB2nM6.d.ts → index-D2_HVwCz.d.cts} +1 -1
  111. package/dist/index.cjs +308 -12
  112. package/dist/index.cjs.map +1 -0
  113. package/dist/index.d.ts +233 -60
  114. package/dist/index.js +306 -11
  115. package/dist/index10.cjs +0 -34
  116. package/dist/index11.cjs +25 -15
  117. package/dist/index11.cjs.map +1 -1
  118. package/dist/index12.cjs +24 -0
  119. package/dist/index12.cjs.map +1 -0
  120. package/dist/index13.cjs +0 -13
  121. package/dist/index15.cjs +3 -2
  122. package/dist/index16.cjs +12 -16
  123. package/dist/index17.cjs +2 -2
  124. package/dist/index18.cjs +336 -204
  125. package/dist/index18.cjs.map +1 -1
  126. package/dist/index19.cjs +325 -105
  127. package/dist/index19.cjs.map +1 -1
  128. package/dist/index20.cjs +136 -133
  129. package/dist/index20.cjs.map +1 -1
  130. package/dist/index21.cjs +203 -59
  131. package/dist/index21.cjs.map +1 -1
  132. package/dist/index22.cjs +104 -262
  133. package/dist/index22.cjs.map +1 -1
  134. package/dist/index23.cjs +132 -74
  135. package/dist/index23.cjs.map +1 -1
  136. package/dist/index24.cjs +59 -102
  137. package/dist/index24.cjs.map +1 -1
  138. package/dist/index25.cjs +262 -68
  139. package/dist/index25.cjs.map +1 -1
  140. package/dist/index26.cjs +74 -107
  141. package/dist/index26.cjs.map +1 -1
  142. package/dist/index27.cjs +102 -95
  143. package/dist/index27.cjs.map +1 -1
  144. package/dist/index28.cjs +68 -13
  145. package/dist/index28.cjs.map +1 -1
  146. package/dist/index29.cjs +107 -33
  147. package/dist/index29.cjs.map +1 -1
  148. package/dist/index30.cjs +95 -14
  149. package/dist/index30.cjs.map +1 -1
  150. package/dist/index31.cjs +11 -22
  151. package/dist/index31.cjs.map +1 -1
  152. package/dist/index32.cjs +31 -13
  153. package/dist/index32.cjs.map +1 -1
  154. package/dist/index33.cjs +12 -7
  155. package/dist/index33.cjs.map +1 -1
  156. package/dist/index34.cjs +22 -7
  157. package/dist/index34.cjs.map +1 -1
  158. package/dist/index35.cjs +13 -10
  159. package/dist/index35.cjs.map +1 -1
  160. package/dist/index36.cjs +7 -6
  161. package/dist/index36.cjs.map +1 -1
  162. package/dist/index37.cjs +7 -101
  163. package/dist/index37.cjs.map +1 -1
  164. package/dist/index38.cjs +10 -106
  165. package/dist/index38.cjs.map +1 -1
  166. package/dist/index39.cjs +6 -119
  167. package/dist/index39.cjs.map +1 -1
  168. package/dist/index40.cjs +101 -106
  169. package/dist/index40.cjs.map +1 -1
  170. package/dist/index41.cjs +106 -98
  171. package/dist/index41.cjs.map +1 -1
  172. package/dist/index42.cjs +119 -118
  173. package/dist/index42.cjs.map +1 -1
  174. package/dist/index43.cjs +106 -127
  175. package/dist/index43.cjs.map +1 -1
  176. package/dist/index44.cjs +98 -117
  177. package/dist/index44.cjs.map +1 -1
  178. package/dist/index45.cjs +118 -14
  179. package/dist/index45.cjs.map +1 -1
  180. package/dist/index46.cjs +127 -95
  181. package/dist/index46.cjs.map +1 -1
  182. package/dist/index47.cjs +117 -142
  183. package/dist/index47.cjs.map +1 -1
  184. package/dist/index48.cjs +14 -114
  185. package/dist/index48.cjs.map +1 -1
  186. package/dist/index49.cjs +95 -144
  187. package/dist/index49.cjs.map +1 -1
  188. package/dist/index5.cjs +0 -25
  189. package/dist/index50.cjs +142 -113
  190. package/dist/index50.cjs.map +1 -1
  191. package/dist/index51.cjs +114 -17
  192. package/dist/index51.cjs.map +1 -1
  193. package/dist/index52.cjs +144 -112
  194. package/dist/index52.cjs.map +1 -1
  195. package/dist/index53.cjs +113 -47
  196. package/dist/index53.cjs.map +1 -1
  197. package/dist/index54.cjs +17 -14
  198. package/dist/index54.cjs.map +1 -1
  199. package/dist/index55.cjs +112 -28
  200. package/dist/index55.cjs.map +1 -1
  201. package/dist/index56.cjs +47 -22
  202. package/dist/index56.cjs.map +1 -1
  203. package/dist/index57.cjs +14 -9
  204. package/dist/index57.cjs.map +1 -1
  205. package/dist/index58.cjs +28 -8
  206. package/dist/index58.cjs.map +1 -1
  207. package/dist/index58.cts.map +1 -0
  208. package/dist/index59.cjs +22 -17
  209. package/dist/index59.cjs.map +1 -1
  210. package/dist/index59.cts.map +1 -1
  211. package/dist/index6.cjs +25 -0
  212. package/dist/{index5.cjs.map → index6.cjs.map} +1 -1
  213. package/dist/index60.cjs +9 -412
  214. package/dist/index60.cjs.map +1 -1
  215. package/dist/index60.cts.map +1 -0
  216. package/dist/index61.cjs +8 -8
  217. package/dist/index61.cjs.map +1 -1
  218. package/dist/index61.cts.map +1 -0
  219. package/dist/index62.cjs +17 -9
  220. package/dist/index62.cjs.map +1 -1
  221. package/dist/index62.cts.map +1 -1
  222. package/dist/index63.cjs +419 -0
  223. package/dist/index63.cjs.map +1 -0
  224. package/dist/index63.cts.map +1 -1
  225. package/dist/index64.cjs +15 -0
  226. package/dist/index64.cjs.map +1 -0
  227. package/dist/index64.cts.map +1 -1
  228. package/dist/index65.cjs +10 -116
  229. package/dist/index65.cjs.map +1 -1
  230. package/dist/index65.cts.map +1 -1
  231. package/dist/index66.cjs +2 -228
  232. package/dist/index66.cts.map +1 -1
  233. package/dist/index8.cjs +0 -25
  234. package/dist/index9.cjs +25 -0
  235. package/dist/{index8.cjs.map → index9.cjs.map} +1 -1
  236. package/dist/msic-codes-C8PJVOaA.d.ts +25 -0
  237. package/dist/{msic-codes-B_1W6lZF.d.cts → msic-codes-CIKdPqag.d.cts} +11 -11
  238. package/dist/{payment-modes-DHihrywe.d.cts → payment-modes-BOTSRC_X.d.ts} +1 -2
  239. package/dist/{payment-modes-B8dNy3SM.d.ts → payment-modes-ghFEXnUl.d.cts} +1 -1
  240. package/dist/platformLogin-PGzMhw1X.cjs.map +1 -1
  241. package/dist/{platformLogin-DsxWWUXr.js → platformLogin-f0bNAoZI.js} +1 -2
  242. package/dist/{signatures-C9QPZTQd.d.ts → signatures-W-_brwdb.d.ts} +1 -2
  243. package/dist/{signatures-BKi9DP2K.d.cts → signatures-hFbt_std.d.cts} +1 -1
  244. package/dist/{state-codes-DXSWtE6a.d.cts → state-codes-BlILGZ9d.d.cts} +1 -1
  245. package/dist/{state-codes-CxG1S9YY.d.ts → state-codes-oeFKlwXZ.d.ts} +1 -2
  246. package/dist/{tax-types-CgwxONDS.d.cts → tax-types-B5sQ8UyN.d.cts} +1 -1
  247. package/dist/{tax-types-CEpfSh5P.d.ts → tax-types-CsQ76JMf.d.ts} +1 -2
  248. package/dist/types/classification-codes.d.ts +1 -1
  249. package/dist/types/country-code.d.ts +1 -1
  250. package/dist/types/currencies.d.ts +1 -1
  251. package/dist/types/documents.d.ts +18 -0
  252. package/dist/types/e-invoice.d.ts +1 -1
  253. package/dist/types/index.d.ts +58 -59
  254. package/dist/types/msic/0X.d.ts +1 -1
  255. package/dist/types/msic/1X.d.ts +1 -1
  256. package/dist/types/msic/2X.d.ts +1 -1
  257. package/dist/types/msic/3X.d.ts +1 -1
  258. package/dist/types/msic/4X.d.ts +1 -1
  259. package/dist/types/msic/5X.d.ts +1 -1
  260. package/dist/types/msic/6X.d.ts +1 -1
  261. package/dist/types/msic/7X.d.ts +1 -1
  262. package/dist/types/msic/8X.d.ts +1 -1
  263. package/dist/types/msic/9X.d.ts +1 -1
  264. package/dist/types/msic-codes.d.ts +11 -11
  265. package/dist/types/payment-modes.d.ts +1 -1
  266. package/dist/types/signatures.d.ts +1 -1
  267. package/dist/types/state-codes.d.ts +1 -1
  268. package/dist/types/tax-types.d.ts +1 -1
  269. package/dist/types/unit/1X.d.ts +1 -1
  270. package/dist/types/unit/2X.d.ts +1 -1
  271. package/dist/types/unit/3X.d.ts +1 -1
  272. package/dist/types/unit/4X.d.ts +1 -1
  273. package/dist/types/unit/5X.d.ts +1 -1
  274. package/dist/types/unit/6X.d.ts +1 -1
  275. package/dist/types/unit/7X.d.ts +1 -1
  276. package/dist/types/unit/8X.d.ts +1 -1
  277. package/dist/types/unit/9X.d.ts +1 -1
  278. package/dist/types/unit/AX.d.ts +1 -1
  279. package/dist/types/unit/BX.d.ts +1 -1
  280. package/dist/types/unit/CX.d.ts +1 -1
  281. package/dist/types/unit/DX.d.ts +1 -1
  282. package/dist/types/unit/EX.d.ts +1 -1
  283. package/dist/types/unit/FX.d.ts +1 -1
  284. package/dist/types/unit/GX.d.ts +1 -1
  285. package/dist/types/unit/HX.d.ts +1 -1
  286. package/dist/types/unit/IX.d.ts +1 -1
  287. package/dist/types/unit/JX.d.ts +1 -1
  288. package/dist/types/unit/KX.d.ts +1 -1
  289. package/dist/types/unit/LX.d.ts +1 -1
  290. package/dist/types/unit/MX.d.ts +1 -1
  291. package/dist/types/unit/NX.d.ts +1 -1
  292. package/dist/types/unit/OX.d.ts +1 -1
  293. package/dist/types/unit/PX.d.ts +1 -1
  294. package/dist/types/unit/QX.d.ts +1 -1
  295. package/dist/types/unit/RX.d.ts +1 -1
  296. package/dist/types/unit/SX.d.ts +1 -1
  297. package/dist/types/unit/TX.d.ts +1 -1
  298. package/dist/types/unit/UX.d.ts +1 -1
  299. package/dist/types/unit/VX.d.ts +1 -1
  300. package/dist/types/unit/WX.d.ts +1 -1
  301. package/dist/types/unit/XX.d.ts +1 -1
  302. package/dist/types/unit/YX.d.ts +1 -1
  303. package/dist/types/unit/ZX.d.ts +1 -1
  304. package/dist/types/unit-types.d.ts +36 -36
  305. package/dist/unit-types-B41YFOLT.d.ts +55 -0
  306. package/dist/unit-types-CjWNk2wS.d.cts +56 -0
  307. package/dist/utils/base64.d.ts +1 -2
  308. package/dist/utils/base64.js +1 -2
  309. package/dist/utils/certificate.d.ts +22 -0
  310. package/dist/utils/certificate.js +3 -0
  311. package/dist/utils/document.d.ts +135 -0
  312. package/dist/utils/document.js +3 -0
  313. package/dist/utils/getBaseUrl.d.ts +1 -2
  314. package/dist/utils/getBaseUrl.js +1 -1
  315. package/dist/utils/helpers.d.ts +271 -0
  316. package/dist/utils/helpers.js +330 -0
  317. package/dist/utils/signature-diagnostics.d.ts +93 -0
  318. package/dist/utils/signature-diagnostics.js +326 -0
  319. package/dist/utils/validation.d.ts +46 -0
  320. package/dist/utils/validation.js +134 -0
  321. package/myinvois-cert.conf.template +23 -0
  322. package/package.json +9 -3
  323. package/scripts/gen-cert.sh +159 -0
  324. package/src/api/platform/platformLogin.ts +1 -1
  325. package/src/index.ts +528 -1
  326. package/src/types/documents.d.ts +870 -0
  327. package/src/types/index.d.ts +1 -1
  328. package/src/utils/certificate.ts +60 -0
  329. package/src/utils/document.ts +852 -0
  330. package/src/utils/helpers.ts +552 -0
  331. package/src/utils/signature-diagnostics.ts +583 -0
  332. package/src/utils/validation.ts +268 -0
  333. package/test/MyInvoiClientWithRealData.test.ts +9 -1
  334. package/test/MyInvoisClient.test.ts +7 -1
  335. package/test/dynamicInvoiceFeatures.test.ts +451 -0
  336. package/test/signAndSubmitInvoice.test.ts +271 -734
  337. package/test/signature-diagnostics.test.ts +130 -0
  338. package/tsconfig.json +0 -3
  339. package/dist/0X-C4IRh_fJ.d.ts.map +0 -1
  340. package/dist/0X-Yw7mZEro.d.cts.map +0 -1
  341. package/dist/1X-Brnls9Jh.d.ts.map +0 -1
  342. package/dist/1X-BwpSoT3o.d.cts.map +0 -1
  343. package/dist/1X-C-_KHV-Q.d.ts.map +0 -1
  344. package/dist/1X-D_aUVsuM.d.cts.map +0 -1
  345. package/dist/2X-Bb6elyzV.d.cts.map +0 -1
  346. package/dist/2X-DkS1BoE5.d.ts.map +0 -1
  347. package/dist/2X-UdQcQW24.d.ts.map +0 -1
  348. package/dist/2X-hClUyw26.d.cts.map +0 -1
  349. package/dist/3X-C7VFD-n-.d.cts.map +0 -1
  350. package/dist/3X-CLMESDvz.d.cts.map +0 -1
  351. package/dist/3X-DFI-4RQQ.d.ts.map +0 -1
  352. package/dist/3X-DVDyspgb.d.ts.map +0 -1
  353. package/dist/4X-CIJ2JJ2w.d.ts.map +0 -1
  354. package/dist/4X-CUR8jlaZ.d.ts.map +0 -1
  355. package/dist/4X-CvScPJTf.d.cts.map +0 -1
  356. package/dist/4X-DIfvpU6V.d.cts.map +0 -1
  357. package/dist/5X-BOUxhadJ.d.cts.map +0 -1
  358. package/dist/5X-C6db432h.d.ts.map +0 -1
  359. package/dist/5X-COsZHUaQ.d.ts.map +0 -1
  360. package/dist/5X-CkLu7Vyd.d.cts.map +0 -1
  361. package/dist/6X-C_fFIcJC.d.ts.map +0 -1
  362. package/dist/6X-ClZDKOTC.d.ts.map +0 -1
  363. package/dist/6X-DE7RJeV6.d.cts.map +0 -1
  364. package/dist/6X-Mf32k1d0.d.cts.map +0 -1
  365. package/dist/7X-BZyesooz.d.ts.map +0 -1
  366. package/dist/7X-Chtd6B66.d.cts.map +0 -1
  367. package/dist/7X-DoCUcp-J.d.cts.map +0 -1
  368. package/dist/7X-kot_VccM.d.ts.map +0 -1
  369. package/dist/8X-Df4DOBOe.d.ts.map +0 -1
  370. package/dist/8X-DkuKAkHz.d.ts.map +0 -1
  371. package/dist/8X-DqZyMvyV.d.cts.map +0 -1
  372. package/dist/8X-Dr9RunRw.d.cts.map +0 -1
  373. package/dist/9X-BDgifncF.d.ts.map +0 -1
  374. package/dist/9X-BaoZtjWF.d.cts.map +0 -1
  375. package/dist/9X-BcAb6Uso.d.cts.map +0 -1
  376. package/dist/9X-BhBWlgxG.d.ts.map +0 -1
  377. package/dist/AX-BY72FohC.d.cts.map +0 -1
  378. package/dist/AX-D6XHWdrY.d.ts.map +0 -1
  379. package/dist/BX-CA0OmrUZ.d.cts.map +0 -1
  380. package/dist/BX-D_0C8Qbd.d.ts.map +0 -1
  381. package/dist/CX-HH4cSZRX.d.ts.map +0 -1
  382. package/dist/CX-glpQSL8x.d.cts.map +0 -1
  383. package/dist/DX-DimL1MDM.d.cts.map +0 -1
  384. package/dist/DX-Dx22ax_I.d.ts.map +0 -1
  385. package/dist/EX-BRWh1wFc.d.ts.map +0 -1
  386. package/dist/EX-Cx87Ruxl.d.cts.map +0 -1
  387. package/dist/FX-D81UlxNN.d.cts.map +0 -1
  388. package/dist/FX-RmjwAr40.d.ts.map +0 -1
  389. package/dist/GX-9i7piP9G.d.cts.map +0 -1
  390. package/dist/GX-CJyo7oDp.d.ts.map +0 -1
  391. package/dist/HX-20GVJAvl.d.cts.map +0 -1
  392. package/dist/HX-XALBTdLA.d.ts.map +0 -1
  393. package/dist/IX-6SZ55QKb.d.ts.map +0 -1
  394. package/dist/IX-D54NGPsc.d.cts.map +0 -1
  395. package/dist/JX-C1RYcwQX.d.cts.map +0 -1
  396. package/dist/JX-hQ1XRmLp.d.ts.map +0 -1
  397. package/dist/KX-BNwunEfn.d.ts.map +0 -1
  398. package/dist/KX-gQHCIgtQ.d.cts.map +0 -1
  399. package/dist/LX-CHYX3X3J.d.ts.map +0 -1
  400. package/dist/LX-CPurJGIh.d.cts.map +0 -1
  401. package/dist/MX-BPGLWSUz.d.ts.map +0 -1
  402. package/dist/MX-BnyW5eHf.d.cts.map +0 -1
  403. package/dist/MyInvoisClient-BrNyMjS-.d.cts +0 -178
  404. package/dist/MyInvoisClient-BrNyMjS-.d.cts.map +0 -1
  405. package/dist/MyInvoisClient-CXu4pdl-.d.ts +0 -178
  406. package/dist/MyInvoisClient-CXu4pdl-.d.ts.map +0 -1
  407. package/dist/MyInvoisClient-Cnvb5iUC.js +0 -299
  408. package/dist/MyInvoisClient-Cnvb5iUC.js.map +0 -1
  409. package/dist/MyInvoisClient-DO1dJfQq.cjs +0 -304
  410. package/dist/MyInvoisClient-DO1dJfQq.cjs.map +0 -1
  411. package/dist/NX-B11fQuco.d.cts.map +0 -1
  412. package/dist/NX-RulN5Ml3.d.ts.map +0 -1
  413. package/dist/OX-DgKVSp7I.d.ts.map +0 -1
  414. package/dist/OX-T-ydRXQS.d.cts.map +0 -1
  415. package/dist/PX-DA4A2kEv.d.ts.map +0 -1
  416. package/dist/PX-p0n1SzvU.d.cts.map +0 -1
  417. package/dist/QX-CI1NccIB.d.cts.map +0 -1
  418. package/dist/QX-DrFqsMEs.d.ts.map +0 -1
  419. package/dist/RX-Cm7vFcFN.d.ts.map +0 -1
  420. package/dist/RX-DnNKol22.d.cts.map +0 -1
  421. package/dist/SX-BUjiWQYz.d.cts.map +0 -1
  422. package/dist/SX-CsPPTu-W.d.ts.map +0 -1
  423. package/dist/TX-DCY25MdR.d.ts.map +0 -1
  424. package/dist/TX-DOEpsf05.d.cts.map +0 -1
  425. package/dist/UX-DauyagHy.d.ts.map +0 -1
  426. package/dist/UX-DgUOnTFK.d.cts.map +0 -1
  427. package/dist/VX-DD4scgCe.d.ts.map +0 -1
  428. package/dist/VX-kUX6LM-3.d.cts.map +0 -1
  429. package/dist/WX-CjkoppdY.d.ts.map +0 -1
  430. package/dist/WX-DPfyPFFh.d.cts.map +0 -1
  431. package/dist/XX-C4C1gQZH.d.cts.map +0 -1
  432. package/dist/XX-sbsIUOnA.d.ts.map +0 -1
  433. package/dist/YX-BeT-LsiA.d.cts.map +0 -1
  434. package/dist/YX-DUdO8mRC.d.ts.map +0 -1
  435. package/dist/ZX-BuVTTq-D.d.cts.map +0 -1
  436. package/dist/ZX-DwfcSA-D.d.ts.map +0 -1
  437. package/dist/api/platform/platformLogin.d.ts.map +0 -1
  438. package/dist/canonicalize-C_fNNpYr.cjs +0 -80
  439. package/dist/canonicalize-C_fNNpYr.cjs.map +0 -1
  440. package/dist/canonicalize-DNUrCGad.js +0 -68
  441. package/dist/canonicalize-DNUrCGad.js.map +0 -1
  442. package/dist/classification-codes-B15PbWxz.d.cts.map +0 -1
  443. package/dist/classification-codes-C2X4xW5-.d.ts.map +0 -1
  444. package/dist/country-code-DPeNFMMi.d.cts.map +0 -1
  445. package/dist/country-code-DsI8Mbzx.d.ts.map +0 -1
  446. package/dist/currencies-DKuDflOO.d.ts.map +0 -1
  447. package/dist/currencies-S5g1gzBU.d.cts.map +0 -1
  448. package/dist/e-invoice-BuwtFnlI.d.cts.map +0 -1
  449. package/dist/e-invoice-C2TxhyrK.d.ts.map +0 -1
  450. package/dist/getBaseUrl-Dx6RDC8I.js.map +0 -1
  451. package/dist/hashCert-Bol7lIh2.js +0 -62
  452. package/dist/hashCert-Bol7lIh2.js.map +0 -1
  453. package/dist/hashCert-mlYEuYex.cjs +0 -68
  454. package/dist/hashCert-mlYEuYex.cjs.map +0 -1
  455. package/dist/hashSignedProperties-9vj5wlYR.js +0 -83
  456. package/dist/hashSignedProperties-9vj5wlYR.js.map +0 -1
  457. package/dist/hashSignedProperties-CU_ZqqmY.cjs +0 -95
  458. package/dist/hashSignedProperties-CU_ZqqmY.cjs.map +0 -1
  459. package/dist/index-B1DSs-wd.d.cts.map +0 -1
  460. package/dist/index-CJNLQVjx.d.ts +0 -1
  461. package/dist/index-FTgB2nM6.d.ts.map +0 -1
  462. package/dist/index-Wy1ONBjV.d.cts +0 -1
  463. package/dist/index10.cjs.map +0 -1
  464. package/dist/index66.cjs.map +0 -1
  465. package/dist/index67.cjs +0 -4
  466. package/dist/index67.cts.map +0 -1
  467. package/dist/index68.cjs +0 -3
  468. package/dist/index68.cts.map +0 -1
  469. package/dist/index69.cjs +0 -4
  470. package/dist/index69.cts.map +0 -1
  471. package/dist/index70.cjs +0 -3
  472. package/dist/index70.cts.map +0 -1
  473. package/dist/index71.cjs +0 -3
  474. package/dist/index71.cts.map +0 -1
  475. package/dist/index72.cjs +0 -3
  476. package/dist/index72.cts.map +0 -1
  477. package/dist/index73.cjs +0 -3
  478. package/dist/index73.cts.map +0 -1
  479. package/dist/invoice-1_1-BJVcw-oE.d.ts +0 -432
  480. package/dist/invoice-1_1-BJVcw-oE.d.ts.map +0 -1
  481. package/dist/invoice-1_1-DWdNPRzr.d.cts +0 -432
  482. package/dist/invoice-1_1-DWdNPRzr.d.cts.map +0 -1
  483. package/dist/invoice1-1-8S-QQn7P.cjs +0 -547
  484. package/dist/invoice1-1-8S-QQn7P.cjs.map +0 -1
  485. package/dist/invoice1-1-CHuLpkFz.js +0 -504
  486. package/dist/invoice1-1-CHuLpkFz.js.map +0 -1
  487. package/dist/msic-codes-B_1W6lZF.d.cts.map +0 -1
  488. package/dist/msic-codes-bs0lTfSZ.d.ts +0 -26
  489. package/dist/msic-codes-bs0lTfSZ.d.ts.map +0 -1
  490. package/dist/payment-modes-B8dNy3SM.d.ts.map +0 -1
  491. package/dist/payment-modes-DHihrywe.d.cts.map +0 -1
  492. package/dist/platformLogin-DsxWWUXr.js.map +0 -1
  493. package/dist/populateFinalDocument-BdyYzz5Y.cjs +0 -96
  494. package/dist/populateFinalDocument-BdyYzz5Y.cjs.map +0 -1
  495. package/dist/populateFinalDocument-BpLXmgLv.js +0 -90
  496. package/dist/populateFinalDocument-BpLXmgLv.js.map +0 -1
  497. package/dist/populateSignedProperties-BJMcBQ6S.cjs +0 -58
  498. package/dist/populateSignedProperties-BJMcBQ6S.cjs.map +0 -1
  499. package/dist/populateSignedProperties-BvGN-YZH.js +0 -52
  500. package/dist/populateSignedProperties-BvGN-YZH.js.map +0 -1
  501. package/dist/sign-B61Cy3gO.cjs +0 -40
  502. package/dist/sign-B61Cy3gO.cjs.map +0 -1
  503. package/dist/sign-DzHK7UhR.js +0 -34
  504. package/dist/sign-DzHK7UhR.js.map +0 -1
  505. package/dist/signatures-BKi9DP2K.d.cts.map +0 -1
  506. package/dist/signatures-C9QPZTQd.d.ts.map +0 -1
  507. package/dist/state-codes-CxG1S9YY.d.ts.map +0 -1
  508. package/dist/state-codes-DXSWtE6a.d.cts.map +0 -1
  509. package/dist/tax-types-CEpfSh5P.d.ts.map +0 -1
  510. package/dist/tax-types-CgwxONDS.d.cts.map +0 -1
  511. package/dist/transform-BLz0S687.cjs +0 -72
  512. package/dist/transform-BLz0S687.cjs.map +0 -1
  513. package/dist/transform-D1q-U6Zj.js +0 -66
  514. package/dist/transform-D1q-U6Zj.js.map +0 -1
  515. package/dist/types/documents/index.d.ts +0 -57
  516. package/dist/types/documents/invoice-1_1.d.ts +0 -56
  517. package/dist/unit-types-1bF0KhIp.d.ts +0 -56
  518. package/dist/unit-types-1bF0KhIp.d.ts.map +0 -1
  519. package/dist/unit-types-CsrkvgfG.d.cts +0 -56
  520. package/dist/unit-types-CsrkvgfG.d.cts.map +0 -1
  521. package/dist/utils/MyInvoisClient.d.ts +0 -60
  522. package/dist/utils/MyInvoisClient.js +0 -13
  523. package/dist/utils/base64.d.ts.map +0 -1
  524. package/dist/utils/base64.js.map +0 -1
  525. package/dist/utils/debug/debug-document-hash.d.ts +0 -100
  526. package/dist/utils/debug/debug-document-hash.d.ts.map +0 -1
  527. package/dist/utils/debug/debug-document-hash.js +0 -120
  528. package/dist/utils/debug/debug-document-hash.js.map +0 -1
  529. package/dist/utils/debug/debug-invoice-submission.d.ts +0 -152
  530. package/dist/utils/debug/debug-invoice-submission.d.ts.map +0 -1
  531. package/dist/utils/debug/debug-invoice-submission.js +0 -226
  532. package/dist/utils/debug/debug-invoice-submission.js.map +0 -1
  533. package/dist/utils/getBaseUrl.d.ts.map +0 -1
  534. package/dist/utils/invoice1-1.d.ts +0 -117
  535. package/dist/utils/invoice1-1.d.ts.map +0 -1
  536. package/dist/utils/invoice1-1.js +0 -10
  537. package/dist/utils/signature/canonicalize.d.ts +0 -26
  538. package/dist/utils/signature/canonicalize.d.ts.map +0 -1
  539. package/dist/utils/signature/canonicalize.js +0 -3
  540. package/dist/utils/signature/hashCert.d.ts +0 -15
  541. package/dist/utils/signature/hashCert.d.ts.map +0 -1
  542. package/dist/utils/signature/hashCert.js +0 -3
  543. package/dist/utils/signature/hashSignedProperties.d.ts +0 -25
  544. package/dist/utils/signature/hashSignedProperties.d.ts.map +0 -1
  545. package/dist/utils/signature/hashSignedProperties.js +0 -3
  546. package/dist/utils/signature/populateFinalDocument.d.ts +0 -23
  547. package/dist/utils/signature/populateFinalDocument.d.ts.map +0 -1
  548. package/dist/utils/signature/populateFinalDocument.js +0 -3
  549. package/dist/utils/signature/populateSignedProperties.d.ts +0 -23
  550. package/dist/utils/signature/populateSignedProperties.d.ts.map +0 -1
  551. package/dist/utils/signature/populateSignedProperties.js +0 -3
  552. package/dist/utils/signature/sign.d.ts +0 -16
  553. package/dist/utils/signature/sign.d.ts.map +0 -1
  554. package/dist/utils/signature/sign.js +0 -3
  555. package/dist/utils/signature/transform.d.ts +0 -16
  556. package/dist/utils/signature/transform.d.ts.map +0 -1
  557. package/dist/utils/signature/transform.js +0 -3
  558. package/src/types/documents/index.d.ts +0 -1
  559. package/src/types/documents/invoice-1_1.d.ts +0 -439
  560. package/src/utils/MyInvoisClient.ts +0 -501
  561. package/src/utils/debug/debug-document-hash.ts +0 -249
  562. package/src/utils/debug/debug-invoice-submission.ts +0 -355
  563. package/src/utils/invoice1-1.ts +0 -671
  564. package/src/utils/signature/canonicalize.ts +0 -104
  565. package/src/utils/signature/hashCert.ts +0 -115
  566. package/src/utils/signature/hashSignedProperties.ts +0 -155
  567. package/src/utils/signature/populateFinalDocument.ts +0 -187
  568. package/src/utils/signature/populateSignedProperties.ts +0 -87
  569. package/src/utils/signature/sign.ts +0 -51
  570. package/src/utils/signature/transform.ts +0 -99
  571. package/test/canonicalize.test.ts +0 -110
  572. package/test/hashCert.test.ts +0 -95
  573. package/test/hashSignedProperties.test.ts +0 -140
  574. package/test/populateFinalDocument.test.ts +0 -218
  575. package/test/populateSignedProperties.test.ts +0 -155
  576. package/test/sign.test.ts +0 -70
  577. package/test/transform.test.ts +0 -158
package/dist/index65.cjs CHANGED
@@ -1,122 +1,16 @@
1
- const require_chunk = require('./chunk-CUT6urMc.cjs');
2
- require('./canonicalize-C_fNNpYr.cjs');
3
- require('./hashCert-mlYEuYex.cjs');
4
- require('./hashSignedProperties-CU_ZqqmY.cjs');
5
- require('./populateFinalDocument-BdyYzz5Y.cjs');
6
- require('./populateSignedProperties-BJMcBQ6S.cjs');
7
- require('./sign-B61Cy3gO.cjs');
8
- require('./transform-BLz0S687.cjs');
9
- const require_invoice1_1 = require('./invoice1-1-8S-QQn7P.cjs');
10
- const crypto = require_chunk.__toESM(require("crypto"));
11
- const xmldom_ts = require_chunk.__toESM(require("xmldom-ts"));
12
1
 
13
- //#region src/utils/debug/debug-document-hash.ts
2
+ //#region src/types/unit/ZX.d.ts
14
3
  /**
15
- * Debug Document Hash Issues
16
- *
17
- * This helps identify why MyInvois is rejecting the document hash
4
+ * Enum representing unit type codes starting with 'Z'.
18
5
  */
19
- /**
20
- * Compare different hash calculation methods to identify the correct approach
21
- */
22
- async function debugDocumentHash(invoiceData, signingCredentials) {
23
- console.log("\n🔍 DEBUGGING DOCUMENT HASH VALIDATION");
24
- console.log("=====================================");
25
- const signedXML = await require_invoice1_1.generateSignedInvoiceXML(invoiceData, signingCredentials);
26
- console.log(`\n📄 Generated signed XML (${signedXML.length} chars)`);
27
- console.log("First 200 chars:", signedXML.substring(0, 200) + "...");
28
- const submissionHash = require_invoice1_1.generateDocumentHash(signedXML);
29
- console.log(`\n📊 SUBMISSION HASH: ${submissionHash}`);
30
- const parser = new xmldom_ts.DOMParserImpl();
31
- const doc = parser.parseFromString(signedXML, "application/xml");
32
- const digestElements = doc.getElementsByTagName("ds:DigestValue");
33
- let signatureDocDigest = "";
34
- if (digestElements.length > 0) {
35
- signatureDocDigest = digestElements[0]?.textContent || "";
36
- console.log(`📊 SIGNATURE DOC DIGEST: ${signatureDocDigest}`);
37
- } else console.error("❌ No DigestValue elements found in signature!");
38
- const rawDocumentHash = crypto.createHash("sha256").update(signedXML, "utf8").digest("hex");
39
- console.log(`📊 RAW DOCUMENT HASH: ${rawDocumentHash}`);
40
- const minifiedXML = signedXML.replace(/>\s+</g, "><").replace(/\s+/g, " ").replace(/>\s/g, ">").replace(/\s</g, "<").trim();
41
- const minifiedDocumentHash = crypto.createHash("sha256").update(minifiedXML, "utf8").digest("hex");
42
- console.log(`📊 MINIFIED DOCUMENT HASH: ${minifiedDocumentHash}`);
43
- console.log(`📊 TRANSFORMED DOCUMENT HASH: [Skipped - requires internal template access]`);
44
- const areEqual = {
45
- submissionVsSignature: submissionHash === Buffer.from(signatureDocDigest, "base64").toString("hex"),
46
- submissionVsRaw: submissionHash === rawDocumentHash,
47
- submissionVsMinified: submissionHash === minifiedDocumentHash,
48
- submissionVsTransformed: false
49
- };
50
- console.log("\n🔍 HASH COMPARISONS:");
51
- console.log(`Submission vs Signature: ${areEqual.submissionVsSignature ? "✅" : "❌"}`);
52
- console.log(`Submission vs Raw: ${areEqual.submissionVsRaw ? "✅" : "❌"}`);
53
- console.log(`Submission vs Minified: ${areEqual.submissionVsMinified ? "✅" : "❌"}`);
54
- console.log(`Submission vs Transformed: ${areEqual.submissionVsTransformed ? "✅" : "❌"}`);
55
- const recommendations = [];
56
- if (!areEqual.submissionVsSignature) {
57
- recommendations.push("❌ Submission hash does not match signature digest - this is likely the root cause!");
58
- recommendations.push("💡 Consider using the same hash calculation method for both signature and submission");
59
- }
60
- if (!areEqual.submissionVsRaw) recommendations.push("⚠️ Current implementation calculates different hashes for signature vs submission");
61
- if (areEqual.submissionVsMinified && !areEqual.submissionVsRaw) recommendations.push("💡 Try using minified XML hash for submission");
62
- if (areEqual.submissionVsTransformed) recommendations.push("💡 The transformed document hash matches - this might be what MyInvois expects");
63
- if (!areEqual.submissionVsSignature) {
64
- recommendations.push("🔧 POTENTIAL FIX: Use the digest value from signature as documentHash in submission");
65
- recommendations.push("🔧 ALTERNATIVE: Ensure submission hash uses same canonicalization as signature creation");
66
- }
67
- console.log("\n💡 RECOMMENDATIONS:");
68
- recommendations.forEach((rec) => console.log(` ${rec}`));
69
- return {
70
- signedXML,
71
- documentHashes: {
72
- submissionHash,
73
- signatureDocDigest,
74
- rawDocumentHash,
75
- minifiedDocumentHash,
76
- transformedDocumentHash: ""
77
- },
78
- areEqual,
79
- recommendations
80
- };
81
- }
82
- /**
83
- * Test different approaches to calculate the submission hash
84
- */
85
- async function testSubmissionHashMethods(invoiceData, signingCredentials) {
86
- console.log("\n🧪 TESTING SUBMISSION HASH METHODS");
87
- console.log("==================================");
88
- const signedXML = await require_invoice1_1.generateSignedInvoiceXML(invoiceData, signingCredentials);
89
- const currentHash = require_invoice1_1.generateDocumentHash(signedXML);
90
- console.log(`Method 1 - Current: ${currentHash}`);
91
- const parser = new xmldom_ts.DOMParserImpl();
92
- const doc = parser.parseFromString(signedXML, "application/xml");
93
- const digestElements = doc.getElementsByTagName("ds:DigestValue");
94
- const signatureDigest = digestElements[0]?.textContent || "";
95
- const signatureDigestHex = Buffer.from(signatureDigest, "base64").toString("hex");
96
- console.log(`Method 2 - Signature Digest: ${signatureDigestHex}`);
97
- console.log(`Method 3 - Canonicalized: [Skipped - requires internal access]`);
98
- console.log(`Method 4 - Transformed: [Skipped - requires internal access]`);
99
- const methods = {
100
- current: currentHash,
101
- signatureDigest: signatureDigestHex,
102
- canonicalized: "",
103
- transformed: ""
104
- };
105
- const recommendations = [];
106
- if (methods.current !== methods.signatureDigest) {
107
- recommendations.push("🔧 PRIMARY RECOMMENDATION: Use signature digest as submission hash");
108
- recommendations.push(" Update generateDocumentHash() to extract digest from signed XML");
109
- }
110
- if (methods.current !== methods.canonicalized) recommendations.push("🔧 ALTERNATIVE: Use canonicalized document hash for submission");
111
- console.log("\n💡 RECOMMENDATIONS:");
112
- recommendations.forEach((rec) => console.log(` ${rec}`));
113
- return {
114
- methods,
115
- recommendations
116
- };
117
- }
6
+ let UnitTypeCodeEnum_ZX = /* @__PURE__ */ function(UnitTypeCodeEnum_ZX$1) {
7
+ UnitTypeCodeEnum_ZX$1["HangingContainer"] = "Z11";
8
+ UnitTypeCodeEnum_ZX$1["Nanomole"] = "Z9";
9
+ UnitTypeCodeEnum_ZX$1["Page"] = "ZP";
10
+ UnitTypeCodeEnum_ZX$1["MutuallyDefined"] = "ZZ";
11
+ return UnitTypeCodeEnum_ZX$1;
12
+ }({});
118
13
 
119
14
  //#endregion
120
- exports.debugDocumentHash = debugDocumentHash;
121
- exports.testSubmissionHashMethods = testSubmissionHashMethods;
15
+ exports.UnitTypeCodeEnum_ZX = UnitTypeCodeEnum_ZX;
122
16
  //# sourceMappingURL=index65.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index65.cjs","names":["invoiceData: InvoiceV1_1","signingCredentials: SigningCredentials","DOMParserImpl","recommendations: string[]"],"sources":["../src/utils/debug/debug-document-hash.ts"],"sourcesContent":["import * as crypto from 'crypto'\nimport { DOMParserImpl } from 'xmldom-ts'\nimport type { InvoiceV1_1 } from '../../types'\nimport { generateDocumentHash, generateSignedInvoiceXML } from '../invoice1-1'\nimport type { SigningCredentials } from '../../types/documents/invoice-1_1.d.ts'\n\n/**\n * Debug Document Hash Issues\n *\n * This helps identify why MyInvois is rejecting the document hash\n */\n\n/**\n * Compare different hash calculation methods to identify the correct approach\n */\nexport async function debugDocumentHash(\n invoiceData: InvoiceV1_1,\n signingCredentials: SigningCredentials,\n): Promise<{\n signedXML: string\n documentHashes: {\n submissionHash: string // The hash sent in submission payload\n signatureDocDigest: string // The digest value inside the signature\n rawDocumentHash: string // Hash of raw signed XML\n minifiedDocumentHash: string // Hash of minified signed XML\n transformedDocumentHash: string // Hash of transformed document (used in signature)\n }\n areEqual: {\n submissionVsSignature: boolean\n submissionVsRaw: boolean\n submissionVsMinified: boolean\n submissionVsTransformed: boolean\n }\n recommendations: string[]\n}> {\n console.log('\\n🔍 DEBUGGING DOCUMENT HASH VALIDATION')\n console.log('=====================================')\n\n // Generate the signed XML\n const signedXML = await generateSignedInvoiceXML(\n invoiceData,\n signingCredentials,\n )\n\n console.log(`\\n📄 Generated signed XML (${signedXML.length} chars)`)\n console.log('First 200 chars:', signedXML.substring(0, 200) + '...')\n\n // 1. Calculate the hash used in submission payload (current implementation)\n const submissionHash = generateDocumentHash(signedXML)\n console.log(`\\n📊 SUBMISSION HASH: ${submissionHash}`)\n\n // 2. Extract the digest value from the signature itself\n const parser = new DOMParserImpl()\n const doc = parser.parseFromString(signedXML, 'application/xml')\n const digestElements = doc.getElementsByTagName('ds:DigestValue')\n let signatureDocDigest = ''\n\n if (digestElements.length > 0) {\n // First DigestValue should be the document digest\n signatureDocDigest = digestElements[0]?.textContent || ''\n console.log(`📊 SIGNATURE DOC DIGEST: ${signatureDocDigest}`)\n } else {\n console.error('❌ No DigestValue elements found in signature!')\n }\n\n // 3. Calculate hash of raw signed XML (what we're currently sending)\n const rawDocumentHash = crypto\n .createHash('sha256')\n .update(signedXML, 'utf8')\n .digest('hex')\n console.log(`📊 RAW DOCUMENT HASH: ${rawDocumentHash}`)\n\n // 4. Calculate hash of minified XML (MyInvois recommendation)\n const minifiedXML = signedXML\n .replace(/>\\s+</g, '><')\n .replace(/\\s+/g, ' ')\n .replace(/>\\s/g, '>')\n .replace(/\\s</g, '<')\n .trim()\n const minifiedDocumentHash = crypto\n .createHash('sha256')\n .update(minifiedXML, 'utf8')\n .digest('hex')\n console.log(`📊 MINIFIED DOCUMENT HASH: ${minifiedDocumentHash}`)\n\n // 5. Calculate hash of the document as it was transformed for signature creation\n // Note: We can't easily recreate the exact transformation without the template,\n // so we'll skip this comparison for now\n console.log(\n `📊 TRANSFORMED DOCUMENT HASH: [Skipped - requires internal template access]`,\n )\n\n // Compare available hashes\n const areEqual = {\n submissionVsSignature:\n submissionHash ===\n Buffer.from(signatureDocDigest, 'base64').toString('hex'),\n submissionVsRaw: submissionHash === rawDocumentHash,\n submissionVsMinified: submissionHash === minifiedDocumentHash,\n submissionVsTransformed: false, // Skip this comparison\n }\n\n console.log('\\n🔍 HASH COMPARISONS:')\n console.log(\n `Submission vs Signature: ${areEqual.submissionVsSignature ? '✅' : '❌'}`,\n )\n console.log(\n `Submission vs Raw: ${areEqual.submissionVsRaw ? '✅' : '❌'}`,\n )\n console.log(\n `Submission vs Minified: ${areEqual.submissionVsMinified ? '✅' : '❌'}`,\n )\n console.log(\n `Submission vs Transformed: ${areEqual.submissionVsTransformed ? '✅' : '❌'}`,\n )\n\n // Generate recommendations\n const recommendations: string[] = []\n\n if (!areEqual.submissionVsSignature) {\n recommendations.push(\n '❌ Submission hash does not match signature digest - this is likely the root cause!',\n )\n recommendations.push(\n '💡 Consider using the same hash calculation method for both signature and submission',\n )\n }\n\n if (!areEqual.submissionVsRaw) {\n recommendations.push(\n '⚠️ Current implementation calculates different hashes for signature vs submission',\n )\n }\n\n if (areEqual.submissionVsMinified && !areEqual.submissionVsRaw) {\n recommendations.push('💡 Try using minified XML hash for submission')\n }\n\n if (areEqual.submissionVsTransformed) {\n recommendations.push(\n '💡 The transformed document hash matches - this might be what MyInvois expects',\n )\n }\n\n // Check if we're using the wrong document for submission hash\n if (!areEqual.submissionVsSignature) {\n recommendations.push(\n '🔧 POTENTIAL FIX: Use the digest value from signature as documentHash in submission',\n )\n recommendations.push(\n '🔧 ALTERNATIVE: Ensure submission hash uses same canonicalization as signature creation',\n )\n }\n\n console.log('\\n💡 RECOMMENDATIONS:')\n recommendations.forEach(rec => console.log(` ${rec}`))\n\n return {\n signedXML,\n documentHashes: {\n submissionHash,\n signatureDocDigest,\n rawDocumentHash,\n minifiedDocumentHash,\n transformedDocumentHash: '',\n },\n areEqual,\n recommendations,\n }\n}\n\n/**\n * Test different approaches to calculate the submission hash\n */\nexport async function testSubmissionHashMethods(\n invoiceData: InvoiceV1_1,\n signingCredentials: SigningCredentials,\n): Promise<{\n methods: {\n current: string // Current implementation\n signatureDigest: string // Use digest from signature\n canonicalized: string // Use same canonicalization as signature\n transformed: string // Use transformed document\n }\n recommendations: string[]\n}> {\n console.log('\\n🧪 TESTING SUBMISSION HASH METHODS')\n console.log('==================================')\n\n // Generate signed XML\n const signedXML = await generateSignedInvoiceXML(\n invoiceData,\n signingCredentials,\n )\n\n // Method 1: Current implementation (direct SHA256 of signed XML)\n const currentHash = generateDocumentHash(signedXML)\n console.log(`Method 1 - Current: ${currentHash}`)\n\n // Method 2: Extract digest from signature\n const parser = new DOMParserImpl()\n const doc = parser.parseFromString(signedXML, 'application/xml')\n const digestElements = doc.getElementsByTagName('ds:DigestValue')\n const signatureDigest = digestElements[0]?.textContent || ''\n const signatureDigestHex = Buffer.from(signatureDigest, 'base64').toString(\n 'hex',\n )\n console.log(`Method 2 - Signature Digest: ${signatureDigestHex}`)\n\n // Method 3: Use same canonicalization as signature creation\n // Note: Skip this method as it requires internal template access\n console.log(`Method 3 - Canonicalized: [Skipped - requires internal access]`)\n\n // Method 4: Hash the transformed document directly\n // Note: Skip this method as it requires internal template access\n console.log(`Method 4 - Transformed: [Skipped - requires internal access]`)\n\n const methods = {\n current: currentHash,\n signatureDigest: signatureDigestHex,\n canonicalized: '', // Skipped\n transformed: '', // Skipped\n }\n\n const recommendations: string[] = []\n\n if (methods.current !== methods.signatureDigest) {\n recommendations.push(\n '🔧 PRIMARY RECOMMENDATION: Use signature digest as submission hash',\n )\n recommendations.push(\n ' Update generateDocumentHash() to extract digest from signed XML',\n )\n }\n\n if (methods.current !== methods.canonicalized) {\n recommendations.push(\n '🔧 ALTERNATIVE: Use canonicalized document hash for submission',\n )\n }\n\n console.log('\\n💡 RECOMMENDATIONS:')\n recommendations.forEach(rec => console.log(` ${rec}`))\n\n return {\n methods,\n recommendations,\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAeA,eAAsB,kBACpBA,aACAC,oBAiBC;AACD,SAAQ,IAAI,0CAA0C;AACtD,SAAQ,IAAI,wCAAwC;CAGpD,MAAM,YAAY,MAAM,4CACtB,aACA,mBACD;AAED,SAAQ,KAAK,6BAA6B,UAAU,OAAO,SAAS;AACpE,SAAQ,IAAI,oBAAoB,UAAU,UAAU,GAAG,IAAI,GAAG,MAAM;CAGpE,MAAM,iBAAiB,wCAAqB,UAAU;AACtD,SAAQ,KAAK,wBAAwB,eAAe,EAAE;CAGtD,MAAM,SAAS,IAAIC;CACnB,MAAM,MAAM,OAAO,gBAAgB,WAAW,kBAAkB;CAChE,MAAM,iBAAiB,IAAI,qBAAqB,iBAAiB;CACjE,IAAI,qBAAqB;AAEzB,KAAI,eAAe,SAAS,GAAG;AAE7B,uBAAqB,eAAe,IAAI,eAAe;AACvD,UAAQ,KAAK,2BAA2B,mBAAmB,EAAE;CAC9D,MACC,SAAQ,MAAM,gDAAgD;CAIhE,MAAM,kBAAkB,OACrB,WAAW,SAAS,CACpB,OAAO,WAAW,OAAO,CACzB,OAAO,MAAM;AAChB,SAAQ,KAAK,wBAAwB,gBAAgB,EAAE;CAGvD,MAAM,cAAc,UACjB,QAAQ,UAAU,KAAK,CACvB,QAAQ,QAAQ,IAAI,CACpB,QAAQ,QAAQ,IAAI,CACpB,QAAQ,QAAQ,IAAI,CACpB,MAAM;CACT,MAAM,uBAAuB,OAC1B,WAAW,SAAS,CACpB,OAAO,aAAa,OAAO,CAC3B,OAAO,MAAM;AAChB,SAAQ,KAAK,6BAA6B,qBAAqB,EAAE;AAKjE,SAAQ,KACL,6EACF;CAGD,MAAM,WAAW;EACf,uBACE,mBACA,OAAO,KAAK,oBAAoB,SAAS,CAAC,SAAS,MAAM;EAC3D,iBAAiB,mBAAmB;EACpC,sBAAsB,mBAAmB;EACzC,yBAAyB;CAC1B;AAED,SAAQ,IAAI,yBAAyB;AACrC,SAAQ,KACL,6BAA6B,SAAS,wBAAwB,MAAM,IAAI,EAC1E;AACD,SAAQ,KACL,6BAA6B,SAAS,kBAAkB,MAAM,IAAI,EACpE;AACD,SAAQ,KACL,6BAA6B,SAAS,uBAAuB,MAAM,IAAI,EACzE;AACD,SAAQ,KACL,6BAA6B,SAAS,0BAA0B,MAAM,IAAI,EAC5E;CAGD,MAAMC,kBAA4B,CAAE;AAEpC,MAAK,SAAS,uBAAuB;AACnC,kBAAgB,KACd,qFACD;AACD,kBAAgB,KACd,uFACD;CACF;AAED,MAAK,SAAS,gBACZ,iBAAgB,KACd,qFACD;AAGH,KAAI,SAAS,yBAAyB,SAAS,gBAC7C,iBAAgB,KAAK,gDAAgD;AAGvE,KAAI,SAAS,wBACX,iBAAgB,KACd,iFACD;AAIH,MAAK,SAAS,uBAAuB;AACnC,kBAAgB,KACd,sFACD;AACD,kBAAgB,KACd,0FACD;CACF;AAED,SAAQ,IAAI,wBAAwB;AACpC,iBAAgB,QAAQ,SAAO,QAAQ,KAAK,KAAK,IAAI,EAAE,CAAC;AAExD,QAAO;EACL;EACA,gBAAgB;GACd;GACA;GACA;GACA;GACA,yBAAyB;EAC1B;EACD;EACA;CACD;AACF;;;;AAKD,eAAsB,0BACpBH,aACAC,oBASC;AACD,SAAQ,IAAI,uCAAuC;AACnD,SAAQ,IAAI,qCAAqC;CAGjD,MAAM,YAAY,MAAM,4CACtB,aACA,mBACD;CAGD,MAAM,cAAc,wCAAqB,UAAU;AACnD,SAAQ,KAAK,sBAAsB,YAAY,EAAE;CAGjD,MAAM,SAAS,IAAIC;CACnB,MAAM,MAAM,OAAO,gBAAgB,WAAW,kBAAkB;CAChE,MAAM,iBAAiB,IAAI,qBAAqB,iBAAiB;CACjE,MAAM,kBAAkB,eAAe,IAAI,eAAe;CAC1D,MAAM,qBAAqB,OAAO,KAAK,iBAAiB,SAAS,CAAC,SAChE,MACD;AACD,SAAQ,KAAK,+BAA+B,mBAAmB,EAAE;AAIjE,SAAQ,KAAK,gEAAgE;AAI7E,SAAQ,KAAK,8DAA8D;CAE3E,MAAM,UAAU;EACd,SAAS;EACT,iBAAiB;EACjB,eAAe;EACf,aAAa;CACd;CAED,MAAMC,kBAA4B,CAAE;AAEpC,KAAI,QAAQ,YAAY,QAAQ,iBAAiB;AAC/C,kBAAgB,KACd,qEACD;AACD,kBAAgB,KACd,qEACD;CACF;AAED,KAAI,QAAQ,YAAY,QAAQ,cAC9B,iBAAgB,KACd,iEACD;AAGH,SAAQ,IAAI,wBAAwB;AACpC,iBAAgB,QAAQ,SAAO,QAAQ,KAAK,KAAK,IAAI,EAAE,CAAC;AAExD,QAAO;EACL;EACA;CACD;AACF"}
1
+ {"version":3,"file":"index65.cjs","names":[],"sources":["../src/types/unit/ZX.d.ts"],"sourcesContent":["/**\n * Unit types starting with Z\n * https://sdk.myinvois.hasil.gov.my/codes/unit-types/\n */\nexport type UnitTypeCode_ZX =\n | 'Z11' // hanging container\n | 'Z9' // nanomole\n | 'ZP' // page\n | 'ZZ' // mutually defined\n\n/**\n * Enum representing unit type codes starting with 'Z'.\n */\nexport enum UnitTypeCodeEnum_ZX {\n HangingContainer = 'Z11',\n Nanomole = 'Z9',\n Page = 'ZP',\n MutuallyDefined = 'ZZ',\n}\n"],"mappings":";;;;;AAaA,IAAY,sEAAL;AACL;AACA;AACA;AACA;;AACD"}
@@ -1 +1 @@
1
- {"version":3,"file":"index65.cts","names":["environment: 'sandbox' | 'production'"],"sources":["../src/utils/getBaseUrl.ts"],"sourcesContent":[],"mappings":";AAAA,IAAa,aAAuC,CAAA,GAAA"}
1
+ {"version":3,"file":"index65.cts","names":[],"sources":["../src/utils/signature-diagnostics.d.ts"],"sourcesContent":["import type { InvoiceV1_1 } from '../types';\nexport interface CertificateAnalysisResult {\n organizationIdentifier?: string;\n serialNumber?: string;\n issuerName: string;\n subjectName: string;\n issues: string[];\n recommendations: string[];\n}\nexport interface SignatureAnalysisResult {\n documentDigest: string;\n certificateDigest: string;\n signedPropertiesDigest: string;\n issues: string[];\n recommendations: string[];\n}\nexport interface DiagnosticResult {\n certificateAnalysis: CertificateAnalysisResult;\n signatureAnalysis: SignatureAnalysisResult;\n summary: {\n totalIssues: number;\n certificateIssues: number;\n signatureIssues: number;\n };\n}\n/**\n * Comprehensive signature diagnostics\n */\nexport declare function diagnoseSignatureIssues(invoices: InvoiceV1_1[], certificatePem: string): DiagnosticResult;\n/**\n * Prints diagnostic results in a formatted way\n */\nexport declare function printDiagnostics(result: DiagnosticResult): void;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,IAAW,4BAA4B,CAAC,GAAG;AAC3C,IAAW,0BAAwB,CAAA,GAAA;AACnC,IAAW,mBAAc;CAAA;CAAA,MAAA;CAAA,MAAA;AAAA;AACzB,IAAW,0BAAW;CAAA;CAAA,MAAA;CAAA,MAAA;AAAA;AACtB,IAAW,mBAAY,CAAA,KAAA,MAAA,gBAAA"}
package/dist/index66.cjs CHANGED
@@ -1,229 +1,3 @@
1
- const require_chunk = require('./chunk-CUT6urMc.cjs');
2
- const require_canonicalize = require('./canonicalize-C_fNNpYr.cjs');
3
- require('./hashCert-mlYEuYex.cjs');
4
- require('./hashSignedProperties-CU_ZqqmY.cjs');
5
- require('./populateFinalDocument-BdyYzz5Y.cjs');
6
- require('./populateSignedProperties-BJMcBQ6S.cjs');
7
- require('./sign-B61Cy3gO.cjs');
8
- const require_transform = require('./transform-BLz0S687.cjs');
9
- const require_invoice1_1 = require('./invoice1-1-8S-QQn7P.cjs');
10
- const xmldom_ts = require_chunk.__toESM(require("xmldom-ts"));
1
+ const require_platformLogin = require('./platformLogin-PGzMhw1X.cjs');
11
2
 
12
- //#region src/utils/debug/debug-invoice-submission.ts
13
- /**
14
- * Tests both canonicalization algorithms and compares their output
15
- * This can help determine if the algorithm difference affects signature validation
16
- * @param xmlDocument - The XML document string to test
17
- * @returns Object with canonicalization results and comparison
18
- */
19
- const testCanonicalizationAlgorithms = async (xmlDocument) => {
20
- const parser = new xmldom_ts.DOMParserImpl();
21
- const doc = parser.parseFromString(xmlDocument, "application/xml");
22
- const results = {
23
- exclusiveC14N: { success: false },
24
- c14n11Fallback: { success: false },
25
- areEqual: false
26
- };
27
- try {
28
- const exclusiveDigest = await require_canonicalize.canonicalizeAndHashDocument(doc, "http://www.w3.org/2001/10/xml-exc-c14n#");
29
- results.exclusiveC14N = {
30
- success: true,
31
- digest: exclusiveDigest
32
- };
33
- } catch (error) {
34
- results.exclusiveC14N = {
35
- success: false,
36
- error: error.message
37
- };
38
- }
39
- try {
40
- const c14n11Digest = await require_canonicalize.canonicalizeAndHashDocumentWithC14N11Fallback(doc);
41
- results.c14n11Fallback = {
42
- success: true,
43
- digest: c14n11Digest
44
- };
45
- } catch (error) {
46
- results.c14n11Fallback = {
47
- success: false,
48
- error: error.message
49
- };
50
- }
51
- if (results.exclusiveC14N.success && results.c14n11Fallback.success) results.areEqual = results.exclusiveC14N.digest === results.c14n11Fallback.digest;
52
- return results;
53
- };
54
- /**
55
- * Simple validation function that checks basic XML structure requirements
56
- */
57
- function validateXMLStructure(xmlString) {
58
- const errors = [];
59
- const warnings = [];
60
- try {
61
- const parser = new xmldom_ts.DOMParserImpl();
62
- const doc = parser.parseFromString(xmlString, "application/xml");
63
- const parserErrors = doc.getElementsByTagName("parsererror");
64
- if (parserErrors.length > 0) {
65
- errors.push("XML parsing failed");
66
- return {
67
- isValid: false,
68
- errors,
69
- warnings
70
- };
71
- }
72
- const requiredElements = [
73
- "Invoice",
74
- "UBLExtensions",
75
- "cbc:ID",
76
- "cbc:IssueDate",
77
- "cbc:IssueTime",
78
- "cbc:InvoiceTypeCode",
79
- "ds:Signature",
80
- "ds:SignatureValue",
81
- "ds:X509Certificate"
82
- ];
83
- for (const element of requiredElements) {
84
- const elements = element.includes(":") ? doc.getElementsByTagName(element) : doc.getElementsByTagName(element);
85
- if (elements.length === 0) errors.push(`Missing required element: ${element}`);
86
- }
87
- const expectedNamespaces = [
88
- "urn:oasis:names:specification:ubl:schema:xsd:Invoice-2",
89
- "urn:oasis:names:specification:ubl:schema:xsd:CommonAggregateComponents-2",
90
- "urn:oasis:names:specification:ubl:schema:xsd:CommonBasicComponents-2"
91
- ];
92
- for (const ns of expectedNamespaces) if (!xmlString.includes(ns)) warnings.push(`Missing namespace declaration: ${ns}`);
93
- } catch (error) {
94
- errors.push(`XML validation error: ${error.message}`);
95
- }
96
- return {
97
- isValid: errors.length === 0,
98
- errors,
99
- warnings
100
- };
101
- }
102
- /**
103
- * Comprehensive debugging function to help identify issues with generated XML
104
- * This validates the structure against MyInvois requirements and provides detailed feedback
105
- */
106
- async function debugSignedInvoiceXML(invoiceInfo, signingCredentials) {
107
- const stepResults = {
108
- step1_template: { success: false },
109
- step2_transform: { success: false },
110
- step3_docDigest: { success: false },
111
- step4_signature: { success: false },
112
- step5_certDigest: { success: false },
113
- step6_signedProps: { success: false },
114
- step7_propsDigest: { success: false },
115
- step8_finalDoc: { success: false }
116
- };
117
- const validationResults = {
118
- xmlStructure: {
119
- valid: false,
120
- errors: []
121
- },
122
- signatureElements: {
123
- valid: false,
124
- errors: []
125
- },
126
- digestValues: {
127
- valid: false,
128
- errors: []
129
- },
130
- certificateInfo: {
131
- valid: false,
132
- errors: []
133
- },
134
- canonicalizationTest: null
135
- };
136
- let signedXML;
137
- try {
138
- try {
139
- const xmlTemplate = require_invoice1_1.generateUBLXMLTemplate(invoiceInfo);
140
- stepResults.step1_template = { success: true };
141
- const parser = new xmldom_ts.DOMParserImpl();
142
- const doc = parser.parseFromString(xmlTemplate, "application/xml");
143
- const parserErrors = doc.getElementsByTagName("parsererror");
144
- if (parserErrors.length > 0) validationResults.xmlStructure.errors.push("XML template parsing failed");
145
- else validationResults.xmlStructure.valid = true;
146
- } catch (error) {
147
- stepResults.step1_template = {
148
- success: false,
149
- error: error.message
150
- };
151
- validationResults.xmlStructure.errors.push(`Template generation failed: ${error.message}`);
152
- }
153
- try {
154
- const xmlTemplate = require_invoice1_1.generateUBLXMLTemplate(invoiceInfo);
155
- const transformedXml = require_transform.transformXmlInvoice(xmlTemplate);
156
- stepResults.step2_transform = { success: true };
157
- if (transformedXml.includes("UBLExtensions")) validationResults.xmlStructure.errors.push("UBLExtensions not properly removed in transformation");
158
- if (transformedXml.includes("<cac:Signature>")) validationResults.xmlStructure.errors.push("cac:Signature elements not properly removed in transformation");
159
- } catch (error) {
160
- stepResults.step2_transform = {
161
- success: false,
162
- error: error.message
163
- };
164
- }
165
- try {
166
- const xmlTemplate = require_invoice1_1.generateUBLXMLTemplate(invoiceInfo);
167
- validationResults.canonicalizationTest = await testCanonicalizationAlgorithms(xmlTemplate);
168
- } catch (error) {
169
- validationResults.canonicalizationTest = { error: error.message };
170
- }
171
- try {
172
- signedXML = await require_invoice1_1.generateSignedInvoiceXML(invoiceInfo, signingCredentials);
173
- const parser = new xmldom_ts.DOMParserImpl();
174
- const finalDoc = parser.parseFromString(signedXML, "application/xml");
175
- const signatureValue = finalDoc.getElementsByTagName("ds:SignatureValue")[0];
176
- const x509Certificate = finalDoc.getElementsByTagName("ds:X509Certificate")[0];
177
- const digestValues = finalDoc.getElementsByTagName("ds:DigestValue");
178
- if (!signatureValue || !signatureValue.textContent?.trim()) validationResults.signatureElements.errors.push("SignatureValue is empty");
179
- if (!x509Certificate || !x509Certificate.textContent?.trim()) validationResults.signatureElements.errors.push("X509Certificate is empty");
180
- if (digestValues.length < 2) validationResults.digestValues.errors.push("Missing digest values (expected at least 2)");
181
- else {
182
- let emptyDigests = 0;
183
- for (let i = 0; i < digestValues.length; i++) {
184
- const digestElement = digestValues[i];
185
- if (!digestElement || !digestElement.textContent?.trim()) emptyDigests++;
186
- }
187
- if (emptyDigests > 0) validationResults.digestValues.errors.push(`${emptyDigests} digest values are empty`);
188
- }
189
- try {
190
- const certInfo = require_invoice1_1.extractCertificateInfo(signingCredentials.certificatePem);
191
- const keyPairValid = require_invoice1_1.validateKeyPair(signingCredentials.certificatePem, signingCredentials.privateKeyPem);
192
- if (!keyPairValid) validationResults.certificateInfo.errors.push("Certificate and private key do not match");
193
- if (!certInfo.issuerName || !certInfo.serialNumber) validationResults.certificateInfo.errors.push("Certificate info extraction failed");
194
- if (validationResults.certificateInfo.errors.length === 0) validationResults.certificateInfo.valid = true;
195
- } catch (error) {
196
- validationResults.certificateInfo.errors.push(`Certificate validation failed: ${error.message}`);
197
- }
198
- if (validationResults.signatureElements.errors.length === 0) validationResults.signatureElements.valid = true;
199
- if (validationResults.digestValues.errors.length === 0) validationResults.digestValues.valid = true;
200
- stepResults.step3_docDigest = { success: true };
201
- stepResults.step4_signature = { success: true };
202
- stepResults.step5_certDigest = { success: true };
203
- stepResults.step6_signedProps = { success: true };
204
- stepResults.step7_propsDigest = { success: true };
205
- stepResults.step8_finalDoc = { success: true };
206
- } catch (error) {
207
- console.error("Error during signing process:", error);
208
- stepResults.step8_finalDoc = {
209
- success: false,
210
- error: error.message
211
- };
212
- }
213
- } catch (error) {
214
- console.error("Fatal error in debugging:", error);
215
- }
216
- const allValid = validationResults.xmlStructure.valid && validationResults.signatureElements.valid && validationResults.digestValues.valid && validationResults.certificateInfo.valid;
217
- return {
218
- success: allValid,
219
- signedXML,
220
- validationResults,
221
- stepByStepResults: stepResults
222
- };
223
- }
224
-
225
- //#endregion
226
- exports.debugSignedInvoiceXML = debugSignedInvoiceXML;
227
- exports.testCanonicalizationAlgorithms = testCanonicalizationAlgorithms;
228
- exports.validateXMLStructure = validateXMLStructure;
229
- //# sourceMappingURL=index66.cjs.map
3
+ exports.platformLogin = require_platformLogin.platformLogin;
@@ -1 +1 @@
1
- {"version":3,"file":"index66.cts","names":["xmlDocument: string","certificatePem: string","privateKeyPem: string","invoiceInfo: InvoiceV1_1","signingCredentials: SigningCredentials"],"sources":["../src/utils/invoice1-1.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8TA,IAAa,uBAAwBA,CAAAA,GAAAA;AA2CrC,IAAa,8BAA+BA,CAAAA,GAAAA;AAc5C,IAAa,yBAKZ,CAAA,GAAA;AA+BD,IAAa,kBAEXE,CAAAA,GAAAA;AA6BF,IAAgB,2BAAA,CAAA,KAAA,MAGb,kBAAA;AAoBH,IAAgB,yBAAA,CAAA,KAAA,MAAoC,WAAA;AAgHpD,IAAa,2BAGV;CAAA;CAAA,MAFY;CAAA,MACO;CAAA,MACnB;AAAA;AA4DH,IAAa,oCAEV,CAAA,KAAA,MAAA,OAAA"}
1
+ {"version":3,"file":"index66.cts","names":[],"sources":["../src/utils/validation.d.ts"],"sourcesContent":["import type { InvoiceV1_1 } from '../types/documents/index.js';\n/**\n * MyInvois Invoice Validation Utilities\n *\n * Provides comprehensive validation for invoice data before document generation\n * and submission to ensure compliance with MyInvois business rules and format requirements.\n */\nexport interface ValidationResult {\n isValid: boolean;\n errors: ValidationError[];\n warnings: ValidationWarning[];\n}\nexport interface ValidationError {\n field: string;\n code: string;\n message: string;\n severity: 'error' | 'warning';\n}\nexport interface ValidationWarning extends ValidationError {\n severity: 'warning';\n}\n/**\n * Validates TIN format based on registration type\n */\nexport declare const validateTIN: (tin: string, registrationType?: string) => ValidationError[];\n/**\n * Validates contact number format (E.164 standard)\n */\nexport declare const validateContactNumber: (contactNumber: string) => ValidationError[];\n/**\n * Validates monetary amounts\n */\nexport declare const validateMonetaryAmount: (amount: number, fieldName: string, maxDigits?: number, maxDecimals?: number) => ValidationError[];\n/**\n * Validates tax calculation consistency\n */\nexport declare const validateTaxCalculations: (invoice: InvoiceV1_1) => ValidationError[];\n/**\n * Main validation function for complete invoice\n */\nexport declare const validateInvoice: (invoice: InvoiceV1_1) => ValidationResult;\n"],"mappings":";;;AACA,IAAE,mBAAA;CAAA;CAAA,MAAA;CAAA,MAAA;AAAA;AACF,IAAW,kBAAkB,CAAC,GAAI;AAClC,IAAC,oBAAA,CAAA,KAAA,MAAA,eAAA;AACD,IAAW,cAAc,CAAC,KAAK,MAAM,eAAgB;AACrD,IAAW,wBAAwB,CAAC,KAAK,MAAM,eAAgB;AAC/D,IAAE,yBAAA,CAAA,KAAA,MAAA,eAAA;AACF,IAAW,0BAAuB;CAAA;CAAA,MAAA;CAAA,MAAA;AAAA;AAClC,IAAW,kBAAS;CAAA;CAAA,MAAA;CAAA,MAAA;AAAA"}
package/dist/index8.cjs CHANGED
@@ -1,25 +0,0 @@
1
-
2
- //#region src/types/payment-modes.d.ts
3
- /**
4
- * Enum representing the allowed payment mode codes with descriptive names.
5
- * Provides a more readable way to reference payment modes.
6
- *
7
- * @example
8
- * const mode = PaymentModeCodeEnum.Cash;
9
- * console.log(mode); // Output: "01"
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;
21
- }({});
22
-
23
- //#endregion
24
- exports.PaymentModeCodeEnum = PaymentModeCodeEnum;
25
- //# sourceMappingURL=index8.cjs.map
package/dist/index9.cjs CHANGED
@@ -0,0 +1,25 @@
1
+
2
+ //#region src/types/payment-modes.d.ts
3
+ /**
4
+ * Enum representing the allowed payment mode codes with descriptive names.
5
+ * Provides a more readable way to reference payment modes.
6
+ *
7
+ * @example
8
+ * const mode = PaymentModeCodeEnum.Cash;
9
+ * console.log(mode); // Output: "01"
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;
21
+ }({});
22
+
23
+ //#endregion
24
+ exports.PaymentModeCodeEnum = PaymentModeCodeEnum;
25
+ //# sourceMappingURL=index9.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index8.cjs","names":[],"sources":["../src/types/payment-modes.d.ts"],"sourcesContent":["/**\n * Represents the allowed codes for payment modes.\n * Based on the documentation: https://sdk.myinvois.hasil.gov.my/codes/payment-methods/\n */\nexport type PaymentModeCode =\n | '01' // Cash\n | '02' // Cheque\n | '03' // Bank Transfer\n | '04' // Credit Card\n | '05' // Debit Card\n | '06' // e-Wallet / Digital Wallet\n | '07' // Digital Bank\n | '08' // Others\n\n/**\n * Enum representing the allowed payment mode codes with descriptive names.\n * Provides a more readable way to reference payment modes.\n *\n * @example\n * const mode = PaymentModeCodeEnum.Cash;\n * console.log(mode); // Output: \"01\"\n */\nexport enum PaymentModeCodeEnum {\n Cash = '01',\n Cheque = '02',\n BankTransfer = '03',\n CreditCard = '04',\n DebitCard = '05',\n EWalletDigitalWallet = '06',\n DigitalBank = '07',\n Others = '08',\n}\n\n/**\n * Interface representing a payment mode entry.\n * Contains the code and its corresponding description.\n */\nexport interface PaymentMode {\n code: PaymentModeCode\n description: string\n}\n"],"mappings":";;;;;;;;;;AAsBA,IAAY,sEAAL;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACD"}
1
+ {"version":3,"file":"index9.cjs","names":[],"sources":["../src/types/payment-modes.d.ts"],"sourcesContent":["/**\n * Represents the allowed codes for payment modes.\n * Based on the documentation: https://sdk.myinvois.hasil.gov.my/codes/payment-methods/\n */\nexport type PaymentModeCode =\n | '01' // Cash\n | '02' // Cheque\n | '03' // Bank Transfer\n | '04' // Credit Card\n | '05' // Debit Card\n | '06' // e-Wallet / Digital Wallet\n | '07' // Digital Bank\n | '08' // Others\n\n/**\n * Enum representing the allowed payment mode codes with descriptive names.\n * Provides a more readable way to reference payment modes.\n *\n * @example\n * const mode = PaymentModeCodeEnum.Cash;\n * console.log(mode); // Output: \"01\"\n */\nexport enum PaymentModeCodeEnum {\n Cash = '01',\n Cheque = '02',\n BankTransfer = '03',\n CreditCard = '04',\n DebitCard = '05',\n EWalletDigitalWallet = '06',\n DigitalBank = '07',\n Others = '08',\n}\n\n/**\n * Interface representing a payment mode entry.\n * Contains the code and its corresponding description.\n */\nexport interface PaymentMode {\n code: PaymentModeCode\n description: string\n}\n"],"mappings":";;;;;;;;;;AAsBA,IAAY,sEAAL;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACD"}
@@ -0,0 +1,25 @@
1
+ import { MSIC_0X_CODE } from "./0X-CTIq3y3a.js";
2
+ import { MSIC_1X_CODE } from "./1X-Bu4oiv8D.js";
3
+ import { MSIC_2X_CODE } from "./2X-DnG3FY1f.js";
4
+ import { MSIC_3X_CODE } from "./3X-CLdmoel1.js";
5
+ import { MSIC_4X_CODE } from "./4X-BTG6o1Gn.js";
6
+ import { MSIC_5X_CODE } from "./5X-CjSz1zxJ.js";
7
+ import { MSIC_6X_CODE } from "./6X-B9KP_vEn.js";
8
+ import { MSIC_7X_CODE } from "./7X-DtkQutx2.js";
9
+ import { MSIC_8X_CODE } from "./8X-5n9seY3z.js";
10
+ import { MSIC_9X_CODE } from "./9X-Cpb6V4JC.js";
11
+
12
+ //#region src/types/msic-codes.d.ts
13
+
14
+ /**
15
+ * Represents the allowed 5-digit Malaysia Standard Industrial Classification (MSIC) codes.
16
+ * Based on the documentation: https://sdk.myinvois.hasil.gov.my/codes/msic-codes/
17
+ * Interface representing an MSIC code entry.
18
+ * Contains the 5-digit code and its description.
19
+ */
20
+ interface MSICCode {
21
+ code: MSIC_0X_CODE | MSIC_1X_CODE | MSIC_2X_CODE | MSIC_3X_CODE | MSIC_4X_CODE | MSIC_5X_CODE | MSIC_6X_CODE | MSIC_7X_CODE | MSIC_8X_CODE | MSIC_9X_CODE;
22
+ description: string;
23
+ }
24
+ //#endregion
25
+ export { MSICCode };
@@ -1,13 +1,13 @@
1
- import { MSIC_0X_CODE } from "./0X-Yw7mZEro.cjs";
2
- import { MSIC_1X_CODE } from "./1X-D_aUVsuM.cjs";
3
- import { MSIC_2X_CODE } from "./2X-hClUyw26.cjs";
4
- import { MSIC_3X_CODE } from "./3X-CLMESDvz.cjs";
5
- import { MSIC_4X_CODE } from "./4X-CvScPJTf.cjs";
6
- import { MSIC_5X_CODE } from "./5X-CkLu7Vyd.cjs";
7
- import { MSIC_6X_CODE } from "./6X-Mf32k1d0.cjs";
8
- import { MSIC_7X_CODE } from "./7X-DoCUcp-J.cjs";
9
- import { MSIC_8X_CODE } from "./8X-Dr9RunRw.cjs";
10
- import { MSIC_9X_CODE } from "./9X-BaoZtjWF.cjs";
1
+ import { MSIC_0X_CODE } from "./0X-Cr3M7hci.cjs";
2
+ import { MSIC_1X_CODE } from "./1X-CWwmfCzo.cjs";
3
+ import { MSIC_2X_CODE } from "./2X-DNtkJ0tj.cjs";
4
+ import { MSIC_3X_CODE } from "./3X-BOxfatu3.cjs";
5
+ import { MSIC_4X_CODE } from "./4X-C7fzDWJ_.cjs";
6
+ import { MSIC_5X_CODE } from "./5X-CNAFsDm2.cjs";
7
+ import { MSIC_6X_CODE } from "./6X-uObUP4VG.cjs";
8
+ import { MSIC_7X_CODE } from "./7X-BifJnY24.cjs";
9
+ import { MSIC_8X_CODE } from "./8X-DioBXCJ0.cjs";
10
+ import { MSIC_9X_CODE } from "./9X-BjffnXuq.cjs";
11
11
 
12
12
  //#region src/types/msic-codes.d.ts
13
13
 
@@ -23,4 +23,4 @@ interface MSICCode {
23
23
  }
24
24
  //#endregion
25
25
  export { MSICCode };
26
- //# sourceMappingURL=msic-codes-B_1W6lZF.d.cts.map
26
+ //# sourceMappingURL=msic-codes-CIKdPqag.d.cts.map
@@ -40,5 +40,4 @@ interface PaymentMode {
40
40
  description: string;
41
41
  }
42
42
  //#endregion
43
- export { PaymentMode, PaymentModeCode, PaymentModeCodeEnum };
44
- //# sourceMappingURL=payment-modes-DHihrywe.d.cts.map
43
+ export { PaymentMode, PaymentModeCode, PaymentModeCodeEnum };
@@ -41,4 +41,4 @@ interface PaymentMode {
41
41
  }
42
42
  //#endregion
43
43
  export { PaymentMode, PaymentModeCode, PaymentModeCodeEnum };
44
- //# sourceMappingURL=payment-modes-B8dNy3SM.d.ts.map
44
+ //# sourceMappingURL=payment-modes-ghFEXnUl.d.cts.map
@@ -1 +1 @@
1
- {"version":3,"file":"platformLogin-PGzMhw1X.cjs","names":["client: ClientCredentials","tokenResponse: TokenResponse"],"sources":["../src/api/platform/platformLogin.ts"],"sourcesContent":["import type { ClientCredentials, TokenResponse } from 'src/types'\n\nexport const platformLogin = async (\n client: ClientCredentials,\n): Promise<{\n token: string\n tokenExpiration: Date\n}> => {\n const { clientId, clientSecret, baseUrl, onBehalfOf, debug } = client\n try {\n const response = await fetch(`${baseUrl}/connect/token`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...(onBehalfOf ? { onbehalfof: onBehalfOf } : {}),\n },\n body: new URLSearchParams({\n grant_type: 'client_credentials',\n client_id: clientId,\n client_secret: clientSecret,\n scope: 'InvoicingAPI',\n }),\n })\n\n const tokenResponse: TokenResponse = await response.json()\n return {\n token: tokenResponse.access_token,\n tokenExpiration: new Date(Date.now() + tokenResponse.expires_in * 1000),\n }\n } catch (error) {\n if (debug) console.error(error)\n throw error\n }\n}\n"],"mappings":";;AAEA,MAAa,gBAAgB,OAC3BA,WAII;CACJ,MAAM,EAAE,UAAU,cAAc,SAAS,YAAY,OAAO,GAAG;AAC/D,KAAI;EACF,MAAM,WAAW,MAAM,OAAO,EAAE,QAAQ,iBAAiB;GACvD,QAAQ;GACR,SAAS;IACP,gBAAgB;IAChB,GAAI,aAAa,EAAE,YAAY,WAAY,IAAG,CAAE;GACjD;GACD,MAAM,IAAI,gBAAgB;IACxB,YAAY;IACZ,WAAW;IACX,eAAe;IACf,OAAO;GACR;EACF,EAAC;EAEF,MAAMC,gBAA+B,MAAM,SAAS,MAAM;AAC1D,SAAO;GACL,OAAO,cAAc;GACrB,iBAAiB,IAAI,KAAK,KAAK,KAAK,GAAG,cAAc,aAAa;EACnE;CACF,SAAQ,OAAO;AACd,MAAI,MAAO,SAAQ,MAAM,MAAM;AAC/B,QAAM;CACP;AACF"}
1
+ {"version":3,"file":"platformLogin-PGzMhw1X.cjs","names":["client: ClientCredentials","tokenResponse: TokenResponse"],"sources":["../src/api/platform/platformLogin.ts"],"sourcesContent":["import type { ClientCredentials, TokenResponse } from '../../types'\n\nexport const platformLogin = async (\n client: ClientCredentials,\n): Promise<{\n token: string\n tokenExpiration: Date\n}> => {\n const { clientId, clientSecret, baseUrl, onBehalfOf, debug } = client\n try {\n const response = await fetch(`${baseUrl}/connect/token`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...(onBehalfOf ? { onbehalfof: onBehalfOf } : {}),\n },\n body: new URLSearchParams({\n grant_type: 'client_credentials',\n client_id: clientId,\n client_secret: clientSecret,\n scope: 'InvoicingAPI',\n }),\n })\n\n const tokenResponse: TokenResponse = await response.json()\n return {\n token: tokenResponse.access_token,\n tokenExpiration: new Date(Date.now() + tokenResponse.expires_in * 1000),\n }\n } catch (error) {\n if (debug) console.error(error)\n throw error\n }\n}\n"],"mappings":";;AAEA,MAAa,gBAAgB,OAC3BA,WAII;CACJ,MAAM,EAAE,UAAU,cAAc,SAAS,YAAY,OAAO,GAAG;AAC/D,KAAI;EACF,MAAM,WAAW,MAAM,OAAO,EAAE,QAAQ,iBAAiB;GACvD,QAAQ;GACR,SAAS;IACP,gBAAgB;IAChB,GAAI,aAAa,EAAE,YAAY,WAAY,IAAG,CAAE;GACjD;GACD,MAAM,IAAI,gBAAgB;IACxB,YAAY;IACZ,WAAW;IACX,eAAe;IACf,OAAO;GACR;EACF,EAAC;EAEF,MAAMC,gBAA+B,MAAM,SAAS,MAAM;AAC1D,SAAO;GACL,OAAO,cAAc;GACrB,iBAAiB,IAAI,KAAK,KAAK,KAAK,GAAG,cAAc,aAAa;EACnE;CACF,SAAQ,OAAO;AACd,MAAI,MAAO,SAAQ,MAAM,MAAM;AAC/B,QAAM;CACP;AACF"}
@@ -27,5 +27,4 @@ const platformLogin = async (client) => {
27
27
  };
28
28
 
29
29
  //#endregion
30
- export { platformLogin };
31
- //# sourceMappingURL=platformLogin-DsxWWUXr.js.map
30
+ export { platformLogin };
@@ -169,5 +169,4 @@ interface IssuerDigitalSignature {
169
169
  };
170
170
  }
171
171
  //#endregion
172
- export { CanonicalizationMethod, Cert, CertDigest, DigestMethod, IssuerDigitalSignature, IssuerSerial, KeyInfo, QualifyingProperties, Reference, SignatureMethod, SignedInfo, SignedProperties, SignedSignatureProperties, SigningCertificate, Transform, X509Data };
173
- //# sourceMappingURL=signatures-C9QPZTQd.d.ts.map
172
+ export { CanonicalizationMethod, Cert, CertDigest, DigestMethod, IssuerDigitalSignature, IssuerSerial, KeyInfo, QualifyingProperties, Reference, SignatureMethod, SignedInfo, SignedProperties, SignedSignatureProperties, SigningCertificate, Transform, X509Data };
@@ -170,4 +170,4 @@ interface IssuerDigitalSignature {
170
170
  }
171
171
  //#endregion
172
172
  export { CanonicalizationMethod, Cert, CertDigest, DigestMethod, IssuerDigitalSignature, IssuerSerial, KeyInfo, QualifyingProperties, Reference, SignatureMethod, SignedInfo, SignedProperties, SignedSignatureProperties, SigningCertificate, Transform, X509Data };
173
- //# sourceMappingURL=signatures-BKi9DP2K.d.cts.map
173
+ //# sourceMappingURL=signatures-hFbt_std.d.cts.map
@@ -59,4 +59,4 @@ interface State {
59
59
  }
60
60
  //#endregion
61
61
  export { State, StateCode, StateCodeEnum };
62
- //# sourceMappingURL=state-codes-DXSWtE6a.d.cts.map
62
+ //# sourceMappingURL=state-codes-BlILGZ9d.d.cts.map
@@ -58,5 +58,4 @@ interface State {
58
58
  name: string;
59
59
  }
60
60
  //#endregion
61
- export { State, StateCode, StateCodeEnum };
62
- //# sourceMappingURL=state-codes-CxG1S9YY.d.ts.map
61
+ export { State, StateCode, StateCodeEnum };
@@ -39,4 +39,4 @@ interface TaxType {
39
39
  }
40
40
  //#endregion
41
41
  export { TaxType, TaxTypeCode, TaxTypeCodeEnum };
42
- //# sourceMappingURL=tax-types-CgwxONDS.d.cts.map
42
+ //# sourceMappingURL=tax-types-B5sQ8UyN.d.cts.map
@@ -38,5 +38,4 @@ interface TaxType {
38
38
  description: string;
39
39
  }
40
40
  //#endregion
41
- export { TaxType, TaxTypeCode, TaxTypeCodeEnum };
42
- //# sourceMappingURL=tax-types-CEpfSh5P.d.ts.map
41
+ export { TaxType, TaxTypeCode, TaxTypeCodeEnum };
@@ -1,2 +1,2 @@
1
- import { Classification, ClassificationCode, ClassificationCodeEnum } from "../classification-codes-C2X4xW5-.js";
1
+ import { Classification, ClassificationCode, ClassificationCodeEnum } from "../classification-codes-BKxV-rO9.js";
2
2
  export { Classification, ClassificationCode, ClassificationCodeEnum };
@@ -1,2 +1,2 @@
1
- import { Country, CountryCode, CountryCodeEnum, CountryNameEnum } from "../country-code-DsI8Mbzx.js";
1
+ import { Country, CountryCode, CountryCodeEnum, CountryNameEnum } from "../country-code-CQuaiQm2.js";
2
2
  export { Country, CountryCode, CountryCodeEnum, CountryNameEnum };
@@ -1,2 +1,2 @@
1
- import { Currency, CurrencyCode, CurrencyCodeEnum } from "../currencies-DKuDflOO.js";
1
+ import { Currency, CurrencyCode, CurrencyCodeEnum } from "../currencies-BYJK-m6v.js";
2
2
  export { Currency, CurrencyCode, CurrencyCodeEnum };