@ripwords/myinvois-client 0.0.9 → 0.1.0
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.
- package/bun.lock +89 -132
- package/dist/0X-C4IRh_fJ.d.ts +211 -0
- package/dist/0X-C4IRh_fJ.d.ts.map +1 -0
- package/dist/0X-Yw7mZEro.d.cts +211 -0
- package/dist/0X-Yw7mZEro.d.cts.map +1 -0
- package/dist/1X-Brnls9Jh.d.ts +112 -0
- package/dist/1X-Brnls9Jh.d.ts.map +1 -0
- package/dist/1X-BwpSoT3o.d.cts +20 -0
- package/dist/1X-BwpSoT3o.d.cts.map +1 -0
- package/dist/1X-C-_KHV-Q.d.ts +20 -0
- package/dist/1X-C-_KHV-Q.d.ts.map +1 -0
- package/dist/1X-D_aUVsuM.d.cts +112 -0
- package/dist/1X-D_aUVsuM.d.cts.map +1 -0
- package/dist/2X-Bb6elyzV.d.cts +40 -0
- package/dist/2X-Bb6elyzV.d.cts.map +1 -0
- package/dist/2X-DkS1BoE5.d.ts +40 -0
- package/dist/2X-DkS1BoE5.d.ts.map +1 -0
- package/dist/2X-UdQcQW24.d.ts +140 -0
- package/dist/2X-UdQcQW24.d.ts.map +1 -0
- package/dist/2X-hClUyw26.d.cts +140 -0
- package/dist/2X-hClUyw26.d.cts.map +1 -0
- package/dist/3X-C7VFD-n-.d.cts +21 -0
- package/dist/3X-C7VFD-n-.d.cts.map +1 -0
- package/dist/3X-CLMESDvz.d.cts +62 -0
- package/dist/3X-CLMESDvz.d.cts.map +1 -0
- package/dist/3X-DFI-4RQQ.d.ts +21 -0
- package/dist/3X-DFI-4RQQ.d.ts.map +1 -0
- package/dist/3X-DVDyspgb.d.ts +62 -0
- package/dist/3X-DVDyspgb.d.ts.map +1 -0
- package/dist/4X-CIJ2JJ2w.d.ts +31 -0
- package/dist/4X-CIJ2JJ2w.d.ts.map +1 -0
- package/dist/4X-CUR8jlaZ.d.ts +265 -0
- package/dist/4X-CUR8jlaZ.d.ts.map +1 -0
- package/dist/4X-CvScPJTf.d.cts +265 -0
- package/dist/4X-CvScPJTf.d.cts.map +1 -0
- package/dist/4X-DIfvpU6V.d.cts +31 -0
- package/dist/4X-DIfvpU6V.d.cts.map +1 -0
- package/dist/5X-BOUxhadJ.d.cts +22 -0
- package/dist/5X-BOUxhadJ.d.cts.map +1 -0
- package/dist/5X-C6db432h.d.ts +77 -0
- package/dist/5X-C6db432h.d.ts.map +1 -0
- package/dist/5X-COsZHUaQ.d.ts +22 -0
- package/dist/5X-COsZHUaQ.d.ts.map +1 -0
- package/dist/5X-CkLu7Vyd.d.cts +77 -0
- package/dist/5X-CkLu7Vyd.d.cts.map +1 -0
- package/dist/6X-C_fFIcJC.d.ts +105 -0
- package/dist/6X-C_fFIcJC.d.ts.map +1 -0
- package/dist/6X-ClZDKOTC.d.ts +16 -0
- package/dist/6X-ClZDKOTC.d.ts.map +1 -0
- package/dist/6X-DE7RJeV6.d.cts +16 -0
- package/dist/6X-DE7RJeV6.d.cts.map +1 -0
- package/dist/6X-Mf32k1d0.d.cts +105 -0
- package/dist/6X-Mf32k1d0.d.cts.map +1 -0
- package/dist/7X-BZyesooz.d.ts +16 -0
- package/dist/7X-BZyesooz.d.ts.map +1 -0
- package/dist/7X-Chtd6B66.d.cts +16 -0
- package/dist/7X-Chtd6B66.d.cts.map +1 -0
- package/dist/7X-DoCUcp-J.d.cts +71 -0
- package/dist/7X-DoCUcp-J.d.cts.map +1 -0
- package/dist/7X-kot_VccM.d.ts +71 -0
- package/dist/7X-kot_VccM.d.ts.map +1 -0
- package/dist/8X-Df4DOBOe.d.ts +110 -0
- package/dist/8X-Df4DOBOe.d.ts.map +1 -0
- package/dist/8X-DkuKAkHz.d.ts +19 -0
- package/dist/8X-DkuKAkHz.d.ts.map +1 -0
- package/dist/8X-DqZyMvyV.d.cts +19 -0
- package/dist/8X-DqZyMvyV.d.cts.map +1 -0
- package/dist/8X-Dr9RunRw.d.cts +110 -0
- package/dist/8X-Dr9RunRw.d.cts.map +1 -0
- package/dist/9X-BDgifncF.d.ts +15 -0
- package/dist/9X-BDgifncF.d.ts.map +1 -0
- package/dist/9X-BaoZtjWF.d.cts +98 -0
- package/dist/9X-BaoZtjWF.d.cts.map +1 -0
- package/dist/9X-BcAb6Uso.d.cts +15 -0
- package/dist/9X-BcAb6Uso.d.cts.map +1 -0
- package/dist/9X-BhBWlgxG.d.ts +98 -0
- package/dist/9X-BhBWlgxG.d.ts.map +1 -0
- package/dist/AX-BY72FohC.d.cts +111 -0
- package/dist/AX-BY72FohC.d.cts.map +1 -0
- package/dist/AX-D6XHWdrY.d.ts +111 -0
- package/dist/AX-D6XHWdrY.d.ts.map +1 -0
- package/dist/BX-CA0OmrUZ.d.cts +115 -0
- package/dist/BX-CA0OmrUZ.d.cts.map +1 -0
- package/dist/BX-D_0C8Qbd.d.ts +115 -0
- package/dist/BX-D_0C8Qbd.d.ts.map +1 -0
- package/dist/CX-HH4cSZRX.d.ts +128 -0
- package/dist/CX-HH4cSZRX.d.ts.map +1 -0
- package/dist/CX-glpQSL8x.d.cts +128 -0
- package/dist/CX-glpQSL8x.d.cts.map +1 -0
- package/dist/DX-DimL1MDM.d.cts +115 -0
- package/dist/DX-DimL1MDM.d.cts.map +1 -0
- package/dist/DX-Dx22ax_I.d.ts +115 -0
- package/dist/DX-Dx22ax_I.d.ts.map +1 -0
- package/dist/EX-BRWh1wFc.d.ts +107 -0
- package/dist/EX-BRWh1wFc.d.ts.map +1 -0
- package/dist/EX-Cx87Ruxl.d.cts +107 -0
- package/dist/EX-Cx87Ruxl.d.cts.map +1 -0
- package/dist/FX-D81UlxNN.d.cts +127 -0
- package/dist/FX-D81UlxNN.d.cts.map +1 -0
- package/dist/FX-RmjwAr40.d.ts +127 -0
- package/dist/FX-RmjwAr40.d.ts.map +1 -0
- package/dist/GX-9i7piP9G.d.cts +136 -0
- package/dist/GX-9i7piP9G.d.cts.map +1 -0
- package/dist/GX-CJyo7oDp.d.ts +136 -0
- package/dist/GX-CJyo7oDp.d.ts.map +1 -0
- package/dist/HX-20GVJAvl.d.cts +126 -0
- package/dist/HX-20GVJAvl.d.cts.map +1 -0
- package/dist/HX-XALBTdLA.d.ts +126 -0
- package/dist/HX-XALBTdLA.d.ts.map +1 -0
- package/dist/IX-6SZ55QKb.d.ts +23 -0
- package/dist/IX-6SZ55QKb.d.ts.map +1 -0
- package/dist/IX-D54NGPsc.d.cts +23 -0
- package/dist/IX-D54NGPsc.d.cts.map +1 -0
- package/dist/JX-C1RYcwQX.d.cts +104 -0
- package/dist/JX-C1RYcwQX.d.cts.map +1 -0
- package/dist/JX-hQ1XRmLp.d.ts +104 -0
- package/dist/JX-hQ1XRmLp.d.ts.map +1 -0
- package/dist/KX-BNwunEfn.d.ts +151 -0
- package/dist/KX-BNwunEfn.d.ts.map +1 -0
- package/dist/KX-gQHCIgtQ.d.cts +151 -0
- package/dist/KX-gQHCIgtQ.d.cts.map +1 -0
- package/dist/LX-CHYX3X3J.d.ts +123 -0
- package/dist/LX-CHYX3X3J.d.ts.map +1 -0
- package/dist/LX-CPurJGIh.d.cts +123 -0
- package/dist/LX-CPurJGIh.d.cts.map +1 -0
- package/dist/MX-BPGLWSUz.d.ts +153 -0
- package/dist/MX-BPGLWSUz.d.ts.map +1 -0
- package/dist/MX-BnyW5eHf.d.cts +153 -0
- package/dist/MX-BnyW5eHf.d.cts.map +1 -0
- package/dist/MyInvoisClient-BrNyMjS-.d.cts +178 -0
- package/dist/MyInvoisClient-BrNyMjS-.d.cts.map +1 -0
- package/dist/MyInvoisClient-CXu4pdl-.d.ts +178 -0
- package/dist/MyInvoisClient-CXu4pdl-.d.ts.map +1 -0
- package/dist/MyInvoisClient-Cnvb5iUC.js +299 -0
- package/dist/MyInvoisClient-Cnvb5iUC.js.map +1 -0
- package/dist/MyInvoisClient-DO1dJfQq.cjs +304 -0
- package/dist/MyInvoisClient-DO1dJfQq.cjs.map +1 -0
- package/dist/NX-B11fQuco.d.cts +122 -0
- package/dist/NX-B11fQuco.d.cts.map +1 -0
- package/dist/NX-RulN5Ml3.d.ts +122 -0
- package/dist/NX-RulN5Ml3.d.ts.map +1 -0
- package/dist/OX-DgKVSp7I.d.ts +26 -0
- package/dist/OX-DgKVSp7I.d.ts.map +1 -0
- package/dist/OX-T-ydRXQS.d.cts +26 -0
- package/dist/OX-T-ydRXQS.d.cts.map +1 -0
- package/dist/PX-DA4A2kEv.d.ts +121 -0
- package/dist/PX-DA4A2kEv.d.ts.map +1 -0
- package/dist/PX-p0n1SzvU.d.cts +121 -0
- package/dist/PX-p0n1SzvU.d.cts.map +1 -0
- package/dist/QX-CI1NccIB.d.cts +59 -0
- package/dist/QX-CI1NccIB.d.cts.map +1 -0
- package/dist/QX-DrFqsMEs.d.ts +59 -0
- package/dist/QX-DrFqsMEs.d.ts.map +1 -0
- package/dist/RX-Cm7vFcFN.d.ts +23 -0
- package/dist/RX-Cm7vFcFN.d.ts.map +1 -0
- package/dist/RX-DnNKol22.d.cts +23 -0
- package/dist/RX-DnNKol22.d.cts.map +1 -0
- package/dist/SX-BUjiWQYz.d.cts +40 -0
- package/dist/SX-BUjiWQYz.d.cts.map +1 -0
- package/dist/SX-CsPPTu-W.d.ts +40 -0
- package/dist/SX-CsPPTu-W.d.ts.map +1 -0
- package/dist/TX-DCY25MdR.d.ts +31 -0
- package/dist/TX-DCY25MdR.d.ts.map +1 -0
- package/dist/TX-DOEpsf05.d.cts +31 -0
- package/dist/TX-DOEpsf05.d.cts.map +1 -0
- package/dist/UX-DauyagHy.d.ts +18 -0
- package/dist/UX-DauyagHy.d.ts.map +1 -0
- package/dist/UX-DgUOnTFK.d.cts +18 -0
- package/dist/UX-DgUOnTFK.d.cts.map +1 -0
- package/dist/VX-DD4scgCe.d.ts +17 -0
- package/dist/VX-DD4scgCe.d.ts.map +1 -0
- package/dist/VX-kUX6LM-3.d.cts +17 -0
- package/dist/VX-kUX6LM-3.d.cts.map +1 -0
- package/dist/WX-CjkoppdY.d.ts +26 -0
- package/dist/WX-CjkoppdY.d.ts.map +1 -0
- package/dist/WX-DPfyPFFh.d.cts +26 -0
- package/dist/WX-DPfyPFFh.d.cts.map +1 -0
- package/dist/XX-C4C1gQZH.d.cts +828 -0
- package/dist/XX-C4C1gQZH.d.cts.map +1 -0
- package/dist/XX-sbsIUOnA.d.ts +828 -0
- package/dist/XX-sbsIUOnA.d.ts.map +1 -0
- package/dist/YX-BeT-LsiA.d.cts +20 -0
- package/dist/YX-BeT-LsiA.d.cts.map +1 -0
- package/dist/YX-DUdO8mRC.d.ts +20 -0
- package/dist/YX-DUdO8mRC.d.ts.map +1 -0
- package/dist/ZX-BuVTTq-D.d.cts +22 -0
- package/dist/ZX-BuVTTq-D.d.cts.map +1 -0
- package/dist/ZX-DwfcSA-D.d.ts +22 -0
- package/dist/ZX-DwfcSA-D.d.ts.map +1 -0
- package/dist/api/platform/platformLogin.d.ts +67 -0
- package/dist/api/platform/platformLogin.d.ts.map +1 -0
- package/dist/api/platform/platformLogin.js +3 -0
- package/dist/canonicalize-C_fNNpYr.cjs +80 -0
- package/dist/canonicalize-C_fNNpYr.cjs.map +1 -0
- package/dist/canonicalize-DNUrCGad.js +68 -0
- package/dist/canonicalize-DNUrCGad.js.map +1 -0
- package/dist/chunk-CUT6urMc.cjs +30 -0
- package/dist/classification-codes-B15PbWxz.d.cts +118 -0
- package/dist/classification-codes-B15PbWxz.d.cts.map +1 -0
- package/dist/classification-codes-C2X4xW5-.d.ts +118 -0
- package/dist/classification-codes-C2X4xW5-.d.ts.map +1 -0
- package/dist/country-code-DPeNFMMi.d.cts +543 -0
- package/dist/country-code-DPeNFMMi.d.cts.map +1 -0
- package/dist/country-code-DsI8Mbzx.d.ts +543 -0
- package/dist/country-code-DsI8Mbzx.d.ts.map +1 -0
- package/dist/currencies-DKuDflOO.d.ts +208 -0
- package/dist/currencies-DKuDflOO.d.ts.map +1 -0
- package/dist/currencies-S5g1gzBU.d.cts +208 -0
- package/dist/currencies-S5g1gzBU.d.cts.map +1 -0
- package/dist/e-invoice-BuwtFnlI.d.cts +44 -0
- package/dist/e-invoice-BuwtFnlI.d.cts.map +1 -0
- package/dist/e-invoice-C2TxhyrK.d.ts +44 -0
- package/dist/e-invoice-C2TxhyrK.d.ts.map +1 -0
- package/dist/getBaseUrl-CO7Jp27d.cjs +14 -0
- package/dist/getBaseUrl-CO7Jp27d.cjs.map +1 -0
- package/dist/getBaseUrl-Dx6RDC8I.js +8 -0
- package/dist/getBaseUrl-Dx6RDC8I.js.map +1 -0
- package/dist/hashCert-Bol7lIh2.js +62 -0
- package/dist/hashCert-Bol7lIh2.js.map +1 -0
- package/dist/hashCert-mlYEuYex.cjs +68 -0
- package/dist/hashCert-mlYEuYex.cjs.map +1 -0
- package/dist/hashSignedProperties-9vj5wlYR.js +83 -0
- package/dist/hashSignedProperties-9vj5wlYR.js.map +1 -0
- package/dist/hashSignedProperties-CU_ZqqmY.cjs +95 -0
- package/dist/hashSignedProperties-CU_ZqqmY.cjs.map +1 -0
- package/dist/index-B1DSs-wd.d.cts +16 -0
- package/dist/index-B1DSs-wd.d.cts.map +1 -0
- package/dist/index-CJNLQVjx.d.ts +1 -0
- package/dist/index-FTgB2nM6.d.ts +16 -0
- package/dist/index-FTgB2nM6.d.ts.map +1 -0
- package/dist/index-Wy1ONBjV.d.cts +1 -0
- package/dist/index.cjs +13 -97
- package/dist/index.d.ts +60 -5664
- package/dist/index.js +11 -93
- package/dist/index10.cjs +34 -0
- package/dist/index10.cjs.map +1 -0
- package/dist/index11.cjs +24 -0
- package/dist/index11.cjs.map +1 -0
- package/dist/index12.cjs +0 -0
- package/dist/index13.cjs +13 -0
- package/dist/index14.cjs +13 -0
- package/dist/index14.cjs.map +1 -0
- package/dist/index15.cjs +3 -0
- package/dist/index16.cjs +17 -0
- package/dist/index17.cjs +3 -0
- package/dist/index18.cjs +208 -0
- package/dist/index18.cjs.map +1 -0
- package/dist/index19.cjs +109 -0
- package/dist/index19.cjs.map +1 -0
- package/dist/index2.cjs +62 -0
- package/dist/index2.cjs.map +1 -0
- package/dist/index20.cjs +137 -0
- package/dist/index20.cjs.map +1 -0
- package/dist/index21.cjs +64 -0
- package/dist/index21.cjs.map +1 -0
- package/dist/index22.cjs +267 -0
- package/dist/index22.cjs.map +1 -0
- package/dist/index23.cjs +79 -0
- package/dist/index23.cjs.map +1 -0
- package/dist/index24.cjs +107 -0
- package/dist/index24.cjs.map +1 -0
- package/dist/index25.cjs +73 -0
- package/dist/index25.cjs.map +1 -0
- package/dist/index26.cjs +112 -0
- package/dist/index26.cjs.map +1 -0
- package/dist/index27.cjs +100 -0
- package/dist/index27.cjs.map +1 -0
- package/dist/index28.cjs +18 -0
- package/dist/index28.cjs.map +1 -0
- package/dist/index29.cjs +38 -0
- package/dist/index29.cjs.map +1 -0
- package/dist/index3.cjs +532 -0
- package/dist/index3.cjs.map +1 -0
- package/dist/index30.cjs +19 -0
- package/dist/index30.cjs.map +1 -0
- package/dist/index31.cjs +29 -0
- package/dist/index31.cjs.map +1 -0
- package/dist/index32.cjs +20 -0
- package/dist/index32.cjs.map +1 -0
- package/dist/index33.cjs +14 -0
- package/dist/index33.cjs.map +1 -0
- package/dist/index34.cjs +14 -0
- package/dist/index34.cjs.map +1 -0
- package/dist/index35.cjs +17 -0
- package/dist/index35.cjs.map +1 -0
- package/dist/index36.cjs +13 -0
- package/dist/index36.cjs.map +1 -0
- package/dist/index37.cjs +108 -0
- package/dist/index37.cjs.map +1 -0
- package/dist/index38.cjs +113 -0
- package/dist/index38.cjs.map +1 -0
- package/dist/index39.cjs +126 -0
- package/dist/index39.cjs.map +1 -0
- package/dist/index4.cjs +196 -0
- package/dist/index4.cjs.map +1 -0
- package/dist/index40.cjs +113 -0
- package/dist/index40.cjs.map +1 -0
- package/dist/index41.cjs +105 -0
- package/dist/index41.cjs.map +1 -0
- package/dist/index42.cjs +125 -0
- package/dist/index42.cjs.map +1 -0
- package/dist/index43.cjs +134 -0
- package/dist/index43.cjs.map +1 -0
- package/dist/index44.cjs +124 -0
- package/dist/index44.cjs.map +1 -0
- package/dist/index45.cjs +21 -0
- package/dist/index45.cjs.map +1 -0
- package/dist/index46.cjs +102 -0
- package/dist/index46.cjs.map +1 -0
- package/dist/index47.cjs +149 -0
- package/dist/index47.cjs.map +1 -0
- package/dist/index48.cjs +121 -0
- package/dist/index48.cjs.map +1 -0
- package/dist/index49.cjs +151 -0
- package/dist/index49.cjs.map +1 -0
- package/dist/index5.cjs +25 -0
- package/dist/index5.cjs.map +1 -0
- package/dist/index50.cjs +120 -0
- package/dist/index50.cjs.map +1 -0
- package/dist/index51.cjs +24 -0
- package/dist/index51.cjs.map +1 -0
- package/dist/index52.cjs +119 -0
- package/dist/index52.cjs.map +1 -0
- package/dist/index53.cjs +54 -0
- package/dist/index53.cjs.map +1 -0
- package/dist/index54.cjs +21 -0
- package/dist/index54.cjs.map +1 -0
- package/dist/index55.cjs +35 -0
- package/dist/index55.cjs.map +1 -0
- package/dist/index56.cjs +29 -0
- package/dist/index56.cjs.map +1 -0
- package/dist/index57.cjs +16 -0
- package/dist/index57.cjs.map +1 -0
- package/dist/index58.cjs +15 -0
- package/dist/index58.cjs.map +1 -0
- package/dist/index59.cjs +24 -0
- package/dist/index59.cjs.map +1 -0
- package/dist/index59.cts.map +1 -0
- package/dist/index6.cjs +0 -0
- package/dist/index60.cjs +419 -0
- package/dist/index60.cjs.map +1 -0
- package/dist/index61.cjs +15 -0
- package/dist/index61.cjs.map +1 -0
- package/dist/index62.cjs +16 -0
- package/dist/index62.cjs.map +1 -0
- package/dist/index62.cts.map +1 -0
- package/dist/index63.cjs +0 -0
- package/dist/index63.cts.map +1 -0
- package/dist/index64.cjs +0 -0
- package/dist/index64.cts.map +1 -0
- package/dist/index65.cjs +122 -0
- package/dist/index65.cjs.map +1 -0
- package/dist/index65.cts.map +1 -0
- package/dist/index66.cjs +229 -0
- package/dist/index66.cjs.map +1 -0
- package/dist/index66.cts.map +1 -0
- package/dist/index67.cjs +4 -0
- package/dist/index67.cts.map +1 -0
- package/dist/index68.cjs +3 -0
- package/dist/index68.cts.map +1 -0
- package/dist/index69.cjs +4 -0
- package/dist/index69.cts.map +1 -0
- package/dist/index7.cjs +0 -0
- package/dist/index70.cjs +3 -0
- package/dist/index70.cts.map +1 -0
- package/dist/index71.cjs +3 -0
- package/dist/index71.cts.map +1 -0
- package/dist/index72.cjs +3 -0
- package/dist/index72.cts.map +1 -0
- package/dist/index73.cjs +3 -0
- package/dist/index73.cts.map +1 -0
- package/dist/index8.cjs +25 -0
- package/dist/index8.cjs.map +1 -0
- package/dist/index9.cjs +0 -0
- package/dist/invoice-1_1-BJVcw-oE.d.ts +432 -0
- package/dist/invoice-1_1-BJVcw-oE.d.ts.map +1 -0
- package/dist/invoice-1_1-DWdNPRzr.d.cts +432 -0
- package/dist/invoice-1_1-DWdNPRzr.d.cts.map +1 -0
- package/dist/invoice1-1-8S-QQn7P.cjs +547 -0
- package/dist/invoice1-1-8S-QQn7P.cjs.map +1 -0
- package/dist/invoice1-1-CHuLpkFz.js +504 -0
- package/dist/invoice1-1-CHuLpkFz.js.map +1 -0
- package/dist/msic-codes-B_1W6lZF.d.cts +26 -0
- package/dist/msic-codes-B_1W6lZF.d.cts.map +1 -0
- package/dist/msic-codes-bs0lTfSZ.d.ts +26 -0
- package/dist/msic-codes-bs0lTfSZ.d.ts.map +1 -0
- package/dist/payment-modes-B8dNy3SM.d.ts +44 -0
- package/dist/payment-modes-B8dNy3SM.d.ts.map +1 -0
- package/dist/payment-modes-DHihrywe.d.cts +44 -0
- package/dist/payment-modes-DHihrywe.d.cts.map +1 -0
- package/dist/platformLogin-DsxWWUXr.js +31 -0
- package/dist/platformLogin-DsxWWUXr.js.map +1 -0
- package/dist/platformLogin-PGzMhw1X.cjs +37 -0
- package/dist/platformLogin-PGzMhw1X.cjs.map +1 -0
- package/dist/populateFinalDocument-BdyYzz5Y.cjs +96 -0
- package/dist/populateFinalDocument-BdyYzz5Y.cjs.map +1 -0
- package/dist/populateFinalDocument-BpLXmgLv.js +90 -0
- package/dist/populateFinalDocument-BpLXmgLv.js.map +1 -0
- package/dist/populateSignedProperties-BJMcBQ6S.cjs +58 -0
- package/dist/populateSignedProperties-BJMcBQ6S.cjs.map +1 -0
- package/dist/populateSignedProperties-BvGN-YZH.js +52 -0
- package/dist/populateSignedProperties-BvGN-YZH.js.map +1 -0
- package/dist/sign-B61Cy3gO.cjs +40 -0
- package/dist/sign-B61Cy3gO.cjs.map +1 -0
- package/dist/sign-DzHK7UhR.js +34 -0
- package/dist/sign-DzHK7UhR.js.map +1 -0
- package/dist/signatures-BKi9DP2K.d.cts +173 -0
- package/dist/signatures-BKi9DP2K.d.cts.map +1 -0
- package/dist/signatures-C9QPZTQd.d.ts +173 -0
- package/dist/signatures-C9QPZTQd.d.ts.map +1 -0
- package/dist/state-codes-CxG1S9YY.d.ts +62 -0
- package/dist/state-codes-CxG1S9YY.d.ts.map +1 -0
- package/dist/state-codes-DXSWtE6a.d.cts +62 -0
- package/dist/state-codes-DXSWtE6a.d.cts.map +1 -0
- package/dist/tax-types-CEpfSh5P.d.ts +42 -0
- package/dist/tax-types-CEpfSh5P.d.ts.map +1 -0
- package/dist/tax-types-CgwxONDS.d.cts +42 -0
- package/dist/tax-types-CgwxONDS.d.cts.map +1 -0
- package/dist/transform-BLz0S687.cjs +72 -0
- package/dist/transform-BLz0S687.cjs.map +1 -0
- package/dist/transform-D1q-U6Zj.js +66 -0
- package/dist/transform-D1q-U6Zj.js.map +1 -0
- package/dist/types/classification-codes.d.ts +2 -0
- package/dist/types/country-code.d.ts +2 -0
- package/dist/types/currencies.d.ts +2 -0
- package/dist/types/documents/index.d.ts +57 -0
- package/dist/types/documents/invoice-1_1.d.ts +56 -0
- package/dist/types/e-invoice.d.ts +2 -0
- package/dist/types/index.d.ts +59 -0
- package/dist/types/msic/0X.d.ts +2 -0
- package/dist/types/msic/1X.d.ts +2 -0
- package/dist/types/msic/2X.d.ts +2 -0
- package/dist/types/msic/3X.d.ts +2 -0
- package/dist/types/msic/4X.d.ts +2 -0
- package/dist/types/msic/5X.d.ts +2 -0
- package/dist/types/msic/6X.d.ts +2 -0
- package/dist/types/msic/7X.d.ts +2 -0
- package/dist/types/msic/8X.d.ts +2 -0
- package/dist/types/msic/9X.d.ts +2 -0
- package/dist/types/msic-codes.d.ts +12 -0
- package/dist/types/payment-modes.d.ts +2 -0
- package/dist/types/signatures.d.ts +2 -0
- package/dist/types/state-codes.d.ts +2 -0
- package/dist/types/tax-types.d.ts +2 -0
- package/dist/types/unit/1X.d.ts +2 -0
- package/dist/types/unit/2X.d.ts +2 -0
- package/dist/types/unit/3X.d.ts +2 -0
- package/dist/types/unit/4X.d.ts +2 -0
- package/dist/types/unit/5X.d.ts +2 -0
- package/dist/types/unit/6X.d.ts +2 -0
- package/dist/types/unit/7X.d.ts +2 -0
- package/dist/types/unit/8X.d.ts +2 -0
- package/dist/types/unit/9X.d.ts +2 -0
- package/dist/types/unit/AX.d.ts +2 -0
- package/dist/types/unit/BX.d.ts +2 -0
- package/dist/types/unit/CX.d.ts +2 -0
- package/dist/types/unit/DX.d.ts +2 -0
- package/dist/types/unit/EX.d.ts +2 -0
- package/dist/types/unit/FX.d.ts +2 -0
- package/dist/types/unit/GX.d.ts +2 -0
- package/dist/types/unit/HX.d.ts +2 -0
- package/dist/types/unit/IX.d.ts +2 -0
- package/dist/types/unit/JX.d.ts +2 -0
- package/dist/types/unit/KX.d.ts +2 -0
- package/dist/types/unit/LX.d.ts +2 -0
- package/dist/types/unit/MX.d.ts +2 -0
- package/dist/types/unit/NX.d.ts +2 -0
- package/dist/types/unit/OX.d.ts +2 -0
- package/dist/types/unit/PX.d.ts +2 -0
- package/dist/types/unit/QX.d.ts +2 -0
- package/dist/types/unit/RX.d.ts +2 -0
- package/dist/types/unit/SX.d.ts +2 -0
- package/dist/types/unit/TX.d.ts +2 -0
- package/dist/types/unit/UX.d.ts +2 -0
- package/dist/types/unit/VX.d.ts +2 -0
- package/dist/types/unit/WX.d.ts +2 -0
- package/dist/types/unit/XX.d.ts +2 -0
- package/dist/types/unit/YX.d.ts +2 -0
- package/dist/types/unit/ZX.d.ts +2 -0
- package/dist/types/unit-types.d.ts +37 -0
- package/dist/unit-types-1bF0KhIp.d.ts +56 -0
- package/dist/unit-types-1bF0KhIp.d.ts.map +1 -0
- package/dist/unit-types-CsrkvgfG.d.cts +56 -0
- package/dist/unit-types-CsrkvgfG.d.cts.map +1 -0
- package/dist/utils/MyInvoisClient.d.ts +60 -0
- package/dist/utils/MyInvoisClient.js +13 -0
- package/dist/utils/base64.d.ts +6 -0
- package/dist/utils/base64.d.ts.map +1 -0
- package/dist/utils/base64.js +11 -0
- package/dist/utils/base64.js.map +1 -0
- package/dist/utils/debug/debug-document-hash.d.ts +100 -0
- package/dist/utils/debug/debug-document-hash.d.ts.map +1 -0
- package/dist/utils/debug/debug-document-hash.js +120 -0
- package/dist/utils/debug/debug-document-hash.js.map +1 -0
- package/dist/utils/debug/debug-invoice-submission.d.ts +152 -0
- package/dist/utils/debug/debug-invoice-submission.d.ts.map +1 -0
- package/dist/utils/debug/debug-invoice-submission.js +226 -0
- package/dist/utils/debug/debug-invoice-submission.js.map +1 -0
- package/dist/utils/getBaseUrl.d.ts +5 -0
- package/dist/utils/getBaseUrl.d.ts.map +1 -0
- package/dist/utils/getBaseUrl.js +3 -0
- package/dist/utils/invoice1-1.d.ts +117 -0
- package/dist/utils/invoice1-1.d.ts.map +1 -0
- package/dist/utils/invoice1-1.js +10 -0
- package/dist/utils/signature/canonicalize.d.ts +26 -0
- package/dist/utils/signature/canonicalize.d.ts.map +1 -0
- package/dist/utils/signature/canonicalize.js +3 -0
- package/dist/utils/signature/hashCert.d.ts +15 -0
- package/dist/utils/signature/hashCert.d.ts.map +1 -0
- package/dist/utils/signature/hashCert.js +3 -0
- package/dist/utils/signature/hashSignedProperties.d.ts +25 -0
- package/dist/utils/signature/hashSignedProperties.d.ts.map +1 -0
- package/dist/utils/signature/hashSignedProperties.js +3 -0
- package/dist/utils/signature/populateFinalDocument.d.ts +23 -0
- package/dist/utils/signature/populateFinalDocument.d.ts.map +1 -0
- package/dist/utils/signature/populateFinalDocument.js +3 -0
- package/dist/utils/signature/populateSignedProperties.d.ts +23 -0
- package/dist/utils/signature/populateSignedProperties.d.ts.map +1 -0
- package/dist/utils/signature/populateSignedProperties.js +3 -0
- package/dist/utils/signature/sign.d.ts +16 -0
- package/dist/utils/signature/sign.d.ts.map +1 -0
- package/dist/utils/signature/sign.js +3 -0
- package/dist/utils/signature/transform.d.ts +16 -0
- package/dist/utils/signature/transform.d.ts.map +1 -0
- package/dist/utils/signature/transform.js +3 -0
- package/package.json +12 -5
- package/src/api/platform/{taxpayerLogin.ts → platformLogin.ts} +8 -2
- package/src/types/documents/invoice-1_1.d.ts +90 -0
- package/src/types/index.d.ts +1 -0
- package/src/types/msic-codes.d.ts +1 -7
- package/src/utils/MyInvoisClient.ts +428 -11
- package/src/utils/base64.ts +7 -0
- package/src/utils/debug/debug-document-hash.ts +249 -0
- package/src/utils/debug/debug-invoice-submission.ts +355 -0
- package/src/utils/getBaseUrl.ts +1 -1
- package/src/utils/invoice1-1.ts +671 -0
- package/src/utils/signature/canonicalize.ts +104 -0
- package/src/utils/signature/hashCert.ts +115 -0
- package/src/utils/signature/hashSignedProperties.ts +155 -0
- package/src/utils/signature/populateFinalDocument.ts +187 -0
- package/src/utils/signature/populateSignedProperties.ts +87 -0
- package/src/utils/signature/sign.ts +51 -0
- package/src/utils/signature/transform.ts +99 -0
- package/test/MyInvoiClientWithRealData.test.ts +2 -1
- package/test/MyInvoisClient.test.ts +16 -8
- package/test/base64.test.ts +43 -0
- package/test/canonicalize.test.ts +110 -0
- package/test/hashCert.test.ts +95 -0
- package/test/hashSignedProperties.test.ts +140 -0
- package/test/populateFinalDocument.test.ts +218 -0
- package/test/populateSignedProperties.test.ts +155 -0
- package/test/sign.test.ts +70 -0
- package/test/signAndSubmitInvoice.test.ts +915 -0
- package/test/transform.test.ts +158 -0
- package/tsconfig.json +7 -1
- package/tsdown.config.ts +31 -0
- package/dist/index.cjs.map +0 -1
- package/rolldown.config.ts +0 -26
|
@@ -0,0 +1,249 @@
|
|
|
1
|
+
import * as crypto from 'crypto'
|
|
2
|
+
import { DOMParserImpl } from 'xmldom-ts'
|
|
3
|
+
import type { InvoiceV1_1 } from '../../types'
|
|
4
|
+
import { generateDocumentHash, generateSignedInvoiceXML } from '../invoice1-1'
|
|
5
|
+
import type { SigningCredentials } from '../../types/documents/invoice-1_1.d.ts'
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Debug Document Hash Issues
|
|
9
|
+
*
|
|
10
|
+
* This helps identify why MyInvois is rejecting the document hash
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Compare different hash calculation methods to identify the correct approach
|
|
15
|
+
*/
|
|
16
|
+
export async function debugDocumentHash(
|
|
17
|
+
invoiceData: InvoiceV1_1,
|
|
18
|
+
signingCredentials: SigningCredentials,
|
|
19
|
+
): Promise<{
|
|
20
|
+
signedXML: string
|
|
21
|
+
documentHashes: {
|
|
22
|
+
submissionHash: string // The hash sent in submission payload
|
|
23
|
+
signatureDocDigest: string // The digest value inside the signature
|
|
24
|
+
rawDocumentHash: string // Hash of raw signed XML
|
|
25
|
+
minifiedDocumentHash: string // Hash of minified signed XML
|
|
26
|
+
transformedDocumentHash: string // Hash of transformed document (used in signature)
|
|
27
|
+
}
|
|
28
|
+
areEqual: {
|
|
29
|
+
submissionVsSignature: boolean
|
|
30
|
+
submissionVsRaw: boolean
|
|
31
|
+
submissionVsMinified: boolean
|
|
32
|
+
submissionVsTransformed: boolean
|
|
33
|
+
}
|
|
34
|
+
recommendations: string[]
|
|
35
|
+
}> {
|
|
36
|
+
console.log('\n🔍 DEBUGGING DOCUMENT HASH VALIDATION')
|
|
37
|
+
console.log('=====================================')
|
|
38
|
+
|
|
39
|
+
// Generate the signed XML
|
|
40
|
+
const signedXML = await generateSignedInvoiceXML(
|
|
41
|
+
invoiceData,
|
|
42
|
+
signingCredentials,
|
|
43
|
+
)
|
|
44
|
+
|
|
45
|
+
console.log(`\n📄 Generated signed XML (${signedXML.length} chars)`)
|
|
46
|
+
console.log('First 200 chars:', signedXML.substring(0, 200) + '...')
|
|
47
|
+
|
|
48
|
+
// 1. Calculate the hash used in submission payload (current implementation)
|
|
49
|
+
const submissionHash = generateDocumentHash(signedXML)
|
|
50
|
+
console.log(`\n📊 SUBMISSION HASH: ${submissionHash}`)
|
|
51
|
+
|
|
52
|
+
// 2. Extract the digest value from the signature itself
|
|
53
|
+
const parser = new DOMParserImpl()
|
|
54
|
+
const doc = parser.parseFromString(signedXML, 'application/xml')
|
|
55
|
+
const digestElements = doc.getElementsByTagName('ds:DigestValue')
|
|
56
|
+
let signatureDocDigest = ''
|
|
57
|
+
|
|
58
|
+
if (digestElements.length > 0) {
|
|
59
|
+
// First DigestValue should be the document digest
|
|
60
|
+
signatureDocDigest = digestElements[0]?.textContent || ''
|
|
61
|
+
console.log(`📊 SIGNATURE DOC DIGEST: ${signatureDocDigest}`)
|
|
62
|
+
} else {
|
|
63
|
+
console.error('❌ No DigestValue elements found in signature!')
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// 3. Calculate hash of raw signed XML (what we're currently sending)
|
|
67
|
+
const rawDocumentHash = crypto
|
|
68
|
+
.createHash('sha256')
|
|
69
|
+
.update(signedXML, 'utf8')
|
|
70
|
+
.digest('hex')
|
|
71
|
+
console.log(`📊 RAW DOCUMENT HASH: ${rawDocumentHash}`)
|
|
72
|
+
|
|
73
|
+
// 4. Calculate hash of minified XML (MyInvois recommendation)
|
|
74
|
+
const minifiedXML = signedXML
|
|
75
|
+
.replace(/>\s+</g, '><')
|
|
76
|
+
.replace(/\s+/g, ' ')
|
|
77
|
+
.replace(/>\s/g, '>')
|
|
78
|
+
.replace(/\s</g, '<')
|
|
79
|
+
.trim()
|
|
80
|
+
const minifiedDocumentHash = crypto
|
|
81
|
+
.createHash('sha256')
|
|
82
|
+
.update(minifiedXML, 'utf8')
|
|
83
|
+
.digest('hex')
|
|
84
|
+
console.log(`📊 MINIFIED DOCUMENT HASH: ${minifiedDocumentHash}`)
|
|
85
|
+
|
|
86
|
+
// 5. Calculate hash of the document as it was transformed for signature creation
|
|
87
|
+
// Note: We can't easily recreate the exact transformation without the template,
|
|
88
|
+
// so we'll skip this comparison for now
|
|
89
|
+
console.log(
|
|
90
|
+
`📊 TRANSFORMED DOCUMENT HASH: [Skipped - requires internal template access]`,
|
|
91
|
+
)
|
|
92
|
+
|
|
93
|
+
// Compare available hashes
|
|
94
|
+
const areEqual = {
|
|
95
|
+
submissionVsSignature:
|
|
96
|
+
submissionHash ===
|
|
97
|
+
Buffer.from(signatureDocDigest, 'base64').toString('hex'),
|
|
98
|
+
submissionVsRaw: submissionHash === rawDocumentHash,
|
|
99
|
+
submissionVsMinified: submissionHash === minifiedDocumentHash,
|
|
100
|
+
submissionVsTransformed: false, // Skip this comparison
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
console.log('\n🔍 HASH COMPARISONS:')
|
|
104
|
+
console.log(
|
|
105
|
+
`Submission vs Signature: ${areEqual.submissionVsSignature ? '✅' : '❌'}`,
|
|
106
|
+
)
|
|
107
|
+
console.log(
|
|
108
|
+
`Submission vs Raw: ${areEqual.submissionVsRaw ? '✅' : '❌'}`,
|
|
109
|
+
)
|
|
110
|
+
console.log(
|
|
111
|
+
`Submission vs Minified: ${areEqual.submissionVsMinified ? '✅' : '❌'}`,
|
|
112
|
+
)
|
|
113
|
+
console.log(
|
|
114
|
+
`Submission vs Transformed: ${areEqual.submissionVsTransformed ? '✅' : '❌'}`,
|
|
115
|
+
)
|
|
116
|
+
|
|
117
|
+
// Generate recommendations
|
|
118
|
+
const recommendations: string[] = []
|
|
119
|
+
|
|
120
|
+
if (!areEqual.submissionVsSignature) {
|
|
121
|
+
recommendations.push(
|
|
122
|
+
'❌ Submission hash does not match signature digest - this is likely the root cause!',
|
|
123
|
+
)
|
|
124
|
+
recommendations.push(
|
|
125
|
+
'💡 Consider using the same hash calculation method for both signature and submission',
|
|
126
|
+
)
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
if (!areEqual.submissionVsRaw) {
|
|
130
|
+
recommendations.push(
|
|
131
|
+
'⚠️ Current implementation calculates different hashes for signature vs submission',
|
|
132
|
+
)
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
if (areEqual.submissionVsMinified && !areEqual.submissionVsRaw) {
|
|
136
|
+
recommendations.push('💡 Try using minified XML hash for submission')
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
if (areEqual.submissionVsTransformed) {
|
|
140
|
+
recommendations.push(
|
|
141
|
+
'💡 The transformed document hash matches - this might be what MyInvois expects',
|
|
142
|
+
)
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
// Check if we're using the wrong document for submission hash
|
|
146
|
+
if (!areEqual.submissionVsSignature) {
|
|
147
|
+
recommendations.push(
|
|
148
|
+
'🔧 POTENTIAL FIX: Use the digest value from signature as documentHash in submission',
|
|
149
|
+
)
|
|
150
|
+
recommendations.push(
|
|
151
|
+
'🔧 ALTERNATIVE: Ensure submission hash uses same canonicalization as signature creation',
|
|
152
|
+
)
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
console.log('\n💡 RECOMMENDATIONS:')
|
|
156
|
+
recommendations.forEach(rec => console.log(` ${rec}`))
|
|
157
|
+
|
|
158
|
+
return {
|
|
159
|
+
signedXML,
|
|
160
|
+
documentHashes: {
|
|
161
|
+
submissionHash,
|
|
162
|
+
signatureDocDigest,
|
|
163
|
+
rawDocumentHash,
|
|
164
|
+
minifiedDocumentHash,
|
|
165
|
+
transformedDocumentHash: '',
|
|
166
|
+
},
|
|
167
|
+
areEqual,
|
|
168
|
+
recommendations,
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* Test different approaches to calculate the submission hash
|
|
174
|
+
*/
|
|
175
|
+
export async function testSubmissionHashMethods(
|
|
176
|
+
invoiceData: InvoiceV1_1,
|
|
177
|
+
signingCredentials: SigningCredentials,
|
|
178
|
+
): Promise<{
|
|
179
|
+
methods: {
|
|
180
|
+
current: string // Current implementation
|
|
181
|
+
signatureDigest: string // Use digest from signature
|
|
182
|
+
canonicalized: string // Use same canonicalization as signature
|
|
183
|
+
transformed: string // Use transformed document
|
|
184
|
+
}
|
|
185
|
+
recommendations: string[]
|
|
186
|
+
}> {
|
|
187
|
+
console.log('\n🧪 TESTING SUBMISSION HASH METHODS')
|
|
188
|
+
console.log('==================================')
|
|
189
|
+
|
|
190
|
+
// Generate signed XML
|
|
191
|
+
const signedXML = await generateSignedInvoiceXML(
|
|
192
|
+
invoiceData,
|
|
193
|
+
signingCredentials,
|
|
194
|
+
)
|
|
195
|
+
|
|
196
|
+
// Method 1: Current implementation (direct SHA256 of signed XML)
|
|
197
|
+
const currentHash = generateDocumentHash(signedXML)
|
|
198
|
+
console.log(`Method 1 - Current: ${currentHash}`)
|
|
199
|
+
|
|
200
|
+
// Method 2: Extract digest from signature
|
|
201
|
+
const parser = new DOMParserImpl()
|
|
202
|
+
const doc = parser.parseFromString(signedXML, 'application/xml')
|
|
203
|
+
const digestElements = doc.getElementsByTagName('ds:DigestValue')
|
|
204
|
+
const signatureDigest = digestElements[0]?.textContent || ''
|
|
205
|
+
const signatureDigestHex = Buffer.from(signatureDigest, 'base64').toString(
|
|
206
|
+
'hex',
|
|
207
|
+
)
|
|
208
|
+
console.log(`Method 2 - Signature Digest: ${signatureDigestHex}`)
|
|
209
|
+
|
|
210
|
+
// Method 3: Use same canonicalization as signature creation
|
|
211
|
+
// Note: Skip this method as it requires internal template access
|
|
212
|
+
console.log(`Method 3 - Canonicalized: [Skipped - requires internal access]`)
|
|
213
|
+
|
|
214
|
+
// Method 4: Hash the transformed document directly
|
|
215
|
+
// Note: Skip this method as it requires internal template access
|
|
216
|
+
console.log(`Method 4 - Transformed: [Skipped - requires internal access]`)
|
|
217
|
+
|
|
218
|
+
const methods = {
|
|
219
|
+
current: currentHash,
|
|
220
|
+
signatureDigest: signatureDigestHex,
|
|
221
|
+
canonicalized: '', // Skipped
|
|
222
|
+
transformed: '', // Skipped
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
const recommendations: string[] = []
|
|
226
|
+
|
|
227
|
+
if (methods.current !== methods.signatureDigest) {
|
|
228
|
+
recommendations.push(
|
|
229
|
+
'🔧 PRIMARY RECOMMENDATION: Use signature digest as submission hash',
|
|
230
|
+
)
|
|
231
|
+
recommendations.push(
|
|
232
|
+
' Update generateDocumentHash() to extract digest from signed XML',
|
|
233
|
+
)
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
if (methods.current !== methods.canonicalized) {
|
|
237
|
+
recommendations.push(
|
|
238
|
+
'🔧 ALTERNATIVE: Use canonicalized document hash for submission',
|
|
239
|
+
)
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
console.log('\n💡 RECOMMENDATIONS:')
|
|
243
|
+
recommendations.forEach(rec => console.log(` ${rec}`))
|
|
244
|
+
|
|
245
|
+
return {
|
|
246
|
+
methods,
|
|
247
|
+
recommendations,
|
|
248
|
+
}
|
|
249
|
+
}
|
|
@@ -0,0 +1,355 @@
|
|
|
1
|
+
import { DOMParserImpl } from 'xmldom-ts'
|
|
2
|
+
import {
|
|
3
|
+
extractCertificateInfo,
|
|
4
|
+
generateSignedInvoiceXML,
|
|
5
|
+
generateUBLXMLTemplate,
|
|
6
|
+
validateKeyPair,
|
|
7
|
+
} from '../invoice1-1'
|
|
8
|
+
import type {
|
|
9
|
+
InvoiceV1_1,
|
|
10
|
+
SigningCredentials,
|
|
11
|
+
} from '../../types/documents/invoice-1_1.d.ts'
|
|
12
|
+
import { transformXmlInvoice } from '../signature/transform'
|
|
13
|
+
import {
|
|
14
|
+
canonicalizeAndHashDocument,
|
|
15
|
+
canonicalizeAndHashDocumentWithC14N11Fallback,
|
|
16
|
+
} from '../signature/canonicalize'
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Tests both canonicalization algorithms and compares their output
|
|
20
|
+
* This can help determine if the algorithm difference affects signature validation
|
|
21
|
+
* @param xmlDocument - The XML document string to test
|
|
22
|
+
* @returns Object with canonicalization results and comparison
|
|
23
|
+
*/
|
|
24
|
+
export const testCanonicalizationAlgorithms = async (
|
|
25
|
+
xmlDocument: string,
|
|
26
|
+
): Promise<{
|
|
27
|
+
exclusiveC14N: { success: boolean; digest?: string; error?: string }
|
|
28
|
+
c14n11Fallback: { success: boolean; digest?: string; error?: string }
|
|
29
|
+
areEqual: boolean
|
|
30
|
+
}> => {
|
|
31
|
+
const parser = new DOMParserImpl()
|
|
32
|
+
const doc = parser.parseFromString(xmlDocument, 'application/xml')
|
|
33
|
+
|
|
34
|
+
const results = {
|
|
35
|
+
exclusiveC14N: { success: false } as any,
|
|
36
|
+
c14n11Fallback: { success: false } as any,
|
|
37
|
+
areEqual: false,
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
// Test Exclusive C14N
|
|
41
|
+
try {
|
|
42
|
+
const exclusiveDigest = await canonicalizeAndHashDocument(
|
|
43
|
+
doc,
|
|
44
|
+
'http://www.w3.org/2001/10/xml-exc-c14n#',
|
|
45
|
+
)
|
|
46
|
+
results.exclusiveC14N = { success: true, digest: exclusiveDigest }
|
|
47
|
+
} catch (error: any) {
|
|
48
|
+
results.exclusiveC14N = { success: false, error: error.message }
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
// Test C14N 1.1 fallback
|
|
52
|
+
try {
|
|
53
|
+
const c14n11Digest =
|
|
54
|
+
await canonicalizeAndHashDocumentWithC14N11Fallback(doc)
|
|
55
|
+
results.c14n11Fallback = { success: true, digest: c14n11Digest }
|
|
56
|
+
} catch (error: any) {
|
|
57
|
+
results.c14n11Fallback = { success: false, error: error.message }
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
// Compare results
|
|
61
|
+
if (results.exclusiveC14N.success && results.c14n11Fallback.success) {
|
|
62
|
+
results.areEqual =
|
|
63
|
+
results.exclusiveC14N.digest === results.c14n11Fallback.digest
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
return results
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* Simple validation function that checks basic XML structure requirements
|
|
71
|
+
*/
|
|
72
|
+
export function validateXMLStructure(xmlString: string): {
|
|
73
|
+
isValid: boolean
|
|
74
|
+
errors: string[]
|
|
75
|
+
warnings: string[]
|
|
76
|
+
} {
|
|
77
|
+
const errors: string[] = []
|
|
78
|
+
const warnings: string[] = []
|
|
79
|
+
|
|
80
|
+
try {
|
|
81
|
+
const parser = new DOMParserImpl()
|
|
82
|
+
const doc = parser.parseFromString(xmlString, 'application/xml')
|
|
83
|
+
|
|
84
|
+
// Check for parser errors
|
|
85
|
+
const parserErrors = doc.getElementsByTagName('parsererror')
|
|
86
|
+
if (parserErrors.length > 0) {
|
|
87
|
+
errors.push('XML parsing failed')
|
|
88
|
+
return { isValid: false, errors, warnings }
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
// Check required elements
|
|
92
|
+
const requiredElements = [
|
|
93
|
+
'Invoice',
|
|
94
|
+
'UBLExtensions',
|
|
95
|
+
'cbc:ID',
|
|
96
|
+
'cbc:IssueDate',
|
|
97
|
+
'cbc:IssueTime',
|
|
98
|
+
'cbc:InvoiceTypeCode',
|
|
99
|
+
'ds:Signature',
|
|
100
|
+
'ds:SignatureValue',
|
|
101
|
+
'ds:X509Certificate',
|
|
102
|
+
]
|
|
103
|
+
|
|
104
|
+
for (const element of requiredElements) {
|
|
105
|
+
const elements = element.includes(':')
|
|
106
|
+
? doc.getElementsByTagName(element)
|
|
107
|
+
: doc.getElementsByTagName(element)
|
|
108
|
+
|
|
109
|
+
if (elements.length === 0) {
|
|
110
|
+
errors.push(`Missing required element: ${element}`)
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
// Check namespace declarations
|
|
115
|
+
const expectedNamespaces = [
|
|
116
|
+
'urn:oasis:names:specification:ubl:schema:xsd:Invoice-2',
|
|
117
|
+
'urn:oasis:names:specification:ubl:schema:xsd:CommonAggregateComponents-2',
|
|
118
|
+
'urn:oasis:names:specification:ubl:schema:xsd:CommonBasicComponents-2',
|
|
119
|
+
]
|
|
120
|
+
|
|
121
|
+
for (const ns of expectedNamespaces) {
|
|
122
|
+
if (!xmlString.includes(ns)) {
|
|
123
|
+
warnings.push(`Missing namespace declaration: ${ns}`)
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
} catch (error: any) {
|
|
127
|
+
errors.push(`XML validation error: ${error.message}`)
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
return {
|
|
131
|
+
isValid: errors.length === 0,
|
|
132
|
+
errors,
|
|
133
|
+
warnings,
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* Comprehensive debugging function to help identify issues with generated XML
|
|
139
|
+
* This validates the structure against MyInvois requirements and provides detailed feedback
|
|
140
|
+
*/
|
|
141
|
+
export async function debugSignedInvoiceXML(
|
|
142
|
+
invoiceInfo: InvoiceV1_1,
|
|
143
|
+
signingCredentials: SigningCredentials,
|
|
144
|
+
): Promise<{
|
|
145
|
+
success: boolean
|
|
146
|
+
signedXML?: string
|
|
147
|
+
validationResults: {
|
|
148
|
+
xmlStructure: { valid: boolean; errors: string[] }
|
|
149
|
+
signatureElements: { valid: boolean; errors: string[] }
|
|
150
|
+
digestValues: { valid: boolean; errors: string[] }
|
|
151
|
+
certificateInfo: { valid: boolean; errors: string[] }
|
|
152
|
+
canonicalizationTest: any
|
|
153
|
+
}
|
|
154
|
+
stepByStepResults: {
|
|
155
|
+
step1_template: { success: boolean; error?: string }
|
|
156
|
+
step2_transform: { success: boolean; error?: string }
|
|
157
|
+
step3_docDigest: { success: boolean; digest?: string; error?: string }
|
|
158
|
+
step4_signature: { success: boolean; signature?: string; error?: string }
|
|
159
|
+
step5_certDigest: { success: boolean; digest?: string; error?: string }
|
|
160
|
+
step6_signedProps: { success: boolean; error?: string }
|
|
161
|
+
step7_propsDigest: { success: boolean; digest?: string; error?: string }
|
|
162
|
+
step8_finalDoc: { success: boolean; error?: string }
|
|
163
|
+
}
|
|
164
|
+
}> {
|
|
165
|
+
const stepResults = {
|
|
166
|
+
step1_template: { success: false } as any,
|
|
167
|
+
step2_transform: { success: false } as any,
|
|
168
|
+
step3_docDigest: { success: false } as any,
|
|
169
|
+
step4_signature: { success: false } as any,
|
|
170
|
+
step5_certDigest: { success: false } as any,
|
|
171
|
+
step6_signedProps: { success: false } as any,
|
|
172
|
+
step7_propsDigest: { success: false } as any,
|
|
173
|
+
step8_finalDoc: { success: false } as any,
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
const validationResults = {
|
|
177
|
+
xmlStructure: { valid: false, errors: [] as string[] },
|
|
178
|
+
signatureElements: { valid: false, errors: [] as string[] },
|
|
179
|
+
digestValues: { valid: false, errors: [] as string[] },
|
|
180
|
+
certificateInfo: { valid: false, errors: [] as string[] },
|
|
181
|
+
canonicalizationTest: null as any,
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
let signedXML: string | undefined
|
|
185
|
+
|
|
186
|
+
try {
|
|
187
|
+
// Step 1: Generate template
|
|
188
|
+
try {
|
|
189
|
+
const xmlTemplate = generateUBLXMLTemplate(invoiceInfo)
|
|
190
|
+
stepResults.step1_template = { success: true }
|
|
191
|
+
|
|
192
|
+
// Validate XML structure
|
|
193
|
+
const parser = new DOMParserImpl()
|
|
194
|
+
const doc = parser.parseFromString(xmlTemplate, 'application/xml')
|
|
195
|
+
const parserErrors = doc.getElementsByTagName('parsererror')
|
|
196
|
+
if (parserErrors.length > 0) {
|
|
197
|
+
validationResults.xmlStructure.errors.push(
|
|
198
|
+
'XML template parsing failed',
|
|
199
|
+
)
|
|
200
|
+
} else {
|
|
201
|
+
validationResults.xmlStructure.valid = true
|
|
202
|
+
}
|
|
203
|
+
} catch (error: any) {
|
|
204
|
+
stepResults.step1_template = { success: false, error: error.message }
|
|
205
|
+
validationResults.xmlStructure.errors.push(
|
|
206
|
+
`Template generation failed: ${error.message}`,
|
|
207
|
+
)
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
// Step 2: Transform
|
|
211
|
+
try {
|
|
212
|
+
const xmlTemplate = generateUBLXMLTemplate(invoiceInfo)
|
|
213
|
+
const transformedXml = transformXmlInvoice(xmlTemplate)
|
|
214
|
+
stepResults.step2_transform = { success: true }
|
|
215
|
+
|
|
216
|
+
// Check if transformation worked correctly
|
|
217
|
+
if (transformedXml.includes('UBLExtensions')) {
|
|
218
|
+
validationResults.xmlStructure.errors.push(
|
|
219
|
+
'UBLExtensions not properly removed in transformation',
|
|
220
|
+
)
|
|
221
|
+
}
|
|
222
|
+
if (transformedXml.includes('<cac:Signature>')) {
|
|
223
|
+
validationResults.xmlStructure.errors.push(
|
|
224
|
+
'cac:Signature elements not properly removed in transformation',
|
|
225
|
+
)
|
|
226
|
+
}
|
|
227
|
+
} catch (error: any) {
|
|
228
|
+
stepResults.step2_transform = { success: false, error: error.message }
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
// Test canonicalization
|
|
232
|
+
try {
|
|
233
|
+
const xmlTemplate = generateUBLXMLTemplate(invoiceInfo)
|
|
234
|
+
validationResults.canonicalizationTest =
|
|
235
|
+
await testCanonicalizationAlgorithms(xmlTemplate)
|
|
236
|
+
} catch (error: any) {
|
|
237
|
+
validationResults.canonicalizationTest = { error: error.message }
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
// Continue with full signing process
|
|
241
|
+
try {
|
|
242
|
+
signedXML = await generateSignedInvoiceXML(
|
|
243
|
+
invoiceInfo,
|
|
244
|
+
signingCredentials,
|
|
245
|
+
)
|
|
246
|
+
|
|
247
|
+
// Parse the final signed XML for validation
|
|
248
|
+
const parser = new DOMParserImpl()
|
|
249
|
+
const finalDoc = parser.parseFromString(signedXML, 'application/xml')
|
|
250
|
+
|
|
251
|
+
// Check signature elements are populated
|
|
252
|
+
const signatureValue =
|
|
253
|
+
finalDoc.getElementsByTagName('ds:SignatureValue')[0]
|
|
254
|
+
const x509Certificate =
|
|
255
|
+
finalDoc.getElementsByTagName('ds:X509Certificate')[0]
|
|
256
|
+
const digestValues = finalDoc.getElementsByTagName('ds:DigestValue')
|
|
257
|
+
|
|
258
|
+
if (!signatureValue || !signatureValue.textContent?.trim()) {
|
|
259
|
+
validationResults.signatureElements.errors.push(
|
|
260
|
+
'SignatureValue is empty',
|
|
261
|
+
)
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
if (!x509Certificate || !x509Certificate.textContent?.trim()) {
|
|
265
|
+
validationResults.signatureElements.errors.push(
|
|
266
|
+
'X509Certificate is empty',
|
|
267
|
+
)
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
if (digestValues.length < 2) {
|
|
271
|
+
validationResults.digestValues.errors.push(
|
|
272
|
+
'Missing digest values (expected at least 2)',
|
|
273
|
+
)
|
|
274
|
+
} else {
|
|
275
|
+
let emptyDigests = 0
|
|
276
|
+
for (let i = 0; i < digestValues.length; i++) {
|
|
277
|
+
const digestElement = digestValues[i]
|
|
278
|
+
if (!digestElement || !digestElement.textContent?.trim()) {
|
|
279
|
+
emptyDigests++
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
if (emptyDigests > 0) {
|
|
283
|
+
validationResults.digestValues.errors.push(
|
|
284
|
+
`${emptyDigests} digest values are empty`,
|
|
285
|
+
)
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
// Validate certificate info
|
|
290
|
+
try {
|
|
291
|
+
const certInfo = extractCertificateInfo(
|
|
292
|
+
signingCredentials.certificatePem,
|
|
293
|
+
)
|
|
294
|
+
const keyPairValid = validateKeyPair(
|
|
295
|
+
signingCredentials.certificatePem,
|
|
296
|
+
signingCredentials.privateKeyPem,
|
|
297
|
+
)
|
|
298
|
+
|
|
299
|
+
if (!keyPairValid) {
|
|
300
|
+
validationResults.certificateInfo.errors.push(
|
|
301
|
+
'Certificate and private key do not match',
|
|
302
|
+
)
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
if (!certInfo.issuerName || !certInfo.serialNumber) {
|
|
306
|
+
validationResults.certificateInfo.errors.push(
|
|
307
|
+
'Certificate info extraction failed',
|
|
308
|
+
)
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
if (validationResults.certificateInfo.errors.length === 0) {
|
|
312
|
+
validationResults.certificateInfo.valid = true
|
|
313
|
+
}
|
|
314
|
+
} catch (error: any) {
|
|
315
|
+
validationResults.certificateInfo.errors.push(
|
|
316
|
+
`Certificate validation failed: ${error.message}`,
|
|
317
|
+
)
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
// Set validation flags
|
|
321
|
+
if (validationResults.signatureElements.errors.length === 0) {
|
|
322
|
+
validationResults.signatureElements.valid = true
|
|
323
|
+
}
|
|
324
|
+
if (validationResults.digestValues.errors.length === 0) {
|
|
325
|
+
validationResults.digestValues.valid = true
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
// Mark individual steps as successful if we got here
|
|
329
|
+
stepResults.step3_docDigest = { success: true }
|
|
330
|
+
stepResults.step4_signature = { success: true }
|
|
331
|
+
stepResults.step5_certDigest = { success: true }
|
|
332
|
+
stepResults.step6_signedProps = { success: true }
|
|
333
|
+
stepResults.step7_propsDigest = { success: true }
|
|
334
|
+
stepResults.step8_finalDoc = { success: true }
|
|
335
|
+
} catch (error: any) {
|
|
336
|
+
console.error('Error during signing process:', error)
|
|
337
|
+
stepResults.step8_finalDoc = { success: false, error: error.message }
|
|
338
|
+
}
|
|
339
|
+
} catch (error: any) {
|
|
340
|
+
console.error('Fatal error in debugging:', error)
|
|
341
|
+
}
|
|
342
|
+
|
|
343
|
+
const allValid =
|
|
344
|
+
validationResults.xmlStructure.valid &&
|
|
345
|
+
validationResults.signatureElements.valid &&
|
|
346
|
+
validationResults.digestValues.valid &&
|
|
347
|
+
validationResults.certificateInfo.valid
|
|
348
|
+
|
|
349
|
+
return {
|
|
350
|
+
success: allValid,
|
|
351
|
+
signedXML,
|
|
352
|
+
validationResults,
|
|
353
|
+
stepByStepResults: stepResults,
|
|
354
|
+
}
|
|
355
|
+
}
|
package/src/utils/getBaseUrl.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export const getBaseUrl = (environment: 'sandbox' | 'production') => {
|
|
1
|
+
export const getBaseUrl = (environment: 'sandbox' | 'production'): string => {
|
|
2
2
|
return environment === 'sandbox'
|
|
3
3
|
? 'https://preprod-api.myinvois.hasil.gov.my'
|
|
4
4
|
: 'https://api.myinvois.hasil.gov.my'
|