@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
@@ -0,0 +1,326 @@
1
+ import { calculateCertificateDigest, calculateDocumentDigest, calculateSignedPropertiesDigest, createSignedProperties, extractCertificateInfo } from "../document-D6VKMAtx.js";
2
+ import crypto from "crypto";
3
+
4
+ //#region src/utils/signature-diagnostics.ts
5
+ /**
6
+ * Analyzes certificate for MyInvois compatibility issues
7
+ */
8
+ function analyzeCertificateForDiagnostics(certificatePem) {
9
+ const issues = [];
10
+ const recommendations = [];
11
+ try {
12
+ const cert = new crypto.X509Certificate(certificatePem);
13
+ const certInfo = extractCertificateInfo(certificatePem);
14
+ const parseSubjectFields = (dn) => {
15
+ const fields = {};
16
+ dn.split("\n").forEach((line) => {
17
+ const trimmed = line.trim();
18
+ if (trimmed.includes("=")) {
19
+ const [key, ...valueParts] = trimmed.split("=");
20
+ if (key) fields[key.trim()] = valueParts.join("=").trim();
21
+ }
22
+ });
23
+ return fields;
24
+ };
25
+ const subjectFields = parseSubjectFields(cert.subject);
26
+ const organizationIdentifier = subjectFields["organizationIdentifier"] || subjectFields["2.5.4.97"];
27
+ const serialNumber = subjectFields["serialNumber"];
28
+ if (!organizationIdentifier) {
29
+ issues.push("DS311: Certificate missing organizationIdentifier field (TIN)");
30
+ recommendations.push("CRITICAL: Generate new certificate with organizationIdentifier matching your MyInvois TIN");
31
+ recommendations.push("Portal Error: \"Signer of invoice doesn't match the submitter of document. TIN doesn't match with the OI.\"");
32
+ } else if (organizationIdentifier.length < 10) {
33
+ issues.push("DS311: OrganizationIdentifier (TIN) appears too short - may cause submission rejection");
34
+ recommendations.push("Verify TIN format matches exactly what is registered in MyInvois");
35
+ }
36
+ if (!serialNumber) {
37
+ issues.push("DS312: Certificate missing serialNumber field (business registration)");
38
+ recommendations.push("CRITICAL: Generate new certificate with serialNumber matching your business registration");
39
+ recommendations.push("Portal Error: \"Submitter registration/identity number doesn't match with the certificate SERIALNUMBER.\"");
40
+ }
41
+ if (cert.issuer === cert.subject) {
42
+ issues.push("DS329: Self-signed certificate detected - will fail chain of trust validation");
43
+ recommendations.push("BLOCKING: Obtain certificate from MyInvois-approved CA:");
44
+ recommendations.push("• MSC Trustgate Sdn Bhd");
45
+ recommendations.push("• DigiCert Sdn Bhd");
46
+ recommendations.push("• Cybersign Asia Sdn Bhd");
47
+ recommendations.push("Portal Error: \"Certificate is not valid according to the chain of trust validation or has been issued by an untrusted certificate authority.\"");
48
+ } else {
49
+ const issuerName = cert.issuer.toLowerCase();
50
+ const approvedCAs = [
51
+ "msc trustgate",
52
+ "digicert",
53
+ "cybersign"
54
+ ];
55
+ const isFromApprovedCA = approvedCAs.some((ca) => issuerName.includes(ca));
56
+ if (!isFromApprovedCA) {
57
+ issues.push("DS329: Certificate may not be from MyInvois-approved CA");
58
+ recommendations.push("Verify certificate was issued by an approved CA for MyInvois");
59
+ }
60
+ }
61
+ const rawIssuer = cert.issuer;
62
+ const normalizedIssuer = certInfo.issuerName;
63
+ const normalizedIssuerIssues = [
64
+ {
65
+ check: normalizedIssuer.includes("\n"),
66
+ issue: "Normalized issuer still contains newlines"
67
+ },
68
+ {
69
+ check: normalizedIssuer.includes(" "),
70
+ issue: "Normalized issuer contains double spaces"
71
+ },
72
+ {
73
+ check: /=\s+/.test(normalizedIssuer),
74
+ issue: "Normalized issuer has spaces after equals"
75
+ },
76
+ {
77
+ check: /\s+=/.test(normalizedIssuer),
78
+ issue: "Normalized issuer has spaces before equals"
79
+ },
80
+ {
81
+ check: normalizedIssuer.includes("\r"),
82
+ issue: "Normalized issuer contains carriage returns"
83
+ }
84
+ ];
85
+ const hasActualFormatIssues = normalizedIssuerIssues.some(({ check, issue }) => {
86
+ if (check) {
87
+ issues.push(`DS326: ${issue} - will cause X509IssuerName mismatch`);
88
+ return true;
89
+ }
90
+ return false;
91
+ });
92
+ const hasRawIssuesButNormalizedOk = rawIssuer.includes("\n") && !normalizedIssuer.includes("\n");
93
+ if (hasActualFormatIssues) {
94
+ recommendations.push("CRITICAL: Fix issuer name normalization in signature generation");
95
+ recommendations.push("Portal Error: \"Certificate X509IssuerName doesn't match the X509IssuerName value provided in the signed properties section.\"");
96
+ recommendations.push("The normalization function is not properly formatting the issuer name");
97
+ recommendations.push("Debug: Check document.ts extractCertificateInfo() normalization logic");
98
+ } else if (hasRawIssuesButNormalizedOk) console.log("ℹ️ Note: Raw certificate issuer has newlines but normalization is handling them correctly");
99
+ const now = /* @__PURE__ */ new Date();
100
+ const validFrom = new Date(cert.validFrom);
101
+ const validTo = new Date(cert.validTo);
102
+ if (now < validFrom) {
103
+ issues.push("DS329: Certificate not yet valid (future start date)");
104
+ recommendations.push("Wait until certificate validity period begins");
105
+ }
106
+ if (now > validTo) {
107
+ issues.push("DS329: Certificate has expired");
108
+ recommendations.push("BLOCKING: Renew certificate - expired certificates are rejected");
109
+ }
110
+ try {
111
+ if (cert.keyUsage && !cert.keyUsage.includes("digital signature")) {
112
+ issues.push("DS333: Certificate lacks digitalSignature key usage");
113
+ recommendations.push("Generate new certificate with digitalSignature key usage enabled");
114
+ }
115
+ } catch {
116
+ console.log("Note: Could not check key usage extensions");
117
+ }
118
+ return {
119
+ organizationIdentifier,
120
+ serialNumber,
121
+ issuerName: certInfo.issuerName,
122
+ subjectName: certInfo.subjectName,
123
+ issues,
124
+ recommendations
125
+ };
126
+ } catch (error) {
127
+ issues.push(`Certificate parsing failed: ${error}`);
128
+ recommendations.push("Verify certificate format and validity");
129
+ return {
130
+ issuerName: "",
131
+ subjectName: "",
132
+ issues,
133
+ recommendations
134
+ };
135
+ }
136
+ }
137
+ /**
138
+ * Analyzes signature generation for potential issues
139
+ */
140
+ function analyzeSignatureForDiagnostics(invoices, certificatePem) {
141
+ const issues = [];
142
+ const recommendations = [];
143
+ try {
144
+ const documentDigest = calculateDocumentDigest(invoices);
145
+ const certificateDigest = calculateCertificateDigest(certificatePem);
146
+ const certInfo = extractCertificateInfo(certificatePem);
147
+ const signingTime = (/* @__PURE__ */ new Date()).toISOString();
148
+ const signedProperties = createSignedProperties(certificateDigest, signingTime, certInfo.issuerName, certInfo.serialNumber);
149
+ const signedPropertiesDigest = calculateSignedPropertiesDigest(signedProperties);
150
+ if (documentDigest.length === 0) {
151
+ issues.push("DS333: Document digest generation failed");
152
+ recommendations.push("CRITICAL: Verify document serialization excludes UBLExtensions/Signature");
153
+ recommendations.push("Portal Error: \"Document signature value is not a valid signature of the document digest using the public key of the certificate provided.\"");
154
+ }
155
+ if (certificateDigest.length === 0) {
156
+ issues.push("DS333: Certificate digest generation failed");
157
+ recommendations.push("CRITICAL: Verify certificate format and encoding");
158
+ recommendations.push("Certificate must be properly base64 encoded without headers/footers");
159
+ }
160
+ if (signedPropertiesDigest.length === 0) {
161
+ issues.push("DS333: Signed properties digest generation failed");
162
+ recommendations.push("CRITICAL: Verify signed properties structure and canonicalization");
163
+ recommendations.push("Check XML canonicalization (C14N) is applied correctly");
164
+ }
165
+ try {
166
+ const cert = new crypto.X509Certificate(certificatePem);
167
+ const publicKey = cert.publicKey;
168
+ const keyDetails = publicKey.asymmetricKeyDetails;
169
+ if (keyDetails) {
170
+ if (publicKey.asymmetricKeyType === "rsa" && keyDetails.modulusLength && keyDetails.modulusLength < 2048) {
171
+ issues.push("DS333: RSA key size too small (minimum 2048 bits required)");
172
+ recommendations.push("CRITICAL: Generate new certificate with RSA 2048+ bits");
173
+ }
174
+ const supportedKeyTypes = ["rsa", "ec"];
175
+ if (!supportedKeyTypes.includes(publicKey.asymmetricKeyType || "")) {
176
+ issues.push(`DS333: Unsupported key type: ${publicKey.asymmetricKeyType}`);
177
+ recommendations.push("CRITICAL: Use RSA or EC key types for MyInvois compatibility");
178
+ }
179
+ }
180
+ const certBuffer = Buffer.from(certificatePem.replace(/-----[^-]+-----/g, "").replace(/\s/g, ""), "base64");
181
+ if (certBuffer.length === 0) {
182
+ issues.push("DS333: Certificate encoding appears invalid");
183
+ recommendations.push("CRITICAL: Verify certificate is properly PEM encoded");
184
+ }
185
+ } catch (error) {
186
+ issues.push(`DS333: Certificate validation failed - ${error}`);
187
+ recommendations.push("CRITICAL: Verify certificate format and structure are valid");
188
+ }
189
+ const isValidBase64 = (str) => {
190
+ try {
191
+ return Buffer.from(str, "base64").toString("base64") === str;
192
+ } catch {
193
+ return false;
194
+ }
195
+ };
196
+ if (documentDigest && !isValidBase64(documentDigest)) {
197
+ issues.push("DS333: Document digest is not valid base64 format");
198
+ recommendations.push("Ensure digest is properly base64 encoded");
199
+ }
200
+ if (certificateDigest && !isValidBase64(certificateDigest)) {
201
+ issues.push("DS333: Certificate digest is not valid base64 format");
202
+ recommendations.push("Ensure certificate digest is properly base64 encoded");
203
+ }
204
+ if (signedPropertiesDigest && !isValidBase64(signedPropertiesDigest)) {
205
+ issues.push("DS333: Signed properties digest is not valid base64 format");
206
+ recommendations.push("Ensure signed properties digest is properly base64 encoded");
207
+ }
208
+ return {
209
+ documentDigest,
210
+ certificateDigest,
211
+ signedPropertiesDigest,
212
+ issues,
213
+ recommendations
214
+ };
215
+ } catch (error) {
216
+ issues.push(`Signature analysis failed: ${error}`);
217
+ recommendations.push("Review signature generation implementation");
218
+ return {
219
+ documentDigest: "",
220
+ certificateDigest: "",
221
+ signedPropertiesDigest: "",
222
+ issues,
223
+ recommendations
224
+ };
225
+ }
226
+ }
227
+ /**
228
+ * Comprehensive signature diagnostics
229
+ */
230
+ function diagnoseSignatureIssues(invoices, certificatePem) {
231
+ const certificateAnalysis = analyzeCertificateForDiagnostics(certificatePem);
232
+ const signatureAnalysis = analyzeSignatureForDiagnostics(invoices, certificatePem);
233
+ const certificateIssues = certificateAnalysis.issues.length;
234
+ const signatureIssues = signatureAnalysis.issues.length;
235
+ return {
236
+ certificateAnalysis,
237
+ signatureAnalysis,
238
+ summary: {
239
+ totalIssues: certificateIssues + signatureIssues,
240
+ certificateIssues,
241
+ signatureIssues
242
+ }
243
+ };
244
+ }
245
+ /**
246
+ * Prints diagnostic results in a formatted way
247
+ */
248
+ function printDiagnostics(result) {
249
+ console.log("\n🔍 MyInvois Signature Diagnostics Report");
250
+ console.log("=".repeat(60));
251
+ console.log("\n📜 CERTIFICATE ANALYSIS");
252
+ console.log("-".repeat(30));
253
+ console.log(` Issuer: ${result.certificateAnalysis.issuerName}`);
254
+ console.log(` Subject: ${result.certificateAnalysis.subjectName}`);
255
+ if (result.certificateAnalysis.organizationIdentifier) console.log(` Organization ID (TIN): ${result.certificateAnalysis.organizationIdentifier}`);
256
+ if (result.certificateAnalysis.serialNumber) console.log(` Serial Number: ${result.certificateAnalysis.serialNumber}`);
257
+ if (result.certificateAnalysis.issues.length > 0) {
258
+ console.log("\n 🚨 Certificate Issues:");
259
+ result.certificateAnalysis.issues.forEach((issue, index) => {
260
+ console.log(` ${index + 1}. ${issue}`);
261
+ });
262
+ }
263
+ if (result.certificateAnalysis.recommendations.length > 0) {
264
+ console.log("\n 💡 Certificate Recommendations:");
265
+ result.certificateAnalysis.recommendations.forEach((rec, index) => {
266
+ console.log(` ${index + 1}. ${rec}`);
267
+ });
268
+ }
269
+ console.log("\n🔐 SIGNATURE ANALYSIS");
270
+ console.log("-".repeat(30));
271
+ console.log(` Document Digest: ${result.signatureAnalysis.documentDigest.substring(0, 32)}...`);
272
+ console.log(` Certificate Digest: ${result.signatureAnalysis.certificateDigest.substring(0, 32)}...`);
273
+ console.log(` Signed Properties Digest: ${result.signatureAnalysis.signedPropertiesDigest.substring(0, 32)}...`);
274
+ if (result.signatureAnalysis.issues.length > 0) {
275
+ console.log("\n 🚨 Signature Issues:");
276
+ result.signatureAnalysis.issues.forEach((issue, index) => {
277
+ console.log(` ${index + 1}. ${issue}`);
278
+ });
279
+ }
280
+ if (result.signatureAnalysis.recommendations.length > 0) {
281
+ console.log("\n 💡 Signature Recommendations:");
282
+ result.signatureAnalysis.recommendations.forEach((rec, index) => {
283
+ console.log(` ${index + 1}. ${rec}`);
284
+ });
285
+ }
286
+ console.log("\n📊 SUMMARY");
287
+ console.log("-".repeat(30));
288
+ console.log(` Total Issues Found: ${result.summary.totalIssues}`);
289
+ console.log(` Certificate Issues: ${result.summary.certificateIssues}`);
290
+ console.log(` Signature Issues: ${result.summary.signatureIssues}`);
291
+ if (result.summary.totalIssues === 0) {
292
+ console.log("\n ✅ No issues detected in current analysis");
293
+ console.log(" 🎉 Certificate and signature implementation appear valid");
294
+ } else {
295
+ console.log("\n ⚠️ Issues detected - review recommendations above");
296
+ const hasDS311 = result.certificateAnalysis.issues.some((issue) => issue.includes("DS311"));
297
+ const hasDS312 = result.certificateAnalysis.issues.some((issue) => issue.includes("DS312"));
298
+ const hasDS326 = result.certificateAnalysis.issues.some((issue) => issue.includes("DS326"));
299
+ const hasDS329 = result.certificateAnalysis.issues.some((issue) => issue.includes("DS329"));
300
+ const hasDS333 = result.signatureAnalysis.issues.some((issue) => issue.includes("DS333"));
301
+ console.log("\n 🎯 MYINVOIS PORTAL ERROR ANALYSIS:");
302
+ if (hasDS311) console.log(" ❌ DS311 - TIN mismatch between certificate and submitter");
303
+ if (hasDS312) console.log(" ❌ DS312 - Registration number mismatch with certificate");
304
+ if (hasDS326) console.log(" ❌ DS326 - X509IssuerName format inconsistency");
305
+ if (hasDS329) console.log(" ❌ DS329 - Certificate trust chain validation failure");
306
+ if (hasDS333) console.log(" ❌ DS333 - Document signature validation failure");
307
+ if (result.summary.certificateIssues > 0) {
308
+ console.log("\n 🚨 PRIMARY ACTION REQUIRED:");
309
+ console.log(" Certificate issues must be resolved first");
310
+ console.log(" Self-generated certificates cannot pass MyInvois validation");
311
+ }
312
+ if (result.summary.signatureIssues > 0) {
313
+ console.log("\n ⚙️ SECONDARY ACTION:");
314
+ console.log(" Review and optimize signature implementation");
315
+ }
316
+ console.log("\n 📋 NEXT STEPS:");
317
+ console.log(" 1. Address BLOCKING/CRITICAL issues first");
318
+ console.log(" 2. Test with updated certificate/implementation");
319
+ console.log(" 3. Re-run diagnostics to verify fixes");
320
+ console.log(" 4. Submit test document to MyInvois portal");
321
+ }
322
+ console.log("\n" + "=".repeat(60));
323
+ }
324
+
325
+ //#endregion
326
+ export { diagnoseSignatureIssues, printDiagnostics };
@@ -0,0 +1,46 @@
1
+ import { InvoiceV1_1 } from "../types/documents/index.js";
2
+
3
+ //#region src/utils/validation.d.ts
4
+
5
+ /**
6
+ * MyInvois Invoice Validation Utilities
7
+ *
8
+ * Provides comprehensive validation for invoice data before document generation
9
+ * and submission to ensure compliance with MyInvois business rules and format requirements.
10
+ */
11
+ interface ValidationResult {
12
+ isValid: boolean;
13
+ errors: ValidationError[];
14
+ warnings: ValidationWarning[];
15
+ }
16
+ interface ValidationError {
17
+ field: string;
18
+ code: string;
19
+ message: string;
20
+ severity: "error" | "warning";
21
+ }
22
+ interface ValidationWarning extends ValidationError {
23
+ severity: "warning";
24
+ }
25
+ /**
26
+ * Validates TIN format based on registration type
27
+ */
28
+ declare const validateTIN: (tin: string, registrationType?: string) => ValidationError[];
29
+ /**
30
+ * Validates contact number format (E.164 standard)
31
+ */
32
+ declare const validateContactNumber: (contactNumber: string) => ValidationError[];
33
+ /**
34
+ * Validates monetary amounts
35
+ */
36
+ declare const validateMonetaryAmount: (amount: number, fieldName: string, maxDigits?: number, maxDecimals?: number) => ValidationError[];
37
+ /**
38
+ * Validates tax calculation consistency
39
+ */
40
+ declare const validateTaxCalculations: (invoice: InvoiceV1_1) => ValidationError[];
41
+ /**
42
+ * Main validation function for complete invoice
43
+ */
44
+ declare const validateInvoice: (invoice: InvoiceV1_1) => ValidationResult;
45
+ //#endregion
46
+ export { ValidationError, ValidationResult, ValidationWarning, validateContactNumber, validateInvoice, validateMonetaryAmount, validateTIN, validateTaxCalculations };
@@ -0,0 +1,134 @@
1
+ //#region src/utils/validation.ts
2
+ /**
3
+ * Validates TIN format based on registration type
4
+ */
5
+ const validateTIN = (tin, registrationType) => {
6
+ const errors = [];
7
+ if (!tin) {
8
+ errors.push({
9
+ field: "tin",
10
+ code: "TIN_REQUIRED",
11
+ message: "TIN is required",
12
+ severity: "error"
13
+ });
14
+ return errors;
15
+ }
16
+ if (registrationType === "BRN" && !tin.startsWith("C")) errors.push({
17
+ field: "tin",
18
+ code: "TIN_FORMAT_INVALID",
19
+ message: "Company TIN should start with \"C\" for BRN registration",
20
+ severity: "warning"
21
+ });
22
+ if (registrationType === "NRIC" && !tin.startsWith("IG")) errors.push({
23
+ field: "tin",
24
+ code: "TIN_FORMAT_INVALID",
25
+ message: "Individual TIN should start with \"IG\" for NRIC registration",
26
+ severity: "warning"
27
+ });
28
+ if (tin.length > 14) errors.push({
29
+ field: "tin",
30
+ code: "TIN_LENGTH_INVALID",
31
+ message: "TIN cannot exceed 14 characters",
32
+ severity: "error"
33
+ });
34
+ return errors;
35
+ };
36
+ /**
37
+ * Validates contact number format (E.164 standard)
38
+ */
39
+ const validateContactNumber = (contactNumber) => {
40
+ const errors = [];
41
+ if (!contactNumber || contactNumber === "NA") return errors;
42
+ const e164Regex = /^\+[1-9]\d{1,14}$/;
43
+ if (!e164Regex.test(contactNumber)) errors.push({
44
+ field: "contactNumber",
45
+ code: "CONTACT_FORMAT_INVALID",
46
+ message: "Contact number must be in E.164 format (e.g., +60123456789)",
47
+ severity: "error"
48
+ });
49
+ if (contactNumber.length < 8) errors.push({
50
+ field: "contactNumber",
51
+ code: "CONTACT_LENGTH_INVALID",
52
+ message: "Contact number must be at least 8 characters",
53
+ severity: "error"
54
+ });
55
+ return errors;
56
+ };
57
+ /**
58
+ * Validates monetary amounts
59
+ */
60
+ const validateMonetaryAmount = (amount, fieldName, maxDigits = 18, maxDecimals = 2) => {
61
+ const errors = [];
62
+ if (amount < 0) errors.push({
63
+ field: fieldName,
64
+ code: "AMOUNT_NEGATIVE",
65
+ message: `${fieldName} cannot be negative`,
66
+ severity: "error"
67
+ });
68
+ const amountStr = amount.toString();
69
+ const [integerPart, decimalPart] = amountStr.split(".");
70
+ if (integerPart && integerPart.length > maxDigits - maxDecimals) errors.push({
71
+ field: fieldName,
72
+ code: "AMOUNT_DIGITS_EXCEEDED",
73
+ message: `${fieldName} exceeds maximum ${maxDigits} digits`,
74
+ severity: "error"
75
+ });
76
+ if (decimalPart && decimalPart.length > maxDecimals) errors.push({
77
+ field: fieldName,
78
+ code: "AMOUNT_DECIMALS_EXCEEDED",
79
+ message: `${fieldName} exceeds maximum ${maxDecimals} decimal places`,
80
+ severity: "error"
81
+ });
82
+ return errors;
83
+ };
84
+ /**
85
+ * Validates tax calculation consistency
86
+ */
87
+ const validateTaxCalculations = (invoice) => {
88
+ const errors = [];
89
+ const expectedTaxExclusive = invoice.invoiceLineItems.reduce((sum, item) => sum + item.totalTaxableAmountPerLine, 0);
90
+ const expectedTaxAmount = invoice.invoiceLineItems.reduce((sum, item) => sum + item.taxAmount, 0);
91
+ const tolerance = .01;
92
+ if (Math.abs(invoice.legalMonetaryTotal.taxExclusiveAmount - expectedTaxExclusive) > tolerance) errors.push({
93
+ field: "legalMonetaryTotal.taxExclusiveAmount",
94
+ code: "TAX_EXCLUSIVE_MISMATCH",
95
+ message: `Tax exclusive amount (${invoice.legalMonetaryTotal.taxExclusiveAmount}) doesn't match sum of line items (${expectedTaxExclusive})`,
96
+ severity: "error"
97
+ });
98
+ if (Math.abs(invoice.taxTotal.taxAmount - expectedTaxAmount) > tolerance) errors.push({
99
+ field: "taxTotal.taxAmount",
100
+ code: "TAX_AMOUNT_MISMATCH",
101
+ message: `Tax amount (${invoice.taxTotal.taxAmount}) doesn't match sum of line item taxes (${expectedTaxAmount})`,
102
+ severity: "error"
103
+ });
104
+ return errors;
105
+ };
106
+ /**
107
+ * Main validation function for complete invoice
108
+ */
109
+ const validateInvoice = (invoice) => {
110
+ const allErrors = [];
111
+ allErrors.push(...validateTIN(invoice.supplier.tin, invoice.supplier.registrationType));
112
+ allErrors.push(...validateTIN(invoice.buyer.tin, invoice.buyer.registrationType));
113
+ allErrors.push(...validateContactNumber(invoice.supplier.contactNumber));
114
+ allErrors.push(...validateContactNumber(invoice.buyer.contactNumber));
115
+ allErrors.push(...validateMonetaryAmount(invoice.legalMonetaryTotal.taxExclusiveAmount, "taxExclusiveAmount"));
116
+ allErrors.push(...validateMonetaryAmount(invoice.legalMonetaryTotal.payableAmount, "payableAmount"));
117
+ allErrors.push(...validateMonetaryAmount(invoice.taxTotal.taxAmount, "taxAmount"));
118
+ invoice.invoiceLineItems.forEach((item, index) => {
119
+ allErrors.push(...validateMonetaryAmount(item.unitPrice, `lineItem[${index}].unitPrice`));
120
+ allErrors.push(...validateMonetaryAmount(item.taxAmount, `lineItem[${index}].taxAmount`));
121
+ allErrors.push(...validateMonetaryAmount(item.totalTaxableAmountPerLine, `lineItem[${index}].totalTaxableAmountPerLine`));
122
+ });
123
+ allErrors.push(...validateTaxCalculations(invoice));
124
+ const errors = allErrors.filter((e) => e.severity === "error");
125
+ const warnings = allErrors.filter((e) => e.severity === "warning");
126
+ return {
127
+ isValid: errors.length === 0,
128
+ errors,
129
+ warnings
130
+ };
131
+ };
132
+
133
+ //#endregion
134
+ export { validateContactNumber, validateInvoice, validateMonetaryAmount, validateTIN, validateTaxCalculations };
@@ -0,0 +1,23 @@
1
+ [req]
2
+ distinguished_name = req_distinguished_name
3
+ req_extensions = v3_req
4
+ prompt = no
5
+
6
+ [req_distinguished_name]
7
+ C = MY
8
+ ST = YOUR_STATE
9
+ L = YOUR_CITY
10
+ O = YOUR_COMPANY_NAME
11
+ CN = YOUR_COMPANY_NAME
12
+ emailAddress = YOUR_EMAIL
13
+ # SERIALNUMBER field - Business registration number (e.g., 202301234567)
14
+ serialNumber = YOUR_BUSINESS_REGISTRATION_NUMBER
15
+
16
+ [v3_req]
17
+ keyUsage = keyEncipherment, dataEncipherment, digitalSignature, nonRepudiation
18
+ extendedKeyUsage = clientAuth, emailProtection
19
+ subjectAltName = @alt_names
20
+
21
+ [alt_names]
22
+ email.1 = YOUR_EMAIL
23
+ DNS.1 = YOUR_DOMAIN
package/package.json CHANGED
@@ -1,11 +1,16 @@
1
1
  {
2
2
  "name": "@ripwords/myinvois-client",
3
- "version": "0.1.0",
3
+ "version": "0.1.3",
4
4
  "description": "MyInvois client",
5
5
  "scripts": {
6
6
  "build": "tsdown",
7
- "release": "bun run build && npm publish --access public",
8
- "clean": "rimraf dist",
7
+ "prerelease": "bun run lint && bun run build",
8
+ "postrelease": "git push --follow-tags",
9
+ "changelog": "changelogen --release",
10
+ "publish": "npm publish --access public && git push --follow-tags",
11
+ "release": "bun run prerelease && bun run changelog && bun run publish",
12
+ "release:minor": "bun run prerelease && bun run changelog --minor && bun run publish",
13
+ "release:major": "bun run prerelease && bun run changelog --major && bun run publish",
9
14
  "lint": "oxlint",
10
15
  "test": "vitest"
11
16
  },
@@ -20,6 +25,7 @@
20
25
  "devDependencies": {
21
26
  "@types/bun": "latest",
22
27
  "@types/xml-c14n": "^0.0.3",
28
+ "changelogen": "^0.6.1",
23
29
  "dotenv": "^16.5.0",
24
30
  "oxlint": "^0.16.6",
25
31
  "prettier": "^3.5.3",