@ripwords/myinvois-client 0.2.24 → 0.2.26
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/dist/api/documentSubmission.js +2 -2
- package/dist/{document-BWReWH1w.cjs → document-B03WWFMc.cjs} +18 -14
- package/dist/document-B03WWFMc.cjs.map +1 -0
- package/dist/{document-BbggZ72T.js → document-BAUDGfZU.js} +17 -13
- package/dist/{documentSubmission-Dz1RhbtK.cjs → documentSubmission-56VbFff3.cjs} +4 -4
- package/dist/documentSubmission-56VbFff3.cjs.map +1 -0
- package/dist/{documentSubmission-CJQJAa4z.js → documentSubmission-isM8tGm0.js} +3 -3
- package/dist/index.cjs +2 -2
- package/dist/index.js +2 -2
- package/dist/index10.cjs +195 -4
- package/dist/index10.cjs.map +1 -0
- package/dist/index11.cjs +0 -22
- package/dist/index12.cjs +24 -2
- package/dist/{index20.cjs.map → index12.cjs.map} +1 -1
- package/dist/index13.cjs +0 -3
- package/dist/index14.cjs +0 -330
- package/dist/index15.cjs +25 -189
- package/dist/index15.cjs.map +1 -1
- package/dist/index16.cjs +16 -53
- package/dist/index16.cjs.map +1 -1
- package/dist/index17.cjs +0 -532
- package/dist/index18.cjs +25 -187
- package/dist/index18.cjs.map +1 -1
- package/dist/index19.cjs +24 -0
- package/dist/{index27.cjs.map → index19.cjs.map} +1 -1
- package/dist/index20.cjs +0 -25
- package/dist/index23.cjs +3 -28
- package/dist/index24.cjs +9 -21
- package/dist/index24.cjs.map +1 -1
- package/dist/index25.cjs +5 -0
- package/dist/index26.cjs +21 -33
- package/dist/index27.cjs +2 -23
- package/dist/index28.cjs +3 -0
- package/dist/index29.cjs +330 -0
- package/dist/{index14.cjs.map → index29.cjs.map} +1 -1
- package/dist/index3.cjs +2 -2
- package/dist/index30.cjs +193 -0
- package/dist/index30.cjs.map +1 -0
- package/dist/index8.cjs +61 -3
- package/dist/index8.cjs.map +1 -0
- package/dist/index9.cjs +528 -9
- package/dist/index9.cjs.map +1 -1
- package/dist/utils/document.js +1 -1
- package/dist/utils/signature-diagnostics.js +1 -1
- package/package.json +1 -1
- package/dist/document-BWReWH1w.cjs.map +0 -1
- package/dist/documentSubmission-Dz1RhbtK.cjs.map +0 -1
- package/dist/index17.cjs.map +0 -1
- package/dist/index23.cjs.map +0 -1
- package/dist/index26.cjs.map +0 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import "../formatIdValue-qTxJqj9o.js";
|
|
2
|
-
import "../document-
|
|
3
|
-
import { getSubmissionStatus, performDocumentAction, submitDocument } from "../documentSubmission-
|
|
2
|
+
import "../document-BAUDGfZU.js";
|
|
3
|
+
import { getSubmissionStatus, performDocumentAction, submitDocument } from "../documentSubmission-isM8tGm0.js";
|
|
4
4
|
|
|
5
5
|
export { getSubmissionStatus, performDocumentAction, submitDocument };
|
|
@@ -345,14 +345,14 @@ const createSignedProperties = (certificateDigest, signingTime, issuerName, seri
|
|
|
345
345
|
* Calculates the digest over the correct structure for validator compliance.
|
|
346
346
|
*/
|
|
347
347
|
const calculateSignedPropertiesDigest = (signedProperties, useTargetWrapper = true) => {
|
|
348
|
-
let
|
|
349
|
-
if (useTargetWrapper) {
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
348
|
+
let digestObj;
|
|
349
|
+
if (useTargetWrapper) digestObj = {
|
|
350
|
+
Target: "signature",
|
|
351
|
+
SignedProperties: signedProperties.SignedProperties
|
|
352
|
+
};
|
|
353
|
+
else digestObj = signedProperties.SignedProperties;
|
|
354
|
+
const sortedDigestObj = sortObjectKeys(digestObj);
|
|
355
|
+
const signedPropertiesString = JSON.stringify(sortedDigestObj);
|
|
356
356
|
const hash = crypto.default.createHash("sha256");
|
|
357
357
|
hash.update(signedPropertiesString, "utf8");
|
|
358
358
|
return hash.digest("base64");
|
|
@@ -428,11 +428,18 @@ const generateCompleteDocument = (invoices, signingCredentials) => {
|
|
|
428
428
|
const certInfo = extractCertificateInfo(signingCredentials.certificatePem);
|
|
429
429
|
const certificateDigest = calculateCertificateDigest(signingCredentials.certificatePem);
|
|
430
430
|
const signedProperties = createSignedProperties(certificateDigest, signingTime, certInfo.issuerName, certInfo.serialNumber);
|
|
431
|
-
const
|
|
431
|
+
const digestObj = {
|
|
432
|
+
Target: "signature",
|
|
433
|
+
SignedProperties: signedProperties.SignedProperties
|
|
434
|
+
};
|
|
435
|
+
const sortedDigestObj = sortObjectKeys(digestObj);
|
|
436
|
+
const signedPropertiesString = JSON.stringify(sortedDigestObj);
|
|
437
|
+
const propsDigest = crypto.default.createHash("sha256").update(signedPropertiesString, "utf8").digest("base64");
|
|
432
438
|
const { signedInfo } = createSignedInfoAndSign(docDigest, propsDigest, signingCredentials.privateKeyPem);
|
|
433
439
|
const certificate = signingCredentials.certificatePem.replace(/-----BEGIN CERTIFICATE-----/g, "").replace(/-----END CERTIFICATE-----/g, "").replace(/\s+/g, "");
|
|
434
440
|
const signedInvoices = invoices.map((invoice) => {
|
|
435
441
|
const cleanInvoice = generateCleanInvoiceObject(invoice);
|
|
442
|
+
const parsedCanonicalSignedProps = JSON.parse(signedPropertiesString);
|
|
436
443
|
return {
|
|
437
444
|
...cleanInvoice,
|
|
438
445
|
UBLExtensions: [{ UBLExtension: [{
|
|
@@ -442,10 +449,7 @@ const generateCompleteDocument = (invoices, signingCredentials) => {
|
|
|
442
449
|
ReferencedSignatureID: [{ _: "urn:oasis:names:specification:ubl:signature:Invoice" }],
|
|
443
450
|
Signature: [{
|
|
444
451
|
Id: "signature",
|
|
445
|
-
Object: [{ QualifyingProperties: [
|
|
446
|
-
Target: "signature",
|
|
447
|
-
SignedProperties: signedProperties.SignedProperties
|
|
448
|
-
}] }],
|
|
452
|
+
Object: [{ QualifyingProperties: [parsedCanonicalSignedProps] }],
|
|
449
453
|
KeyInfo: [{ X509Data: [{
|
|
450
454
|
X509Certificate: [{ _: certificate }],
|
|
451
455
|
X509SubjectName: [{ _: certInfo.subjectName }],
|
|
@@ -645,4 +649,4 @@ Object.defineProperty(exports, 'transformDocumentForHashing', {
|
|
|
645
649
|
return transformDocumentForHashing;
|
|
646
650
|
}
|
|
647
651
|
});
|
|
648
|
-
//# sourceMappingURL=document-
|
|
652
|
+
//# sourceMappingURL=document-B03WWFMc.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"document-B03WWFMc.cjs","names":["item: InvoiceLineItem","doc: AllDocumentsV1_1","obj: unknown","sortedObj: Record<string, unknown>","invoice: AllDocumentsV1_1","invoices: AllDocumentsV1_1[]","invoice: InvoiceSubmission","certificatePem: string","X509Certificate","dn: string","serialHex: string","error: unknown","certificateDigest: string","signingTime: string","issuerName: string","serialNumber: string","signedProperties: SignedPropertiesObject","useTargetWrapper: boolean","digestObj: unknown","docDigest: string","propsDigest: string","privateKeyPem: string","signedInfo: SignedInfoObject","documentString: string","signingCredentials: SigningCredentials","params: {\n itemClassificationCode: ClassificationCode\n itemDescription: string\n unitPrice: number\n quantity?: number\n taxType: TaxTypeCode\n taxRate: number\n totalTaxableAmountPerLine?: number\n}","params: {\n itemClassificationCode: ClassificationCode\n itemDescription: string\n unitPrice: number\n quantity?: number\n taxType: TaxTypeCode\n taxPerUnitAmount: number\n baseUnitMeasure: number\n baseUnitMeasureCode: UnitTypeCode\n totalTaxableAmountPerLine?: number\n}","lineItems: InvoiceLineItem[]"],"sources":["../src/utils/document.ts"],"sourcesContent":["import crypto, { X509Certificate } from 'crypto'\nimport {\n InvoiceSubmission,\n AllDocumentsV1_1,\n SigningCredentials,\n SignedPropertiesObject,\n UBLDocument,\n CompleteInvoice,\n SignedInfoObject,\n UnitTypeCode,\n InvoiceLineItem,\n} from '../types'\nimport type { ClassificationCode } from '../types'\nimport type { TaxTypeCode } from '../types'\nimport { formatIdValue } from './formatIdValue'\n\n/**\n * MyInvois v1.1 Document Generation and Signing Utilities\n * Strictly follows: https://sdk.myinvois.hasil.gov.my/documents/invoice-v1-1\n * JSON Signature Guide: https://sdk.myinvois.hasil.gov.my/signature-creation-json/\n */\n\n/**\n * Determines if a line item uses fixed rate taxation\n */\nexport const isFixedRateTax = (item: InvoiceLineItem): boolean => {\n return (\n item.taxPerUnitAmount !== undefined && item.baseUnitMeasure !== undefined\n )\n}\n\n/**\n * Determines if a line item uses percentage taxation\n */\nexport const isPercentageTax = (item: InvoiceLineItem): boolean => {\n return item.taxRate !== undefined && !isFixedRateTax(item)\n}\n\n/**\n * Calculates expected tax amount for a line item based on its tax type\n */\nexport const calculateExpectedTaxAmount = (item: InvoiceLineItem): number => {\n if (isFixedRateTax(item)) {\n return item.taxPerUnitAmount! * item.baseUnitMeasure!\n } else if (isPercentageTax(item)) {\n return (item.totalTaxableAmountPerLine * item.taxRate!) / 100\n }\n return 0\n}\n\n/**\n * Extracts the line-item array from any document variant\n */\nconst getLineItems = (doc: AllDocumentsV1_1): InvoiceLineItem[] => {\n if ('invoiceLineItems' in doc) return doc.invoiceLineItems\n if ('creditNoteLineItems' in doc) return doc.creditNoteLineItems\n if ('debitNoteLineItems' in doc) return doc.debitNoteLineItems\n if ('refundNoteLineItems' in doc) return doc.refundNoteLineItems\n if ('selfBilledCreditNoteLineItems' in doc)\n return doc.selfBilledCreditNoteLineItems\n if ('selfBilledRefundNoteLineItems' in doc)\n return doc.selfBilledRefundNoteLineItems\n // Fallback (should never happen with exhaustive types)\n return []\n}\n\n/**\n * Helper function to recursively sort object keys for JSON canonicalization\n */\nexport function sortObjectKeys(obj: unknown): unknown {\n if (obj === null || typeof obj !== 'object') {\n return obj\n }\n\n if (Array.isArray(obj)) {\n return obj.map(sortObjectKeys)\n }\n\n const sortedObj: Record<string, unknown> = {}\n const keys = Object.keys(obj as Record<string, unknown>).sort()\n\n for (const key of keys) {\n sortedObj[key] = sortObjectKeys((obj as Record<string, unknown>)[key])\n }\n\n return sortedObj\n}\n\n/**\n * Enhanced canonicalization following MyInvois specification exactly\n * Key changes: ensure consistent ordering and formatting\n */\nexport const canonicalizeJSON = (obj: unknown): string => {\n const sortedObj = sortObjectKeys(obj)\n // Use compact JSON with no extra whitespace\n return JSON.stringify(sortedObj, null, 0)\n}\n\n/**\n * Generates a clean invoice object following MyInvois v1.1 specification exactly\n * This is the base invoice structure WITHOUT signature elements (for hash calculation)\n *\n * Key requirements from working documents:\n * - All mandatory fields must be present\n * - Many optional fields must be present even if empty\n * - Specific field ordering and structure\n * - Correct listID values (e.g., \"3166-1\" not \"ISO3166-1\")\n */\nexport const generateCleanInvoiceObject = (\n invoice: AllDocumentsV1_1,\n): InvoiceSubmission => {\n const lineItems = getLineItems(invoice)\n return {\n // === MANDATORY CORE FIELDS ===\n ID: [{ _: invoice.eInvoiceCodeOrNumber }],\n IssueDate: [{ _: invoice.eInvoiceDate }],\n IssueTime: [{ _: invoice.eInvoiceTime }],\n InvoiceTypeCode: [\n {\n _: invoice.eInvoiceTypeCode,\n listVersionID: invoice.eInvoiceVersion || '1.1',\n },\n ],\n DocumentCurrencyCode: [{ _: invoice.invoiceCurrencyCode }],\n\n // === BILLING REFERENCE (only for credit/debit/refund notes) ===\n ...('originalEInvoiceReferenceNumber' in invoice &&\n 'originalEInvoiceInternalId' in invoice &&\n invoice.originalEInvoiceReferenceNumber\n ? {\n BillingReference: [\n {\n InvoiceDocumentReference: [\n {\n UUID: [\n {\n _: invoice.originalEInvoiceReferenceNumber,\n },\n ],\n ID: [\n {\n _: invoice.originalEInvoiceInternalId,\n },\n ],\n },\n ],\n },\n ],\n }\n : {}),\n\n // === SUPPLIER PARTY (AccountingSupplierParty) ===\n AccountingSupplierParty: [\n {\n Party: [\n {\n // Industry Classification - required field\n IndustryClassificationCode: [\n {\n _: invoice.supplier.industryClassificationCode,\n name: invoice.supplier.industryClassificationDescription,\n },\n ],\n\n // Party Identifications\n PartyIdentification: [\n {\n ID: [\n {\n _: invoice.supplier.tin,\n schemeID: 'TIN',\n },\n ],\n },\n {\n ID: [\n {\n _: formatIdValue(invoice.supplier.registrationNumber),\n schemeID: invoice.supplier.registrationType || 'NRIC',\n },\n ],\n },\n ],\n\n // Postal Address - FIXED listID format\n PostalAddress: [\n {\n CityName: [{ _: invoice.supplier.address.cityName }],\n CountrySubentityCode: [{ _: invoice.supplier.address.state }],\n AddressLine: [\n {\n Line: [{ _: invoice.supplier.address.addressLine0 }],\n },\n ],\n Country: [\n {\n IdentificationCode: [\n {\n _: invoice.supplier.address.country || 'MYS',\n listID: '3166-1', // FIXED: was \"ISO3166-1\"\n listAgencyID: 'ISO',\n },\n ],\n },\n ],\n },\n ],\n\n // Party Legal Entity\n PartyLegalEntity: [\n {\n RegistrationName: [{ _: invoice.supplier.name }],\n },\n ],\n\n // Contact Information\n Contact: [\n {\n Telephone: [{ _: invoice.supplier.contactNumber || '' }],\n },\n ],\n },\n ],\n },\n ],\n\n // === BUYER PARTY (AccountingCustomerParty) ===\n AccountingCustomerParty: [\n {\n Party: [\n {\n // Party Identifications\n PartyIdentification: [\n {\n ID: [\n {\n _: invoice.buyer.tin,\n schemeID: 'TIN',\n },\n ],\n },\n {\n ID: [\n {\n _: formatIdValue(invoice.buyer.registrationNumber),\n schemeID: invoice.buyer.registrationType || 'NRIC',\n },\n ],\n },\n {\n ID: [\n {\n _: invoice.buyer.sstRegistrationNumber || 'NA',\n schemeID: 'SST',\n },\n ],\n },\n ],\n\n // Postal Address - FIXED listID format\n PostalAddress: [\n {\n CityName: [{ _: invoice.buyer.address.cityName }],\n CountrySubentityCode: [{ _: invoice.buyer.address.state }],\n AddressLine: [\n {\n Line: [{ _: invoice.buyer.address.addressLine0 }],\n },\n ],\n Country: [\n {\n IdentificationCode: [\n {\n _: invoice.buyer.address.country || 'MYS',\n listID: '3166-1', // FIXED: was \"ISO3166-1\"\n listAgencyID: 'ISO',\n },\n ],\n },\n ],\n },\n ],\n\n // Party Legal Entity\n PartyLegalEntity: [\n {\n RegistrationName: [{ _: invoice.buyer.name }],\n },\n ],\n\n // Contact Information\n Contact: [\n {\n Telephone: [{ _: invoice.buyer.contactNumber || '' }],\n },\n ],\n },\n ],\n },\n ],\n\n // === TAX TOTAL ===\n TaxTotal: [\n {\n TaxAmount: [\n {\n _: invoice.taxTotal.taxAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxSubtotal: [\n // Generate basic tax subtotal from invoice line items\n {\n TaxableAmount: [\n {\n _: invoice.legalMonetaryTotal.taxExclusiveAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxAmount: [\n {\n _: invoice.taxTotal.taxAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxCategory: [\n {\n ID: [{ _: lineItems[0]?.taxType || '01' }],\n TaxScheme: [\n {\n ID: [\n {\n _: 'OTH',\n schemeAgencyID: '6',\n schemeID: 'UN/ECE 5153',\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n\n // === LEGAL MONETARY TOTAL ===\n LegalMonetaryTotal: [\n {\n LineExtensionAmount: [\n {\n _: invoice.legalMonetaryTotal.taxExclusiveAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxExclusiveAmount: [\n {\n _: invoice.legalMonetaryTotal.taxExclusiveAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxInclusiveAmount: [\n {\n _: invoice.legalMonetaryTotal.taxInclusiveAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n PayableAmount: [\n {\n _: invoice.legalMonetaryTotal.payableAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n },\n ],\n\n // === INVOICE LINES ===\n InvoiceLine: lineItems.map((item, index) => ({\n ID: [{ _: (index + 1).toString() }],\n\n // Item Information\n Item: [\n {\n CommodityClassification: [\n {\n ItemClassificationCode: [\n {\n _: item.itemClassificationCode,\n listID: 'CLASS',\n },\n ],\n },\n ],\n Description: [{ _: item.itemDescription }],\n },\n ],\n\n ItemPriceExtension: [\n {\n Amount: [\n {\n _: item.totalTaxableAmountPerLine,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n },\n ],\n\n LineExtensionAmount: [\n {\n _: item.totalTaxableAmountPerLine,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n\n // Price Information\n Price: [\n {\n PriceAmount: [\n {\n _: item.unitPrice,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n },\n ],\n\n // Tax Information for line\n TaxTotal: [\n {\n TaxAmount: [\n {\n _: item.taxAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxSubtotal: [\n {\n TaxableAmount: [\n {\n _: item.totalTaxableAmountPerLine,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n TaxAmount: [\n {\n _: item.taxAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n // Conditional tax fields based on taxation type\n ...(item.taxPerUnitAmount !== undefined &&\n item.baseUnitMeasure !== undefined\n ? {\n // Fixed Rate Taxation\n PerUnitAmount: [\n {\n _: item.taxPerUnitAmount,\n currencyID: invoice.invoiceCurrencyCode,\n },\n ],\n BaseUnitMeasure: [\n {\n _: item.baseUnitMeasure,\n unitCode: item.baseUnitMeasureCode || 'C62',\n },\n ],\n }\n : item.taxRate !== undefined\n ? {\n // Percentage Taxation\n Percent: [{ _: item.taxRate }],\n }\n : {}),\n TaxCategory: [\n {\n ID: [{ _: item.taxType }],\n TaxScheme: [\n {\n ID: [\n {\n _: 'OTH',\n schemeAgencyID: '6',\n schemeID: 'UN/ECE 5153',\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n })),\n\n // === TAX EXCHANGE RATE (mandatory where applicable) ===\n TaxExchangeRate: invoice.currencyExchangeRate\n ? [\n {\n SourceCurrencyCode: [\n {\n _: invoice.invoiceCurrencyCode,\n },\n ],\n TargetCurrencyCode: [\n {\n _: 'MYR',\n },\n ],\n CalculationRate: [\n {\n _: invoice.currencyExchangeRate,\n },\n ],\n },\n ]\n : undefined,\n }\n}\n\n/**\n * Generates the complete UBL document structure with namespace declarations\n */\nexport const generateCleanUBLDocument = (\n invoices: AllDocumentsV1_1[],\n): UBLDocument => {\n return {\n _D: 'urn:oasis:names:specification:ubl:schema:xsd:Invoice-2',\n _A: 'urn:oasis:names:specification:ubl:schema:xsd:CommonAggregateComponents-2',\n _B: 'urn:oasis:names:specification:ubl:schema:xsd:CommonBasicComponents-2',\n Invoice: invoices.map(generateCleanInvoiceObject),\n }\n}\n\n/**\n * Step 1: Transform the document for hashing or transmission\n * Removes UBLExtensions and Signature, and minifies the JSON\n * Returns the minified, cleaned JSON string\n */\nexport const transformDocumentForHashing = (\n invoices: AllDocumentsV1_1[],\n): string => {\n // Generate clean UBL document structure\n const cleanDocument = generateCleanUBLDocument(invoices)\n\n // Deep clone to avoid mutating input\n const documentForTransform = JSON.parse(JSON.stringify(cleanDocument))\n if (\n documentForTransform.Invoice &&\n Array.isArray(documentForTransform.Invoice)\n ) {\n documentForTransform.Invoice.forEach((invoice: InvoiceSubmission) => {\n delete invoice.UBLExtensions\n delete invoice.Signature\n })\n }\n\n // Return minified JSON string\n return JSON.stringify(documentForTransform)\n}\n\n/**\n * Step 2: Calculate Document Digest\n * FIXED: Remove UBLExtensions and Signature before hashing (DS322)\n * Based on working implementation pattern\n */\nexport const calculateDocumentDigest = (\n invoices: AllDocumentsV1_1[],\n): string => {\n // Use the transformation function to get the minified, cleaned JSON string\n const documentString = transformDocumentForHashing(invoices)\n\n // Calculate SHA-256 hash\n const hash = crypto.createHash('sha256')\n hash.update(documentString, 'utf8')\n\n // Return as Base64 (DocDigest)\n return hash.digest('base64')\n}\n\n/**\n * Step 4: Calculate Certificate Digest\n * Enhanced to handle certificate content properly\n */\nexport const calculateCertificateDigest = (certificatePem: string): string => {\n // Extract certificate content (Base64 without PEM headers/footers)\n const certificateContent = certificatePem\n .replace(/-----BEGIN CERTIFICATE-----/g, '')\n .replace(/-----END CERTIFICATE-----/g, '')\n .replace(/\\s+/g, '') // Remove all whitespace\n\n // Convert Base64 to binary\n const certificateBinary = Buffer.from(certificateContent, 'base64')\n\n // Calculate SHA-256 hash of binary content\n const hash = crypto.createHash('sha256')\n hash.update(certificateBinary)\n\n // Return as Base64\n return hash.digest('base64')\n}\n\n/**\n * Enhanced certificate info extraction with better error handling\n * FIXED: Normalize issuer name format to match MyInvois expectations (DS326)\n */\nexport const extractCertificateInfo = (\n certificatePem: string,\n): {\n issuerName: string\n serialNumber: string\n subjectName: string\n} => {\n try {\n const cert = new X509Certificate(certificatePem)\n\n // Extract serial number and convert to decimal string\n const serialNumberHex = cert.serialNumber\n\n // Keep the DN formatting exactly as it appears in the certificate to avoid\n // mismatches when the signing service validates the X509IssuerName fields.\n // We only replace raw new-lines with \", \" so that the DN remains a single-line\n // string while preserving all other whitespace and ordering.\n const normalizeDistinguishedName = (dn: string): string => {\n // Node returns issuer DN in reverse RDN order (C, O, ... , CN).\n // The MyInvois validator expects forward order (CN first).\n // 1. Break DN into components separated by newline or commas.\n // 2. Reverse to get CN → ... → C ordering.\n // 3. Join with \", \" and ensure single '=' spacing.\n const parts = dn\n .split(/\\r?\\n|,\\s*/)\n .map(part => part.trim())\n .filter(part => part.length > 0)\n .reverse()\n return parts.join(', ').replace(/\\s*=\\s*/g, '=')\n }\n\n // Enhanced serial number formatting\n const formatSerialNumber = (serialHex: string): string => {\n // Convert hex to decimal and ensure it's a string\n const decimal = BigInt('0x' + serialHex).toString()\n return decimal\n }\n\n return {\n issuerName: normalizeDistinguishedName(cert.issuer),\n serialNumber: formatSerialNumber(serialNumberHex),\n subjectName: normalizeDistinguishedName(cert.subject),\n }\n } catch (error: unknown) {\n throw new Error(\n `Failed to extract certificate info: ${error instanceof Error ? error.message : String(error)}`,\n )\n }\n}\n\n/**\n * Step 5: Create SignedProperties with enhanced structure\n * FIXED: Simplified structure to match MyInvois expectations (DS320)\n * Following MyInvois JSON signature specification exactly\n */\nexport const createSignedProperties = (\n certificateDigest: string,\n signingTime: string,\n issuerName: string,\n serialNumber: string,\n): SignedPropertiesObject => {\n return {\n SignedProperties: [\n {\n Id: 'id-xades-signed-props',\n SignedSignatureProperties: [\n {\n SigningTime: [{ _: signingTime }],\n SigningCertificate: [\n {\n Cert: [\n {\n CertDigest: [\n {\n DigestMethod: [\n {\n _: '',\n Algorithm:\n 'http://www.w3.org/2001/04/xmlenc#sha256',\n },\n ],\n DigestValue: [{ _: certificateDigest }],\n },\n ],\n IssuerSerial: [\n {\n X509IssuerName: [{ _: issuerName }],\n X509SerialNumber: [{ _: serialNumber }],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n }\n}\n\n/**\n * Step 6: Calculate SignedProperties Digest\n * Calculates the digest over the correct structure for validator compliance.\n */\nexport const calculateSignedPropertiesDigest = (\n signedProperties: SignedPropertiesObject,\n useTargetWrapper: boolean = true, // now default to wrapper for compliance\n): string => {\n let digestObj: unknown\n if (useTargetWrapper) {\n digestObj = {\n Target: 'signature',\n SignedProperties: signedProperties.SignedProperties,\n }\n } else {\n digestObj = signedProperties.SignedProperties\n }\n // Recursively sort all object keys for deterministic output\n const sortedDigestObj = sortObjectKeys(digestObj)\n const signedPropertiesString = JSON.stringify(sortedDigestObj)\n const hash = crypto.createHash('sha256')\n hash.update(signedPropertiesString, 'utf8')\n return hash.digest('base64')\n}\n\n/**\n * Step 3: Create SignedInfo and calculate signature\n * Enhanced with better structure and signature generation\n */\nexport const createSignedInfoAndSign = (\n docDigest: string,\n propsDigest: string,\n privateKeyPem: string,\n): { signedInfo: SignedInfoObject; signatureValue: string } => {\n // Create SignedInfo structure following specification exactly\n const signedInfo: SignedInfoObject = {\n CanonicalizationMethod: [\n {\n _: '',\n Algorithm: 'http://www.w3.org/2006/12/xml-c14n11',\n },\n ],\n SignatureMethod: [\n {\n _: '',\n Algorithm: 'http://www.w3.org/2001/04/xmldsig-more#rsa-sha256',\n },\n ],\n Reference: [\n {\n Id: 'id-doc-signed-data',\n Type: '',\n URI: '',\n DigestMethod: [\n {\n _: '',\n Algorithm: 'http://www.w3.org/2001/04/xmlenc#sha256',\n },\n ],\n DigestValue: [{ _: docDigest }],\n },\n {\n Id: 'id-xades-signed-props',\n Type: 'http://uri.etsi.org/01903/v1.3.2#SignedProperties',\n URI: '#id-xades-signed-props',\n DigestMethod: [\n {\n _: '',\n Algorithm: 'http://www.w3.org/2001/04/xmlenc#sha256',\n },\n ],\n DigestValue: [{ _: propsDigest }],\n },\n ],\n }\n\n // Serialize the SignedInfo exactly as it will be embedded (no reordering)\n const signedInfoRaw = JSON.stringify(signedInfo)\n\n try {\n const signer = crypto.createSign('RSA-SHA256')\n signer.update(signedInfoRaw, 'utf8')\n const signatureValue = signer.sign(privateKeyPem, 'base64')\n\n // Reuse the original object so ordering is preserved\n return { signedInfo, signatureValue }\n } catch (error) {\n throw new Error(\n `Signature generation failed: ${error instanceof Error ? error.message : String(error)}`,\n )\n }\n}\n\n/**\n * Signs the minified document string using the provided private key PEM\n * Returns the signature as a base64 string\n */\nexport const signDocumentString = (\n documentString: string,\n privateKeyPem: string,\n): string => {\n const signature = crypto.sign('sha256', Buffer.from(documentString, 'utf8'), {\n key: privateKeyPem,\n padding: crypto.constants.RSA_PKCS1_PADDING,\n })\n return signature.toString('base64')\n}\n\n/**\n * Complete document generation with signatures\n * Follows the complete MyInvois JSON signature creation process (Steps 1-7)\n */\nexport const generateCompleteDocument = (\n invoices: AllDocumentsV1_1[],\n signingCredentials: SigningCredentials,\n): CompleteInvoice => {\n try {\n // Step 1: Generate clean document (done in calculateDocumentDigest)\n // Step 2: Calculate document digest\n const docDigest = calculateDocumentDigest(invoices)\n\n // Get the minified, cleaned JSON string for signing\n const documentString = transformDocumentForHashing(invoices)\n\n // Step 3: Sign the minified document string (not the digest)\n const docSignature = signDocumentString(\n documentString,\n signingCredentials.privateKeyPem,\n )\n\n // Generate signing time in proper ISO format\n const signingTime = new Date().toISOString()\n\n // Extract certificate information (enhanced)\n const certInfo = extractCertificateInfo(signingCredentials.certificatePem)\n\n // Step 4: Calculate certificate digest\n const certificateDigest = calculateCertificateDigest(\n signingCredentials.certificatePem,\n )\n\n // Step 5: Create SignedProperties using extracted cert info\n const signedProperties = createSignedProperties(\n certificateDigest,\n signingTime,\n certInfo.issuerName,\n certInfo.serialNumber,\n )\n\n // Step 6: Build canonical digest object, sort, and stringify\n const digestObj = {\n Target: 'signature',\n SignedProperties: signedProperties.SignedProperties,\n }\n const sortedDigestObj = sortObjectKeys(digestObj)\n const signedPropertiesString = JSON.stringify(sortedDigestObj)\n const propsDigest = crypto\n .createHash('sha256')\n .update(signedPropertiesString, 'utf8')\n .digest('base64')\n\n // Step 3 (new): Create SignedInfo structure (but do not sign it, just include for type compliance)\n const { signedInfo } = createSignedInfoAndSign(\n docDigest,\n propsDigest,\n signingCredentials.privateKeyPem,\n )\n\n // Extract certificate content (Base64 without PEM headers)\n const certificate = signingCredentials.certificatePem\n .replace(/-----BEGIN CERTIFICATE-----/g, '')\n .replace(/-----END CERTIFICATE-----/g, '')\n .replace(/\\s+/g, '')\n\n // Step 7: Create final signed document\n const signedInvoices = invoices.map(invoice => {\n const cleanInvoice = generateCleanInvoiceObject(invoice)\n\n // Parse the canonical signed properties string back to an object for embedding\n const parsedCanonicalSignedProps = JSON.parse(signedPropertiesString)\n\n return {\n ...cleanInvoice,\n\n // Add UBLExtensions with complete signature structure\n UBLExtensions: [\n {\n UBLExtension: [\n {\n ExtensionURI: [\n {\n _: 'urn:oasis:names:specification:ubl:dsig:enveloped:xades',\n },\n ],\n ExtensionContent: [\n {\n UBLDocumentSignatures: [\n {\n SignatureInformation: [\n {\n ID: [\n {\n _: 'urn:oasis:names:specification:ubl:signature:1',\n },\n ],\n ReferencedSignatureID: [\n {\n _: 'urn:oasis:names:specification:ubl:signature:Invoice',\n },\n ],\n Signature: [\n {\n Id: 'signature',\n Object: [\n {\n QualifyingProperties: [\n parsedCanonicalSignedProps,\n ],\n },\n ],\n KeyInfo: [\n {\n X509Data: [\n {\n X509Certificate: [{ _: certificate }],\n X509SubjectName: [\n { _: certInfo.subjectName },\n ],\n X509IssuerSerial: [\n {\n X509IssuerName: [\n {\n _: certInfo.issuerName,\n },\n ],\n X509SerialNumber: [\n {\n _: certInfo.serialNumber,\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n SignatureValue: [{ _: docSignature }],\n SignedInfo: [signedInfo],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n },\n ],\n\n // Add simple Signature reference\n Signature: [\n {\n ID: [\n {\n _: 'urn:oasis:names:specification:ubl:signature:Invoice',\n },\n ],\n SignatureMethod: [\n {\n _: 'urn:oasis:names:specification:ubl:dsig:enveloped:xades',\n },\n ],\n },\n ],\n }\n })\n\n return {\n _D: 'urn:oasis:names:specification:ubl:schema:xsd:Invoice-2',\n _A: 'urn:oasis:names:specification:ubl:schema:xsd:CommonAggregateComponents-2',\n _B: 'urn:oasis:names:specification:ubl:schema:xsd:CommonBasicComponents-2',\n Invoice: signedInvoices,\n }\n } catch (error) {\n throw new Error(\n `Document generation failed: ${error instanceof Error ? error.message : String(error)}`,\n )\n }\n}\n\n/**\n * Creates a line item with percentage-based taxation (e.g., SST, GST)\n */\nexport const createPercentageTaxLineItem = (params: {\n itemClassificationCode: ClassificationCode\n itemDescription: string\n unitPrice: number\n quantity?: number\n taxType: TaxTypeCode\n taxRate: number\n totalTaxableAmountPerLine?: number\n}): InvoiceLineItem => {\n const quantity = params.quantity || 1\n const totalTaxableAmount =\n params.totalTaxableAmountPerLine || params.unitPrice * quantity\n const taxAmount = (totalTaxableAmount * params.taxRate) / 100\n\n return {\n itemClassificationCode: params.itemClassificationCode,\n itemDescription: params.itemDescription,\n unitPrice: params.unitPrice,\n taxType: params.taxType,\n taxRate: params.taxRate,\n taxAmount: Math.round(taxAmount * 100) / 100, // Round to 2 decimal places\n totalTaxableAmountPerLine: totalTaxableAmount,\n totalAmountPerLine: totalTaxableAmount + taxAmount,\n }\n}\n\n/**\n * Creates a line item with fixed rate taxation (e.g., Tourism Tax)\n */\nexport const createFixedRateTaxLineItem = (params: {\n itemClassificationCode: ClassificationCode\n itemDescription: string\n unitPrice: number\n quantity?: number\n taxType: TaxTypeCode\n taxPerUnitAmount: number\n baseUnitMeasure: number\n baseUnitMeasureCode: UnitTypeCode\n totalTaxableAmountPerLine?: number\n}): InvoiceLineItem => {\n const quantity = params.quantity || 1\n const totalTaxableAmount =\n params.totalTaxableAmountPerLine || params.unitPrice * quantity\n const taxAmount = params.taxPerUnitAmount * params.baseUnitMeasure\n\n return {\n itemClassificationCode: params.itemClassificationCode,\n itemDescription: params.itemDescription,\n unitPrice: params.unitPrice,\n taxType: params.taxType,\n taxPerUnitAmount: params.taxPerUnitAmount,\n baseUnitMeasure: params.baseUnitMeasure,\n baseUnitMeasureCode: params.baseUnitMeasureCode,\n taxAmount: Math.round(taxAmount * 100) / 100, // Round to 2 decimal places\n totalTaxableAmountPerLine: totalTaxableAmount,\n totalAmountPerLine: totalTaxableAmount + taxAmount,\n }\n}\n\n/**\n * Calculates invoice totals from line items\n */\nexport const calculateInvoiceTotals = (\n lineItems: InvoiceLineItem[],\n): {\n legalMonetaryTotal: {\n taxExclusiveAmount: number\n taxInclusiveAmount: number\n payableAmount: number\n }\n taxTotal: {\n taxAmount: number\n }\n} => {\n const taxExclusiveAmount = lineItems.reduce(\n (sum, item) => sum + item.totalTaxableAmountPerLine,\n 0,\n )\n const totalTaxAmount = lineItems.reduce(\n (sum, item) => sum + item.taxAmount,\n 0,\n )\n const taxInclusiveAmount = taxExclusiveAmount + totalTaxAmount\n\n return {\n legalMonetaryTotal: {\n taxExclusiveAmount: Math.round(taxExclusiveAmount * 100) / 100,\n taxInclusiveAmount: Math.round(taxInclusiveAmount * 100) / 100,\n payableAmount: Math.round(taxInclusiveAmount * 100) / 100,\n },\n taxTotal: {\n taxAmount: Math.round(totalTaxAmount * 100) / 100,\n },\n }\n}\n"],"mappings":";;;;;;;;;;;;;AAyBA,MAAa,iBAAiB,CAACA,SAAmC;AAChE,QACE,KAAK,+BAAkC,KAAK;AAE/C;;;;AAKD,MAAa,kBAAkB,CAACA,SAAmC;AACjE,QAAO,KAAK,uBAA0B,eAAe,KAAK;AAC3D;;;;AAKD,MAAa,6BAA6B,CAACA,SAAkC;AAC3E,KAAI,eAAe,KAAK,CACtB,QAAO,KAAK,mBAAoB,KAAK;UAC5B,gBAAgB,KAAK,CAC9B,QAAQ,KAAK,4BAA4B,KAAK,UAAY;AAE5D,QAAO;AACR;;;;AAKD,MAAM,eAAe,CAACC,QAA6C;AACjE,KAAI,sBAAsB,IAAK,QAAO,IAAI;AAC1C,KAAI,yBAAyB,IAAK,QAAO,IAAI;AAC7C,KAAI,wBAAwB,IAAK,QAAO,IAAI;AAC5C,KAAI,yBAAyB,IAAK,QAAO,IAAI;AAC7C,KAAI,mCAAmC,IACrC,QAAO,IAAI;AACb,KAAI,mCAAmC,IACrC,QAAO,IAAI;AAEb,QAAO,CAAE;AACV;;;;AAKD,SAAgB,eAAeC,KAAuB;AACpD,KAAI,QAAQ,eAAe,QAAQ,SACjC,QAAO;AAGT,KAAI,MAAM,QAAQ,IAAI,CACpB,QAAO,IAAI,IAAI,eAAe;CAGhC,MAAMC,YAAqC,CAAE;CAC7C,MAAM,OAAO,OAAO,KAAK,IAA+B,CAAC,MAAM;AAE/D,MAAK,MAAM,OAAO,KAChB,WAAU,OAAO,eAAgB,IAAgC,KAAK;AAGxE,QAAO;AACR;;;;;AAMD,MAAa,mBAAmB,CAACD,QAAyB;CACxD,MAAM,YAAY,eAAe,IAAI;AAErC,QAAO,KAAK,UAAU,WAAW,MAAM,EAAE;AAC1C;;;;;;;;;;;AAYD,MAAa,6BAA6B,CACxCE,YACsB;CACtB,MAAM,YAAY,aAAa,QAAQ;AACvC,QAAO;EAEL,IAAI,CAAC,EAAE,GAAG,QAAQ,qBAAsB,CAAC;EACzC,WAAW,CAAC,EAAE,GAAG,QAAQ,aAAc,CAAC;EACxC,WAAW,CAAC,EAAE,GAAG,QAAQ,aAAc,CAAC;EACxC,iBAAiB,CACf;GACE,GAAG,QAAQ;GACX,eAAe,QAAQ,mBAAmB;EAC3C,CACF;EACD,sBAAsB,CAAC,EAAE,GAAG,QAAQ,oBAAqB,CAAC;EAG1D,GAAI,qCAAqC,WACzC,gCAAgC,WAChC,QAAQ,kCACJ,EACE,kBAAkB,CAChB,EACE,0BAA0B,CACxB;GACE,MAAM,CACJ,EACE,GAAG,QAAQ,gCACZ,CACF;GACD,IAAI,CACF,EACE,GAAG,QAAQ,2BACZ,CACF;EACF,CACF,EACF,CACF,EACF,IACD,CAAE;EAGN,yBAAyB,CACvB,EACE,OAAO,CACL;GAEE,4BAA4B,CAC1B;IACE,GAAG,QAAQ,SAAS;IACpB,MAAM,QAAQ,SAAS;GACxB,CACF;GAGD,qBAAqB,CACnB,EACE,IAAI,CACF;IACE,GAAG,QAAQ,SAAS;IACpB,UAAU;GACX,CACF,EACF,GACD,EACE,IAAI,CACF;IACE,GAAG,oCAAc,QAAQ,SAAS,mBAAmB;IACrD,UAAU,QAAQ,SAAS,oBAAoB;GAChD,CACF,EACF,CACF;GAGD,eAAe,CACb;IACE,UAAU,CAAC,EAAE,GAAG,QAAQ,SAAS,QAAQ,SAAU,CAAC;IACpD,sBAAsB,CAAC,EAAE,GAAG,QAAQ,SAAS,QAAQ,MAAO,CAAC;IAC7D,aAAa,CACX,EACE,MAAM,CAAC,EAAE,GAAG,QAAQ,SAAS,QAAQ,aAAc,CAAC,EACrD,CACF;IACD,SAAS,CACP,EACE,oBAAoB,CAClB;KACE,GAAG,QAAQ,SAAS,QAAQ,WAAW;KACvC,QAAQ;KACR,cAAc;IACf,CACF,EACF,CACF;GACF,CACF;GAGD,kBAAkB,CAChB,EACE,kBAAkB,CAAC,EAAE,GAAG,QAAQ,SAAS,KAAM,CAAC,EACjD,CACF;GAGD,SAAS,CACP,EACE,WAAW,CAAC,EAAE,GAAG,QAAQ,SAAS,iBAAiB,GAAI,CAAC,EACzD,CACF;EACF,CACF,EACF,CACF;EAGD,yBAAyB,CACvB,EACE,OAAO,CACL;GAEE,qBAAqB;IACnB,EACE,IAAI,CACF;KACE,GAAG,QAAQ,MAAM;KACjB,UAAU;IACX,CACF,EACF;IACD,EACE,IAAI,CACF;KACE,GAAG,oCAAc,QAAQ,MAAM,mBAAmB;KAClD,UAAU,QAAQ,MAAM,oBAAoB;IAC7C,CACF,EACF;IACD,EACE,IAAI,CACF;KACE,GAAG,QAAQ,MAAM,yBAAyB;KAC1C,UAAU;IACX,CACF,EACF;GACF;GAGD,eAAe,CACb;IACE,UAAU,CAAC,EAAE,GAAG,QAAQ,MAAM,QAAQ,SAAU,CAAC;IACjD,sBAAsB,CAAC,EAAE,GAAG,QAAQ,MAAM,QAAQ,MAAO,CAAC;IAC1D,aAAa,CACX,EACE,MAAM,CAAC,EAAE,GAAG,QAAQ,MAAM,QAAQ,aAAc,CAAC,EAClD,CACF;IACD,SAAS,CACP,EACE,oBAAoB,CAClB;KACE,GAAG,QAAQ,MAAM,QAAQ,WAAW;KACpC,QAAQ;KACR,cAAc;IACf,CACF,EACF,CACF;GACF,CACF;GAGD,kBAAkB,CAChB,EACE,kBAAkB,CAAC,EAAE,GAAG,QAAQ,MAAM,KAAM,CAAC,EAC9C,CACF;GAGD,SAAS,CACP,EACE,WAAW,CAAC,EAAE,GAAG,QAAQ,MAAM,iBAAiB,GAAI,CAAC,EACtD,CACF;EACF,CACF,EACF,CACF;EAGD,UAAU,CACR;GACE,WAAW,CACT;IACE,GAAG,QAAQ,SAAS;IACpB,YAAY,QAAQ;GACrB,CACF;GACD,aAAa,CAEX;IACE,eAAe,CACb;KACE,GAAG,QAAQ,mBAAmB;KAC9B,YAAY,QAAQ;IACrB,CACF;IACD,WAAW,CACT;KACE,GAAG,QAAQ,SAAS;KACpB,YAAY,QAAQ;IACrB,CACF;IACD,aAAa,CACX;KACE,IAAI,CAAC,EAAE,GAAG,UAAU,IAAI,WAAW,KAAM,CAAC;KAC1C,WAAW,CACT,EACE,IAAI,CACF;MACE,GAAG;MACH,gBAAgB;MAChB,UAAU;KACX,CACF,EACF,CACF;IACF,CACF;GACF,CACF;EACF,CACF;EAGD,oBAAoB,CAClB;GACE,qBAAqB,CACnB;IACE,GAAG,QAAQ,mBAAmB;IAC9B,YAAY,QAAQ;GACrB,CACF;GACD,oBAAoB,CAClB;IACE,GAAG,QAAQ,mBAAmB;IAC9B,YAAY,QAAQ;GACrB,CACF;GACD,oBAAoB,CAClB;IACE,GAAG,QAAQ,mBAAmB;IAC9B,YAAY,QAAQ;GACrB,CACF;GACD,eAAe,CACb;IACE,GAAG,QAAQ,mBAAmB;IAC9B,YAAY,QAAQ;GACrB,CACF;EACF,CACF;EAGD,aAAa,UAAU,IAAI,CAAC,MAAM,WAAW;GAC3C,IAAI,CAAC,EAAE,GAAG,CAAC,QAAQ,GAAG,UAAU,CAAE,CAAC;GAGnC,MAAM,CACJ;IACE,yBAAyB,CACvB,EACE,wBAAwB,CACtB;KACE,GAAG,KAAK;KACR,QAAQ;IACT,CACF,EACF,CACF;IACD,aAAa,CAAC,EAAE,GAAG,KAAK,gBAAiB,CAAC;GAC3C,CACF;GAED,oBAAoB,CAClB,EACE,QAAQ,CACN;IACE,GAAG,KAAK;IACR,YAAY,QAAQ;GACrB,CACF,EACF,CACF;GAED,qBAAqB,CACnB;IACE,GAAG,KAAK;IACR,YAAY,QAAQ;GACrB,CACF;GAGD,OAAO,CACL,EACE,aAAa,CACX;IACE,GAAG,KAAK;IACR,YAAY,QAAQ;GACrB,CACF,EACF,CACF;GAGD,UAAU,CACR;IACE,WAAW,CACT;KACE,GAAG,KAAK;KACR,YAAY,QAAQ;IACrB,CACF;IACD,aAAa,CACX;KACE,eAAe,CACb;MACE,GAAG,KAAK;MACR,YAAY,QAAQ;KACrB,CACF;KACD,WAAW,CACT;MACE,GAAG,KAAK;MACR,YAAY,QAAQ;KACrB,CACF;KAED,GAAI,KAAK,+BACT,KAAK,6BACD;MAEE,eAAe,CACb;OACE,GAAG,KAAK;OACR,YAAY,QAAQ;MACrB,CACF;MACD,iBAAiB,CACf;OACE,GAAG,KAAK;OACR,UAAU,KAAK,uBAAuB;MACvC,CACF;KACF,IACD,KAAK,qBACH,EAEE,SAAS,CAAC,EAAE,GAAG,KAAK,QAAS,CAAC,EAC/B,IACD,CAAE;KACR,aAAa,CACX;MACE,IAAI,CAAC,EAAE,GAAG,KAAK,QAAS,CAAC;MACzB,WAAW,CACT,EACE,IAAI,CACF;OACE,GAAG;OACH,gBAAgB;OAChB,UAAU;MACX,CACF,EACF,CACF;KACF,CACF;IACF,CACF;GACF,CACF;EACF,GAAE;EAGH,iBAAiB,QAAQ,uBACrB,CACE;GACE,oBAAoB,CAClB,EACE,GAAG,QAAQ,oBACZ,CACF;GACD,oBAAoB,CAClB,EACE,GAAG,MACJ,CACF;GACD,iBAAiB,CACf,EACE,GAAG,QAAQ,qBACZ,CACF;EACF,CACF;CAEN;AACF;;;;AAKD,MAAa,2BAA2B,CACtCC,aACgB;AAChB,QAAO;EACL,IAAI;EACJ,IAAI;EACJ,IAAI;EACJ,SAAS,SAAS,IAAI,2BAA2B;CAClD;AACF;;;;;;AAOD,MAAa,8BAA8B,CACzCA,aACW;CAEX,MAAM,gBAAgB,yBAAyB,SAAS;CAGxD,MAAM,uBAAuB,KAAK,MAAM,KAAK,UAAU,cAAc,CAAC;AACtE,KACE,qBAAqB,WACrB,MAAM,QAAQ,qBAAqB,QAAQ,CAE3C,sBAAqB,QAAQ,QAAQ,CAACC,YAA+B;AACnE,SAAO,QAAQ;AACf,SAAO,QAAQ;CAChB,EAAC;AAIJ,QAAO,KAAK,UAAU,qBAAqB;AAC5C;;;;;;AAOD,MAAa,0BAA0B,CACrCD,aACW;CAEX,MAAM,iBAAiB,4BAA4B,SAAS;CAG5D,MAAM,OAAO,eAAO,WAAW,SAAS;AACxC,MAAK,OAAO,gBAAgB,OAAO;AAGnC,QAAO,KAAK,OAAO,SAAS;AAC7B;;;;;AAMD,MAAa,6BAA6B,CAACE,mBAAmC;CAE5E,MAAM,qBAAqB,eACxB,QAAQ,gCAAgC,GAAG,CAC3C,QAAQ,8BAA8B,GAAG,CACzC,QAAQ,QAAQ,GAAG;CAGtB,MAAM,oBAAoB,OAAO,KAAK,oBAAoB,SAAS;CAGnE,MAAM,OAAO,eAAO,WAAW,SAAS;AACxC,MAAK,OAAO,kBAAkB;AAG9B,QAAO,KAAK,OAAO,SAAS;AAC7B;;;;;AAMD,MAAa,yBAAyB,CACpCA,mBAKG;AACH,KAAI;EACF,MAAM,OAAO,IAAIC,uBAAgB;EAGjC,MAAM,kBAAkB,KAAK;EAM7B,MAAM,6BAA6B,CAACC,OAAuB;GAMzD,MAAM,QAAQ,GACX,MAAM,aAAa,CACnB,IAAI,UAAQ,KAAK,MAAM,CAAC,CACxB,OAAO,UAAQ,KAAK,SAAS,EAAE,CAC/B,SAAS;AACZ,UAAO,MAAM,KAAK,KAAK,CAAC,QAAQ,YAAY,IAAI;EACjD;EAGD,MAAM,qBAAqB,CAACC,cAA8B;GAExD,MAAM,UAAU,OAAO,OAAO,UAAU,CAAC,UAAU;AACnD,UAAO;EACR;AAED,SAAO;GACL,YAAY,2BAA2B,KAAK,OAAO;GACnD,cAAc,mBAAmB,gBAAgB;GACjD,aAAa,2BAA2B,KAAK,QAAQ;EACtD;CACF,SAAQC,OAAgB;AACvB,QAAM,IAAI,OACP,sCAAsC,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM,CAAC;CAEjG;AACF;;;;;;AAOD,MAAa,yBAAyB,CACpCC,mBACAC,aACAC,YACAC,iBAC2B;AAC3B,QAAO,EACL,kBAAkB,CAChB;EACE,IAAI;EACJ,2BAA2B,CACzB;GACE,aAAa,CAAC,EAAE,GAAG,YAAa,CAAC;GACjC,oBAAoB,CAClB,EACE,MAAM,CACJ;IACE,YAAY,CACV;KACE,cAAc,CACZ;MACE,GAAG;MACH,WACE;KACH,CACF;KACD,aAAa,CAAC,EAAE,GAAG,kBAAmB,CAAC;IACxC,CACF;IACD,cAAc,CACZ;KACE,gBAAgB,CAAC,EAAE,GAAG,WAAY,CAAC;KACnC,kBAAkB,CAAC,EAAE,GAAG,aAAc,CAAC;IACxC,CACF;GACF,CACF,EACF,CACF;EACF,CACF;CACF,CACF,EACF;AACF;;;;;AAMD,MAAa,kCAAkC,CAC7CC,kBACAC,mBAA4B,SACjB;CACX,IAAIC;AACJ,KAAI,iBACF,aAAY;EACV,QAAQ;EACR,kBAAkB,iBAAiB;CACpC;KAED,aAAY,iBAAiB;CAG/B,MAAM,kBAAkB,eAAe,UAAU;CACjD,MAAM,yBAAyB,KAAK,UAAU,gBAAgB;CAC9D,MAAM,OAAO,eAAO,WAAW,SAAS;AACxC,MAAK,OAAO,wBAAwB,OAAO;AAC3C,QAAO,KAAK,OAAO,SAAS;AAC7B;;;;;AAMD,MAAa,0BAA0B,CACrCC,WACAC,aACAC,kBAC6D;CAE7D,MAAMC,aAA+B;EACnC,wBAAwB,CACtB;GACE,GAAG;GACH,WAAW;EACZ,CACF;EACD,iBAAiB,CACf;GACE,GAAG;GACH,WAAW;EACZ,CACF;EACD,WAAW,CACT;GACE,IAAI;GACJ,MAAM;GACN,KAAK;GACL,cAAc,CACZ;IACE,GAAG;IACH,WAAW;GACZ,CACF;GACD,aAAa,CAAC,EAAE,GAAG,UAAW,CAAC;EAChC,GACD;GACE,IAAI;GACJ,MAAM;GACN,KAAK;GACL,cAAc,CACZ;IACE,GAAG;IACH,WAAW;GACZ,CACF;GACD,aAAa,CAAC,EAAE,GAAG,YAAa,CAAC;EAClC,CACF;CACF;CAGD,MAAM,gBAAgB,KAAK,UAAU,WAAW;AAEhD,KAAI;EACF,MAAM,SAAS,eAAO,WAAW,aAAa;AAC9C,SAAO,OAAO,eAAe,OAAO;EACpC,MAAM,iBAAiB,OAAO,KAAK,eAAe,SAAS;AAG3D,SAAO;GAAE;GAAY;EAAgB;CACtC,SAAQ,OAAO;AACd,QAAM,IAAI,OACP,+BAA+B,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM,CAAC;CAE1F;AACF;;;;;AAMD,MAAa,qBAAqB,CAChCC,gBACAF,kBACW;CACX,MAAM,YAAY,eAAO,KAAK,UAAU,OAAO,KAAK,gBAAgB,OAAO,EAAE;EAC3E,KAAK;EACL,SAAS,eAAO,UAAU;CAC3B,EAAC;AACF,QAAO,UAAU,SAAS,SAAS;AACpC;;;;;AAMD,MAAa,2BAA2B,CACtChB,UACAmB,uBACoB;AACpB,KAAI;EAGF,MAAM,YAAY,wBAAwB,SAAS;EAGnD,MAAM,iBAAiB,4BAA4B,SAAS;EAG5D,MAAM,eAAe,mBACnB,gBACA,mBAAmB,cACpB;EAGD,MAAM,cAAc,qBAAI,QAAO,aAAa;EAG5C,MAAM,WAAW,uBAAuB,mBAAmB,eAAe;EAG1E,MAAM,oBAAoB,2BACxB,mBAAmB,eACpB;EAGD,MAAM,mBAAmB,uBACvB,mBACA,aACA,SAAS,YACT,SAAS,aACV;EAGD,MAAM,YAAY;GAChB,QAAQ;GACR,kBAAkB,iBAAiB;EACpC;EACD,MAAM,kBAAkB,eAAe,UAAU;EACjD,MAAM,yBAAyB,KAAK,UAAU,gBAAgB;EAC9D,MAAM,cAAc,eACjB,WAAW,SAAS,CACpB,OAAO,wBAAwB,OAAO,CACtC,OAAO,SAAS;EAGnB,MAAM,EAAE,YAAY,GAAG,wBACrB,WACA,aACA,mBAAmB,cACpB;EAGD,MAAM,cAAc,mBAAmB,eACpC,QAAQ,gCAAgC,GAAG,CAC3C,QAAQ,8BAA8B,GAAG,CACzC,QAAQ,QAAQ,GAAG;EAGtB,MAAM,iBAAiB,SAAS,IAAI,aAAW;GAC7C,MAAM,eAAe,2BAA2B,QAAQ;GAGxD,MAAM,6BAA6B,KAAK,MAAM,uBAAuB;AAErE,UAAO;IACL,GAAG;IAGH,eAAe,CACb,EACE,cAAc,CACZ;KACE,cAAc,CACZ,EACE,GAAG,yDACJ,CACF;KACD,kBAAkB,CAChB,EACE,uBAAuB,CACrB,EACE,sBAAsB,CACpB;MACE,IAAI,CACF,EACE,GAAG,gDACJ,CACF;MACD,uBAAuB,CACrB,EACE,GAAG,sDACJ,CACF;MACD,WAAW,CACT;OACE,IAAI;OACJ,QAAQ,CACN,EACE,sBAAsB,CACpB,0BACD,EACF,CACF;OACD,SAAS,CACP,EACE,UAAU,CACR;QACE,iBAAiB,CAAC,EAAE,GAAG,YAAa,CAAC;QACrC,iBAAiB,CACf,EAAE,GAAG,SAAS,YAAa,CAC5B;QACD,kBAAkB,CAChB;SACE,gBAAgB,CACd,EACE,GAAG,SAAS,WACb,CACF;SACD,kBAAkB,CAChB,EACE,GAAG,SAAS,aACb,CACF;QACF,CACF;OACF,CACF,EACF,CACF;OACD,gBAAgB,CAAC,EAAE,GAAG,aAAc,CAAC;OACrC,YAAY,CAAC,UAAW;MACzB,CACF;KACF,CACF,EACF,CACF,EACF,CACF;IACF,CACF,EACF,CACF;IAGD,WAAW,CACT;KACE,IAAI,CACF,EACE,GAAG,sDACJ,CACF;KACD,iBAAiB,CACf,EACE,GAAG,yDACJ,CACF;IACF,CACF;GACF;EACF,EAAC;AAEF,SAAO;GACL,IAAI;GACJ,IAAI;GACJ,IAAI;GACJ,SAAS;EACV;CACF,SAAQ,OAAO;AACd,QAAM,IAAI,OACP,8BAA8B,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM,CAAC;CAEzF;AACF;;;;AAKD,MAAa,8BAA8B,CAACC,WAQrB;CACrB,MAAM,WAAW,OAAO,YAAY;CACpC,MAAM,qBACJ,OAAO,6BAA6B,OAAO,YAAY;CACzD,MAAM,YAAa,qBAAqB,OAAO,UAAW;AAE1D,QAAO;EACL,wBAAwB,OAAO;EAC/B,iBAAiB,OAAO;EACxB,WAAW,OAAO;EAClB,SAAS,OAAO;EAChB,SAAS,OAAO;EAChB,WAAW,KAAK,MAAM,YAAY,IAAI,GAAG;EACzC,2BAA2B;EAC3B,oBAAoB,qBAAqB;CAC1C;AACF;;;;AAKD,MAAa,6BAA6B,CAACC,WAUpB;CACrB,MAAM,WAAW,OAAO,YAAY;CACpC,MAAM,qBACJ,OAAO,6BAA6B,OAAO,YAAY;CACzD,MAAM,YAAY,OAAO,mBAAmB,OAAO;AAEnD,QAAO;EACL,wBAAwB,OAAO;EAC/B,iBAAiB,OAAO;EACxB,WAAW,OAAO;EAClB,SAAS,OAAO;EAChB,kBAAkB,OAAO;EACzB,iBAAiB,OAAO;EACxB,qBAAqB,OAAO;EAC5B,WAAW,KAAK,MAAM,YAAY,IAAI,GAAG;EACzC,2BAA2B;EAC3B,oBAAoB,qBAAqB;CAC1C;AACF;;;;AAKD,MAAa,yBAAyB,CACpCC,cAUG;CACH,MAAM,qBAAqB,UAAU,OACnC,CAAC,KAAK,SAAS,MAAM,KAAK,2BAC1B,EACD;CACD,MAAM,iBAAiB,UAAU,OAC/B,CAAC,KAAK,SAAS,MAAM,KAAK,WAC1B,EACD;CACD,MAAM,qBAAqB,qBAAqB;AAEhD,QAAO;EACL,oBAAoB;GAClB,oBAAoB,KAAK,MAAM,qBAAqB,IAAI,GAAG;GAC3D,oBAAoB,KAAK,MAAM,qBAAqB,IAAI,GAAG;GAC3D,eAAe,KAAK,MAAM,qBAAqB,IAAI,GAAG;EACvD;EACD,UAAU,EACR,WAAW,KAAK,MAAM,iBAAiB,IAAI,GAAG,IAC/C;CACF;AACF"}
|
|
@@ -344,14 +344,14 @@ const createSignedProperties = (certificateDigest, signingTime, issuerName, seri
|
|
|
344
344
|
* Calculates the digest over the correct structure for validator compliance.
|
|
345
345
|
*/
|
|
346
346
|
const calculateSignedPropertiesDigest = (signedProperties, useTargetWrapper = true) => {
|
|
347
|
-
let
|
|
348
|
-
if (useTargetWrapper) {
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
347
|
+
let digestObj;
|
|
348
|
+
if (useTargetWrapper) digestObj = {
|
|
349
|
+
Target: "signature",
|
|
350
|
+
SignedProperties: signedProperties.SignedProperties
|
|
351
|
+
};
|
|
352
|
+
else digestObj = signedProperties.SignedProperties;
|
|
353
|
+
const sortedDigestObj = sortObjectKeys(digestObj);
|
|
354
|
+
const signedPropertiesString = JSON.stringify(sortedDigestObj);
|
|
355
355
|
const hash = crypto.createHash("sha256");
|
|
356
356
|
hash.update(signedPropertiesString, "utf8");
|
|
357
357
|
return hash.digest("base64");
|
|
@@ -427,11 +427,18 @@ const generateCompleteDocument = (invoices, signingCredentials) => {
|
|
|
427
427
|
const certInfo = extractCertificateInfo(signingCredentials.certificatePem);
|
|
428
428
|
const certificateDigest = calculateCertificateDigest(signingCredentials.certificatePem);
|
|
429
429
|
const signedProperties = createSignedProperties(certificateDigest, signingTime, certInfo.issuerName, certInfo.serialNumber);
|
|
430
|
-
const
|
|
430
|
+
const digestObj = {
|
|
431
|
+
Target: "signature",
|
|
432
|
+
SignedProperties: signedProperties.SignedProperties
|
|
433
|
+
};
|
|
434
|
+
const sortedDigestObj = sortObjectKeys(digestObj);
|
|
435
|
+
const signedPropertiesString = JSON.stringify(sortedDigestObj);
|
|
436
|
+
const propsDigest = crypto.createHash("sha256").update(signedPropertiesString, "utf8").digest("base64");
|
|
431
437
|
const { signedInfo } = createSignedInfoAndSign(docDigest, propsDigest, signingCredentials.privateKeyPem);
|
|
432
438
|
const certificate = signingCredentials.certificatePem.replace(/-----BEGIN CERTIFICATE-----/g, "").replace(/-----END CERTIFICATE-----/g, "").replace(/\s+/g, "");
|
|
433
439
|
const signedInvoices = invoices.map((invoice) => {
|
|
434
440
|
const cleanInvoice = generateCleanInvoiceObject(invoice);
|
|
441
|
+
const parsedCanonicalSignedProps = JSON.parse(signedPropertiesString);
|
|
435
442
|
return {
|
|
436
443
|
...cleanInvoice,
|
|
437
444
|
UBLExtensions: [{ UBLExtension: [{
|
|
@@ -441,10 +448,7 @@ const generateCompleteDocument = (invoices, signingCredentials) => {
|
|
|
441
448
|
ReferencedSignatureID: [{ _: "urn:oasis:names:specification:ubl:signature:Invoice" }],
|
|
442
449
|
Signature: [{
|
|
443
450
|
Id: "signature",
|
|
444
|
-
Object: [{ QualifyingProperties: [
|
|
445
|
-
Target: "signature",
|
|
446
|
-
SignedProperties: signedProperties.SignedProperties
|
|
447
|
-
}] }],
|
|
451
|
+
Object: [{ QualifyingProperties: [parsedCanonicalSignedProps] }],
|
|
448
452
|
KeyInfo: [{ X509Data: [{
|
|
449
453
|
X509Certificate: [{ _: certificate }],
|
|
450
454
|
X509SubjectName: [{ _: certInfo.subjectName }],
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
const require_document = require('./document-
|
|
1
|
+
const require_document = require('./document-B03WWFMc.cjs');
|
|
2
2
|
|
|
3
3
|
//#region src/api/documentSubmission.ts
|
|
4
4
|
async function submitDocument(context, documents) {
|
|
@@ -89,9 +89,9 @@ async function getSubmissionStatus(context, submissionUid, pollInterval = 1e3, m
|
|
|
89
89
|
return await getSubmissionStatus(context, submissionUid, pollInterval, maxRetries - 1);
|
|
90
90
|
}
|
|
91
91
|
return {
|
|
92
|
-
status: "TimedOut",
|
|
92
|
+
status: data.overallStatus || "TimedOut",
|
|
93
93
|
documentSummary: data.documentSummary,
|
|
94
|
-
error: {
|
|
94
|
+
error: data.error ?? {
|
|
95
95
|
code: "Timeout",
|
|
96
96
|
message: "Submission timed out",
|
|
97
97
|
target: "submission",
|
|
@@ -147,4 +147,4 @@ Object.defineProperty(exports, 'submitDocument', {
|
|
|
147
147
|
return submitDocument;
|
|
148
148
|
}
|
|
149
149
|
});
|
|
150
|
-
//# sourceMappingURL=documentSubmission-
|
|
150
|
+
//# sourceMappingURL=documentSubmission-56VbFff3.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"documentSubmission-56VbFff3.cjs","names":["context: SubmissionContext","documents: AllDocumentsV1_1[]","context: Pick<SubmissionContext, 'fetch' | 'debug'>","submissionUid: string","pollInterval: number","maxRetries: number","documentUid: string","status: 'rejected' | 'cancelled'","reason: string"],"sources":["../src/api/documentSubmission.ts"],"sourcesContent":["import type {\n AllDocumentsV1_1,\n SubmissionResponse,\n SigningCredentials,\n SubmissionStatus,\n DocumentSummary,\n Fetch,\n StandardError,\n GetSubmissionResponse,\n} from '../types'\nimport { generateCompleteDocument } from '../utils/document'\n\ninterface SubmissionContext {\n fetch: Fetch\n debug: boolean\n signingCredentials: SigningCredentials\n}\n\nexport async function submitDocument(\n context: SubmissionContext,\n documents: AllDocumentsV1_1[],\n): Promise<{\n data: SubmissionResponse\n status: number\n}> {\n const { fetch, debug, signingCredentials } = context\n\n // 🔒 Hard enforcement of platform submission limits\n if (documents.length > 100) {\n throw new Error(\n 'Submission rejected: Cannot submit more than 100 documents at once',\n )\n }\n\n if (debug) {\n console.log(`📦 Preparing to submit ${documents.length} document(s)...`)\n }\n\n // For batch submission, each document must be signed and encoded separately\n // Build the submission payload according to MyInvois API format\n const crypto = await import('crypto')\n\n const submissionPayload = {\n documents: await Promise.all(\n documents.map(async doc => {\n // 1️⃣ Sign the single document (generateCompleteDocument expects an array)\n const signedDocument = generateCompleteDocument(\n [doc],\n signingCredentials,\n )\n\n // 2️⃣ Serialize\n const docJson = JSON.stringify(signedDocument)\n\n // 3️⃣ Hash\n const docHash = crypto\n .createHash('sha256')\n .update(docJson, 'utf8')\n .digest('hex')\n\n // 4️⃣ Base64 encode\n const docBase64 = Buffer.from(docJson, 'utf8').toString('base64')\n\n // 🚨 Enforce 300 KB per-document limit\n const rawSize = Buffer.byteLength(docBase64, 'base64')\n if (rawSize > 300 * 1024) {\n throw new Error(\n `Submission rejected: Document ${doc.eInvoiceCodeOrNumber} is ${rawSize} bytes – exceeds 300KB limit`,\n )\n }\n\n if (debug) {\n console.log('—'.repeat(60))\n console.log(`📄 Prepared document: ${doc.eInvoiceCodeOrNumber}`)\n console.log(` • JSON size : ${docJson.length} bytes`)\n console.log(` • Base64 size: ${docBase64.length} bytes`)\n }\n\n return {\n format: 'JSON',\n document: docBase64,\n documentHash: docHash,\n codeNumber: doc.eInvoiceCodeOrNumber,\n }\n }),\n ),\n }\n\n const payloadSize = Buffer.byteLength(JSON.stringify(submissionPayload))\n\n if (payloadSize > 5 * 1024 * 1024) {\n throw new Error(\n `Submission rejected: Payload is ${payloadSize} bytes – exceeds 5MB limit`,\n )\n }\n\n if (debug) {\n console.log('🚀 Submission payload structure:')\n console.log('- Format: JSON')\n console.log('- Documents count:', submissionPayload.documents.length)\n console.log('- Total payload size:', payloadSize, 'bytes')\n }\n\n // Submit to MyInvois API with proper headers\n const response = await fetch('/api/v1.0/documentsubmissions', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(submissionPayload),\n })\n\n const responseData = (await response.json()) as SubmissionResponse\n\n if (debug) {\n console.log(`📡 API Response status: ${response.status}`)\n\n if (responseData.rejectedDocuments?.length > 0) {\n responseData.rejectedDocuments.forEach((doc, index) => {\n console.log(` Document ${index + 1}:`, doc.invoiceCodeNumber)\n if (doc.error) {\n console.log(` Error:`, doc.error.message)\n if (doc.error.details) {\n doc.error.details.forEach((detail, detailIndex) => {\n console.log(` Detail ${detailIndex + 1}:`, detail.message)\n })\n }\n }\n })\n }\n }\n\n const data = responseData as SubmissionResponse\n\n if (debug) {\n if (response.status !== 202) {\n console.error('❌ Submission failed with status:', response.status)\n console.error('❌ Response data:', JSON.stringify(data, null, 2))\n } else {\n console.log('✅ Submission successful!')\n console.log(`📋 Submission UID: ${data.submissionUid}`)\n console.log(\n `✅ Accepted documents: ${data.acceptedDocuments?.length || 0}`,\n )\n console.log(\n `❌ Rejected documents: ${data.rejectedDocuments?.length || 0}`,\n )\n }\n }\n\n return {\n data,\n status: response.status,\n }\n}\n\nexport async function getSubmissionStatus(\n context: Pick<SubmissionContext, 'fetch' | 'debug'>,\n submissionUid: string,\n pollInterval: number = 1000,\n maxRetries: number = 10,\n): Promise<{\n status: SubmissionStatus\n documentSummary?: DocumentSummary[]\n error?: {\n code: string\n message: string | null\n target: string\n details: {\n code: string\n message: string\n target: string\n }[]\n }\n}> {\n const { fetch, debug } = context\n\n try {\n const response = await fetch(\n `/api/v1.0/documentsubmissions/${submissionUid}`,\n )\n\n const data = (await response.json()) as GetSubmissionResponse\n\n if (debug) {\n console.log('Submission:', data)\n if (data.error) {\n console.log('Submission error details:', data.error.details)\n }\n }\n\n // If we have a successful response and status is completed, return success\n if (data.overallStatus === 'Valid') {\n return {\n status: data.overallStatus,\n documentSummary: data.documentSummary,\n }\n }\n if (data.overallStatus === 'Invalid') {\n return {\n status: 'Invalid',\n documentSummary: data.documentSummary,\n }\n }\n\n // If we have retries left, continue polling for any non-completed status or errors\n if (maxRetries > 0) {\n await new Promise(resolve => setTimeout(resolve, pollInterval))\n return await getSubmissionStatus(\n context,\n submissionUid,\n pollInterval,\n maxRetries - 1,\n )\n }\n\n return {\n status: data.overallStatus || 'TimedOut',\n documentSummary: data.documentSummary,\n error:\n data.error ??\n ({\n code: 'Timeout',\n message: 'Submission timed out',\n target: 'submission',\n details: [],\n } satisfies StandardError),\n }\n } catch (error) {\n // Handle any request errors by retrying if we have retries left\n if (maxRetries > 0) {\n if (debug) {\n console.log('Request error, retrying...', error)\n }\n await new Promise(resolve => setTimeout(resolve, pollInterval))\n return await getSubmissionStatus(\n context,\n submissionUid,\n pollInterval,\n maxRetries - 1,\n )\n }\n\n // No retries left - return timeout\n return {\n status: 'TimedOut',\n documentSummary: [],\n error: {\n code: 'Timeout',\n message: 'Submission timed out after request errors',\n target: 'submission',\n details: [],\n },\n }\n }\n}\n\nexport async function performDocumentAction(\n documentUid: string,\n status: 'rejected' | 'cancelled',\n reason: string,\n): Promise<{\n uuid: string\n status: string\n error: StandardError\n}> {\n const response = await fetch(\n `/api/v1.0/documents/state/${documentUid}/state`,\n {\n method: 'POST',\n body: JSON.stringify({\n status,\n reason,\n }),\n },\n )\n\n const data = (await response.json()) as {\n uuid: string\n status: string\n error: StandardError\n }\n\n return data\n}\n"],"mappings":";;;AAkBA,eAAsB,eACpBA,SACAC,WAIC;CACD,MAAM,EAAE,gBAAO,OAAO,oBAAoB,GAAG;AAG7C,KAAI,UAAU,SAAS,IACrB,OAAM,IAAI,MACR;AAIJ,KAAI,MACF,SAAQ,KAAK,yBAAyB,UAAU,OAAO,iBAAiB;CAK1E,MAAM,SAAS,MAAM,OAAO;CAE5B,MAAM,oBAAoB,EACxB,WAAW,MAAM,QAAQ,IACvB,UAAU,IAAI,OAAM,QAAO;EAEzB,MAAM,iBAAiB,0CACrB,CAAC,GAAI,GACL,mBACD;EAGD,MAAM,UAAU,KAAK,UAAU,eAAe;EAG9C,MAAM,UAAU,OACb,WAAW,SAAS,CACpB,OAAO,SAAS,OAAO,CACvB,OAAO,MAAM;EAGhB,MAAM,YAAY,OAAO,KAAK,SAAS,OAAO,CAAC,SAAS,SAAS;EAGjE,MAAM,UAAU,OAAO,WAAW,WAAW,SAAS;AACtD,MAAI,UAAU,MAAM,KAClB,OAAM,IAAI,OACP,gCAAgC,IAAI,qBAAqB,MAAM,QAAQ;AAI5E,MAAI,OAAO;AACT,WAAQ,IAAI,IAAI,OAAO,GAAG,CAAC;AAC3B,WAAQ,KAAK,wBAAwB,IAAI,qBAAqB,EAAE;AAChE,WAAQ,KAAK,mBAAmB,QAAQ,OAAO,QAAQ;AACvD,WAAQ,KAAK,oBAAoB,UAAU,OAAO,QAAQ;EAC3D;AAED,SAAO;GACL,QAAQ;GACR,UAAU;GACV,cAAc;GACd,YAAY,IAAI;EACjB;CACF,EAAC,CACH,CACF;CAED,MAAM,cAAc,OAAO,WAAW,KAAK,UAAU,kBAAkB,CAAC;AAExE,KAAI,cAAc,IAAI,OAAO,KAC3B,OAAM,IAAI,OACP,kCAAkC,YAAY;AAInD,KAAI,OAAO;AACT,UAAQ,IAAI,mCAAmC;AAC/C,UAAQ,IAAI,iBAAiB;AAC7B,UAAQ,IAAI,sBAAsB,kBAAkB,UAAU,OAAO;AACrE,UAAQ,IAAI,yBAAyB,aAAa,QAAQ;CAC3D;CAGD,MAAM,WAAW,MAAM,QAAM,iCAAiC;EAC5D,QAAQ;EACR,SAAS,EACP,gBAAgB,mBACjB;EACD,MAAM,KAAK,UAAU,kBAAkB;CACxC,EAAC;CAEF,MAAM,eAAgB,MAAM,SAAS,MAAM;AAE3C,KAAI,OAAO;AACT,UAAQ,KAAK,0BAA0B,SAAS,OAAO,EAAE;AAEzD,MAAI,aAAa,mBAAmB,SAAS,EAC3C,cAAa,kBAAkB,QAAQ,CAAC,KAAK,UAAU;AACrD,WAAQ,KAAK,aAAa,QAAQ,EAAE,IAAI,IAAI,kBAAkB;AAC9D,OAAI,IAAI,OAAO;AACb,YAAQ,KAAK,aAAa,IAAI,MAAM,QAAQ;AAC5C,QAAI,IAAI,MAAM,QACZ,KAAI,MAAM,QAAQ,QAAQ,CAAC,QAAQ,gBAAgB;AACjD,aAAQ,KAAK,eAAe,cAAc,EAAE,IAAI,OAAO,QAAQ;IAChE,EAAC;GAEL;EACF,EAAC;CAEL;CAED,MAAM,OAAO;AAEb,KAAI,MACF,KAAI,SAAS,WAAW,KAAK;AAC3B,UAAQ,MAAM,oCAAoC,SAAS,OAAO;AAClE,UAAQ,MAAM,oBAAoB,KAAK,UAAU,MAAM,MAAM,EAAE,CAAC;CACjE,OAAM;AACL,UAAQ,IAAI,2BAA2B;AACvC,UAAQ,KAAK,qBAAqB,KAAK,cAAc,EAAE;AACvD,UAAQ,KACL,wBAAwB,KAAK,mBAAmB,UAAU,EAAE,EAC9D;AACD,UAAQ,KACL,wBAAwB,KAAK,mBAAmB,UAAU,EAAE,EAC9D;CACF;AAGH,QAAO;EACL;EACA,QAAQ,SAAS;CAClB;AACF;AAED,eAAsB,oBACpBC,SACAC,eACAC,eAAuB,KACvBC,aAAqB,IAcpB;CACD,MAAM,EAAE,gBAAO,OAAO,GAAG;AAEzB,KAAI;EACF,MAAM,WAAW,MAAM,SACpB,gCAAgC,cAAc,EAChD;EAED,MAAM,OAAQ,MAAM,SAAS,MAAM;AAEnC,MAAI,OAAO;AACT,WAAQ,IAAI,eAAe,KAAK;AAChC,OAAI,KAAK,MACP,SAAQ,IAAI,6BAA6B,KAAK,MAAM,QAAQ;EAE/D;AAGD,MAAI,KAAK,kBAAkB,QACzB,QAAO;GACL,QAAQ,KAAK;GACb,iBAAiB,KAAK;EACvB;AAEH,MAAI,KAAK,kBAAkB,UACzB,QAAO;GACL,QAAQ;GACR,iBAAiB,KAAK;EACvB;AAIH,MAAI,aAAa,GAAG;AAClB,SAAM,IAAI,QAAQ,aAAW,WAAW,SAAS,aAAa;AAC9D,UAAO,MAAM,oBACX,SACA,eACA,cACA,aAAa,EACd;EACF;AAED,SAAO;GACL,QAAQ,KAAK,iBAAiB;GAC9B,iBAAiB,KAAK;GACtB,OACE,KAAK,SACJ;IACC,MAAM;IACN,SAAS;IACT,QAAQ;IACR,SAAS,CAAE;GACZ;EACJ;CACF,SAAQ,OAAO;AAEd,MAAI,aAAa,GAAG;AAClB,OAAI,MACF,SAAQ,IAAI,8BAA8B,MAAM;AAElD,SAAM,IAAI,QAAQ,aAAW,WAAW,SAAS,aAAa;AAC9D,UAAO,MAAM,oBACX,SACA,eACA,cACA,aAAa,EACd;EACF;AAGD,SAAO;GACL,QAAQ;GACR,iBAAiB,CAAE;GACnB,OAAO;IACL,MAAM;IACN,SAAS;IACT,QAAQ;IACR,SAAS,CAAE;GACZ;EACF;CACF;AACF;AAED,eAAsB,sBACpBC,aACAC,QACAC,QAKC;CACD,MAAM,WAAW,MAAM,OACpB,4BAA4B,YAAY,SACzC;EACE,QAAQ;EACR,MAAM,KAAK,UAAU;GACnB;GACA;EACD,EAAC;CACH,EACF;CAED,MAAM,OAAQ,MAAM,SAAS,MAAM;AAMnC,QAAO;AACR"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { generateCompleteDocument } from "./document-
|
|
1
|
+
import { generateCompleteDocument } from "./document-BAUDGfZU.js";
|
|
2
2
|
|
|
3
3
|
//#region src/api/documentSubmission.ts
|
|
4
4
|
async function submitDocument(context, documents) {
|
|
@@ -89,9 +89,9 @@ async function getSubmissionStatus(context, submissionUid, pollInterval = 1e3, m
|
|
|
89
89
|
return await getSubmissionStatus(context, submissionUid, pollInterval, maxRetries - 1);
|
|
90
90
|
}
|
|
91
91
|
return {
|
|
92
|
-
status: "TimedOut",
|
|
92
|
+
status: data.overallStatus || "TimedOut",
|
|
93
93
|
documentSummary: data.documentSummary,
|
|
94
|
-
error: {
|
|
94
|
+
error: data.error ?? {
|
|
95
95
|
code: "Timeout",
|
|
96
96
|
message: "Submission timed out",
|
|
97
97
|
target: "submission",
|
package/dist/index.cjs
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
const require_documentManagement = require('./documentManagement-DQ7JEcBq.cjs');
|
|
2
2
|
require('./formatIdValue-i67o4kyD.cjs');
|
|
3
|
-
require('./document-
|
|
4
|
-
const require_documentSubmission = require('./documentSubmission-
|
|
3
|
+
require('./document-B03WWFMc.cjs');
|
|
4
|
+
const require_documentSubmission = require('./documentSubmission-56VbFff3.cjs');
|
|
5
5
|
const require_documentTypeManagement = require('./documentTypeManagement-D_-LiQVg.cjs');
|
|
6
6
|
const require_notificationManagement = require('./notificationManagement-DLBDn77E.cjs');
|
|
7
7
|
const require_platformLogin = require('./platformLogin-Ch6hFKoU.cjs');
|
package/dist/index.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { getDocument, getDocumentDetails, searchDocuments } from "./documentManagement-CIQPkmyb.js";
|
|
2
2
|
import "./formatIdValue-qTxJqj9o.js";
|
|
3
|
-
import "./document-
|
|
4
|
-
import { getSubmissionStatus, performDocumentAction, submitDocument } from "./documentSubmission-
|
|
3
|
+
import "./document-BAUDGfZU.js";
|
|
4
|
+
import { getSubmissionStatus, performDocumentAction, submitDocument } from "./documentSubmission-isM8tGm0.js";
|
|
5
5
|
import { getDocumentType, getDocumentTypeVersion, getDocumentTypes } from "./documentTypeManagement-cBtVCOY3.js";
|
|
6
6
|
import { getNotifications } from "./notificationManagement-n4Z5e-My.js";
|
|
7
7
|
import { platformLogin } from "./platformLogin-CqI9OLYP.js";
|
package/dist/index10.cjs
CHANGED
|
@@ -1,5 +1,196 @@
|
|
|
1
|
-
const require_certificate = require('./certificate-CWmfCPdt.cjs');
|
|
2
1
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
//#region src/types/currencies.d.ts
|
|
3
|
+
/**
|
|
4
|
+
* Enum representing the allowed ISO-4217 3-letter currency codes.
|
|
5
|
+
* Provides a more readable way to reference currency codes.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* const currency = CurrencyCodeEnum.MYR;
|
|
9
|
+
* console.log(currency); // Output: "MYR"
|
|
10
|
+
*/
|
|
11
|
+
let CurrencyCodeEnum = /* @__PURE__ */ function(CurrencyCodeEnum$1) {
|
|
12
|
+
CurrencyCodeEnum$1["AED"] = "AED";
|
|
13
|
+
CurrencyCodeEnum$1["AFN"] = "AFN";
|
|
14
|
+
CurrencyCodeEnum$1["ALL"] = "ALL";
|
|
15
|
+
CurrencyCodeEnum$1["AMD"] = "AMD";
|
|
16
|
+
CurrencyCodeEnum$1["ANG"] = "ANG";
|
|
17
|
+
CurrencyCodeEnum$1["AOA"] = "AOA";
|
|
18
|
+
CurrencyCodeEnum$1["ARS"] = "ARS";
|
|
19
|
+
CurrencyCodeEnum$1["AUD"] = "AUD";
|
|
20
|
+
CurrencyCodeEnum$1["AWG"] = "AWG";
|
|
21
|
+
CurrencyCodeEnum$1["AZN"] = "AZN";
|
|
22
|
+
CurrencyCodeEnum$1["BAM"] = "BAM";
|
|
23
|
+
CurrencyCodeEnum$1["BBD"] = "BBD";
|
|
24
|
+
CurrencyCodeEnum$1["BDT"] = "BDT";
|
|
25
|
+
CurrencyCodeEnum$1["BGN"] = "BGN";
|
|
26
|
+
CurrencyCodeEnum$1["BHD"] = "BHD";
|
|
27
|
+
CurrencyCodeEnum$1["BIF"] = "BIF";
|
|
28
|
+
CurrencyCodeEnum$1["BMD"] = "BMD";
|
|
29
|
+
CurrencyCodeEnum$1["BND"] = "BND";
|
|
30
|
+
CurrencyCodeEnum$1["BOB"] = "BOB";
|
|
31
|
+
CurrencyCodeEnum$1["BOV"] = "BOV";
|
|
32
|
+
CurrencyCodeEnum$1["BRL"] = "BRL";
|
|
33
|
+
CurrencyCodeEnum$1["BSD"] = "BSD";
|
|
34
|
+
CurrencyCodeEnum$1["BTN"] = "BTN";
|
|
35
|
+
CurrencyCodeEnum$1["BWP"] = "BWP";
|
|
36
|
+
CurrencyCodeEnum$1["BYN"] = "BYN";
|
|
37
|
+
CurrencyCodeEnum$1["BZD"] = "BZD";
|
|
38
|
+
CurrencyCodeEnum$1["CAD"] = "CAD";
|
|
39
|
+
CurrencyCodeEnum$1["CDF"] = "CDF";
|
|
40
|
+
CurrencyCodeEnum$1["CHE"] = "CHE";
|
|
41
|
+
CurrencyCodeEnum$1["CHF"] = "CHF";
|
|
42
|
+
CurrencyCodeEnum$1["CHW"] = "CHW";
|
|
43
|
+
CurrencyCodeEnum$1["CLF"] = "CLF";
|
|
44
|
+
CurrencyCodeEnum$1["CLP"] = "CLP";
|
|
45
|
+
CurrencyCodeEnum$1["CNY"] = "CNY";
|
|
46
|
+
CurrencyCodeEnum$1["COP"] = "COP";
|
|
47
|
+
CurrencyCodeEnum$1["COU"] = "COU";
|
|
48
|
+
CurrencyCodeEnum$1["CRC"] = "CRC";
|
|
49
|
+
CurrencyCodeEnum$1["CUC"] = "CUC";
|
|
50
|
+
CurrencyCodeEnum$1["CUP"] = "CUP";
|
|
51
|
+
CurrencyCodeEnum$1["CVE"] = "CVE";
|
|
52
|
+
CurrencyCodeEnum$1["CZK"] = "CZK";
|
|
53
|
+
CurrencyCodeEnum$1["DJF"] = "DJF";
|
|
54
|
+
CurrencyCodeEnum$1["DKK"] = "DKK";
|
|
55
|
+
CurrencyCodeEnum$1["DOP"] = "DOP";
|
|
56
|
+
CurrencyCodeEnum$1["DZD"] = "DZD";
|
|
57
|
+
CurrencyCodeEnum$1["EGP"] = "EGP";
|
|
58
|
+
CurrencyCodeEnum$1["ERN"] = "ERN";
|
|
59
|
+
CurrencyCodeEnum$1["ETB"] = "ETB";
|
|
60
|
+
CurrencyCodeEnum$1["EUR"] = "EUR";
|
|
61
|
+
CurrencyCodeEnum$1["FJD"] = "FJD";
|
|
62
|
+
CurrencyCodeEnum$1["FKP"] = "FKP";
|
|
63
|
+
CurrencyCodeEnum$1["GBP"] = "GBP";
|
|
64
|
+
CurrencyCodeEnum$1["GEL"] = "GEL";
|
|
65
|
+
CurrencyCodeEnum$1["GHS"] = "GHS";
|
|
66
|
+
CurrencyCodeEnum$1["GIP"] = "GIP";
|
|
67
|
+
CurrencyCodeEnum$1["GMD"] = "GMD";
|
|
68
|
+
CurrencyCodeEnum$1["GNF"] = "GNF";
|
|
69
|
+
CurrencyCodeEnum$1["GTQ"] = "GTQ";
|
|
70
|
+
CurrencyCodeEnum$1["GYD"] = "GYD";
|
|
71
|
+
CurrencyCodeEnum$1["HKD"] = "HKD";
|
|
72
|
+
CurrencyCodeEnum$1["HNL"] = "HNL";
|
|
73
|
+
CurrencyCodeEnum$1["HRK"] = "HRK";
|
|
74
|
+
CurrencyCodeEnum$1["HTG"] = "HTG";
|
|
75
|
+
CurrencyCodeEnum$1["HUF"] = "HUF";
|
|
76
|
+
CurrencyCodeEnum$1["IDR"] = "IDR";
|
|
77
|
+
CurrencyCodeEnum$1["ILS"] = "ILS";
|
|
78
|
+
CurrencyCodeEnum$1["INR"] = "INR";
|
|
79
|
+
CurrencyCodeEnum$1["IQD"] = "IQD";
|
|
80
|
+
CurrencyCodeEnum$1["IRR"] = "IRR";
|
|
81
|
+
CurrencyCodeEnum$1["ISK"] = "ISK";
|
|
82
|
+
CurrencyCodeEnum$1["JMD"] = "JMD";
|
|
83
|
+
CurrencyCodeEnum$1["JOD"] = "JOD";
|
|
84
|
+
CurrencyCodeEnum$1["JPY"] = "JPY";
|
|
85
|
+
CurrencyCodeEnum$1["KES"] = "KES";
|
|
86
|
+
CurrencyCodeEnum$1["KGS"] = "KGS";
|
|
87
|
+
CurrencyCodeEnum$1["KHR"] = "KHR";
|
|
88
|
+
CurrencyCodeEnum$1["KMF"] = "KMF";
|
|
89
|
+
CurrencyCodeEnum$1["KPW"] = "KPW";
|
|
90
|
+
CurrencyCodeEnum$1["KRW"] = "KRW";
|
|
91
|
+
CurrencyCodeEnum$1["KWD"] = "KWD";
|
|
92
|
+
CurrencyCodeEnum$1["KYD"] = "KYD";
|
|
93
|
+
CurrencyCodeEnum$1["KZT"] = "KZT";
|
|
94
|
+
CurrencyCodeEnum$1["LAK"] = "LAK";
|
|
95
|
+
CurrencyCodeEnum$1["LBP"] = "LBP";
|
|
96
|
+
CurrencyCodeEnum$1["LKR"] = "LKR";
|
|
97
|
+
CurrencyCodeEnum$1["LRD"] = "LRD";
|
|
98
|
+
CurrencyCodeEnum$1["LSL"] = "LSL";
|
|
99
|
+
CurrencyCodeEnum$1["LYD"] = "LYD";
|
|
100
|
+
CurrencyCodeEnum$1["MAD"] = "MAD";
|
|
101
|
+
CurrencyCodeEnum$1["MDL"] = "MDL";
|
|
102
|
+
CurrencyCodeEnum$1["MGA"] = "MGA";
|
|
103
|
+
CurrencyCodeEnum$1["MKD"] = "MKD";
|
|
104
|
+
CurrencyCodeEnum$1["MMK"] = "MMK";
|
|
105
|
+
CurrencyCodeEnum$1["MNT"] = "MNT";
|
|
106
|
+
CurrencyCodeEnum$1["MOP"] = "MOP";
|
|
107
|
+
CurrencyCodeEnum$1["MRU"] = "MRU";
|
|
108
|
+
CurrencyCodeEnum$1["MUR"] = "MUR";
|
|
109
|
+
CurrencyCodeEnum$1["MVR"] = "MVR";
|
|
110
|
+
CurrencyCodeEnum$1["MWK"] = "MWK";
|
|
111
|
+
CurrencyCodeEnum$1["MXN"] = "MXN";
|
|
112
|
+
CurrencyCodeEnum$1["MXV"] = "MXV";
|
|
113
|
+
CurrencyCodeEnum$1["MYR"] = "MYR";
|
|
114
|
+
CurrencyCodeEnum$1["MZN"] = "MZN";
|
|
115
|
+
CurrencyCodeEnum$1["NAD"] = "NAD";
|
|
116
|
+
CurrencyCodeEnum$1["NGN"] = "NGN";
|
|
117
|
+
CurrencyCodeEnum$1["NIO"] = "NIO";
|
|
118
|
+
CurrencyCodeEnum$1["NOK"] = "NOK";
|
|
119
|
+
CurrencyCodeEnum$1["NPR"] = "NPR";
|
|
120
|
+
CurrencyCodeEnum$1["NZD"] = "NZD";
|
|
121
|
+
CurrencyCodeEnum$1["OMR"] = "OMR";
|
|
122
|
+
CurrencyCodeEnum$1["PAB"] = "PAB";
|
|
123
|
+
CurrencyCodeEnum$1["PEN"] = "PEN";
|
|
124
|
+
CurrencyCodeEnum$1["PGK"] = "PGK";
|
|
125
|
+
CurrencyCodeEnum$1["PHP"] = "PHP";
|
|
126
|
+
CurrencyCodeEnum$1["PKR"] = "PKR";
|
|
127
|
+
CurrencyCodeEnum$1["PLN"] = "PLN";
|
|
128
|
+
CurrencyCodeEnum$1["PYG"] = "PYG";
|
|
129
|
+
CurrencyCodeEnum$1["QAR"] = "QAR";
|
|
130
|
+
CurrencyCodeEnum$1["RON"] = "RON";
|
|
131
|
+
CurrencyCodeEnum$1["RSD"] = "RSD";
|
|
132
|
+
CurrencyCodeEnum$1["RUB"] = "RUB";
|
|
133
|
+
CurrencyCodeEnum$1["RWF"] = "RWF";
|
|
134
|
+
CurrencyCodeEnum$1["SAR"] = "SAR";
|
|
135
|
+
CurrencyCodeEnum$1["SBD"] = "SBD";
|
|
136
|
+
CurrencyCodeEnum$1["SCR"] = "SCR";
|
|
137
|
+
CurrencyCodeEnum$1["SDG"] = "SDG";
|
|
138
|
+
CurrencyCodeEnum$1["SEK"] = "SEK";
|
|
139
|
+
CurrencyCodeEnum$1["SGD"] = "SGD";
|
|
140
|
+
CurrencyCodeEnum$1["SHP"] = "SHP";
|
|
141
|
+
CurrencyCodeEnum$1["SLL"] = "SLL";
|
|
142
|
+
CurrencyCodeEnum$1["SOS"] = "SOS";
|
|
143
|
+
CurrencyCodeEnum$1["SRD"] = "SRD";
|
|
144
|
+
CurrencyCodeEnum$1["SSP"] = "SSP";
|
|
145
|
+
CurrencyCodeEnum$1["STN"] = "STN";
|
|
146
|
+
CurrencyCodeEnum$1["SVC"] = "SVC";
|
|
147
|
+
CurrencyCodeEnum$1["SYP"] = "SYP";
|
|
148
|
+
CurrencyCodeEnum$1["SZL"] = "SZL";
|
|
149
|
+
CurrencyCodeEnum$1["THB"] = "THB";
|
|
150
|
+
CurrencyCodeEnum$1["TJS"] = "TJS";
|
|
151
|
+
CurrencyCodeEnum$1["TMT"] = "TMT";
|
|
152
|
+
CurrencyCodeEnum$1["TND"] = "TND";
|
|
153
|
+
CurrencyCodeEnum$1["TOP"] = "TOP";
|
|
154
|
+
CurrencyCodeEnum$1["TRY"] = "TRY";
|
|
155
|
+
CurrencyCodeEnum$1["TTD"] = "TTD";
|
|
156
|
+
CurrencyCodeEnum$1["TWD"] = "TWD";
|
|
157
|
+
CurrencyCodeEnum$1["TZS"] = "TZS";
|
|
158
|
+
CurrencyCodeEnum$1["UAH"] = "UAH";
|
|
159
|
+
CurrencyCodeEnum$1["UGX"] = "UGX";
|
|
160
|
+
CurrencyCodeEnum$1["USD"] = "USD";
|
|
161
|
+
CurrencyCodeEnum$1["USN"] = "USN";
|
|
162
|
+
CurrencyCodeEnum$1["UYI"] = "UYI";
|
|
163
|
+
CurrencyCodeEnum$1["UYU"] = "UYU";
|
|
164
|
+
CurrencyCodeEnum$1["UYW"] = "UYW";
|
|
165
|
+
CurrencyCodeEnum$1["UZS"] = "UZS";
|
|
166
|
+
CurrencyCodeEnum$1["VED"] = "VED";
|
|
167
|
+
CurrencyCodeEnum$1["VES"] = "VES";
|
|
168
|
+
CurrencyCodeEnum$1["VND"] = "VND";
|
|
169
|
+
CurrencyCodeEnum$1["VUV"] = "VUV";
|
|
170
|
+
CurrencyCodeEnum$1["WST"] = "WST";
|
|
171
|
+
CurrencyCodeEnum$1["XAF"] = "XAF";
|
|
172
|
+
CurrencyCodeEnum$1["XAG"] = "XAG";
|
|
173
|
+
CurrencyCodeEnum$1["XAU"] = "XAU";
|
|
174
|
+
CurrencyCodeEnum$1["XBA"] = "XBA";
|
|
175
|
+
CurrencyCodeEnum$1["XBB"] = "XBB";
|
|
176
|
+
CurrencyCodeEnum$1["XBC"] = "XBC";
|
|
177
|
+
CurrencyCodeEnum$1["XBD"] = "XBD";
|
|
178
|
+
CurrencyCodeEnum$1["XCD"] = "XCD";
|
|
179
|
+
CurrencyCodeEnum$1["XDR"] = "XDR";
|
|
180
|
+
CurrencyCodeEnum$1["XOF"] = "XOF";
|
|
181
|
+
CurrencyCodeEnum$1["XPD"] = "XPD";
|
|
182
|
+
CurrencyCodeEnum$1["XPF"] = "XPF";
|
|
183
|
+
CurrencyCodeEnum$1["XPT"] = "XPT";
|
|
184
|
+
CurrencyCodeEnum$1["XSU"] = "XSU";
|
|
185
|
+
CurrencyCodeEnum$1["XUA"] = "XUA";
|
|
186
|
+
CurrencyCodeEnum$1["XXX"] = "XXX";
|
|
187
|
+
CurrencyCodeEnum$1["YER"] = "YER";
|
|
188
|
+
CurrencyCodeEnum$1["ZAR"] = "ZAR";
|
|
189
|
+
CurrencyCodeEnum$1["ZMW"] = "ZMW";
|
|
190
|
+
CurrencyCodeEnum$1["ZWL"] = "ZWL";
|
|
191
|
+
return CurrencyCodeEnum$1;
|
|
192
|
+
}({});
|
|
193
|
+
|
|
194
|
+
//#endregion
|
|
195
|
+
exports.CurrencyCodeEnum = CurrencyCodeEnum;
|
|
196
|
+
//# sourceMappingURL=index10.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index10.cjs","names":[],"sources":["../src/types/currencies.d.ts"],"sourcesContent":["/**\n * Represents the allowed ISO-4217 3-letter currency codes.\n * Based on the documentation: https://sdk.myinvois.hasil.gov.my/codes/currencies/\n */\nexport type CurrencyCode =\n | 'AED'\n | 'AFN'\n | 'ALL'\n | 'AMD'\n | 'ANG'\n | 'AOA'\n | 'ARS'\n | 'AUD'\n | 'AWG'\n | 'AZN'\n | 'BAM'\n | 'BBD'\n | 'BDT'\n | 'BGN'\n | 'BHD'\n | 'BIF'\n | 'BMD'\n | 'BND'\n | 'BOB'\n | 'BOV'\n | 'BRL'\n | 'BSD'\n | 'BTN'\n | 'BWP'\n | 'BYN'\n | 'BZD'\n | 'CAD'\n | 'CDF'\n | 'CHE'\n | 'CHF'\n | 'CHW'\n | 'CLF'\n | 'CLP'\n | 'CNY'\n | 'COP'\n | 'COU'\n | 'CRC'\n | 'CUC'\n | 'CUP'\n | 'CVE'\n | 'CZK'\n | 'DJF'\n | 'DKK'\n | 'DOP'\n | 'DZD'\n | 'EGP'\n | 'ERN'\n | 'ETB'\n | 'EUR'\n | 'FJD'\n | 'FKP'\n | 'GBP'\n | 'GEL'\n | 'GHS'\n | 'GIP'\n | 'GMD'\n | 'GNF'\n | 'GTQ'\n | 'GYD'\n | 'HKD'\n | 'HNL'\n | 'HRK'\n | 'HTG'\n | 'HUF'\n | 'IDR'\n | 'ILS'\n | 'INR'\n | 'IQD'\n | 'IRR'\n | 'ISK'\n | 'JMD'\n | 'JOD'\n | 'JPY'\n | 'KES'\n | 'KGS'\n | 'KHR'\n | 'KMF'\n | 'KPW'\n | 'KRW'\n | 'KWD'\n | 'KYD'\n | 'KZT'\n | 'LAK'\n | 'LBP'\n | 'LKR'\n | 'LRD'\n | 'LSL'\n | 'LYD'\n | 'MAD'\n | 'MDL'\n | 'MGA'\n | 'MKD'\n | 'MMK'\n | 'MNT'\n | 'MOP'\n | 'MRU'\n | 'MUR'\n | 'MVR'\n | 'MWK'\n | 'MXN'\n | 'MXV'\n | 'MYR'\n | 'MZN'\n | 'NAD'\n | 'NGN'\n | 'NIO'\n | 'NOK'\n | 'NPR'\n | 'NZD'\n | 'OMR'\n | 'PAB'\n | 'PEN'\n | 'PGK'\n | 'PHP'\n | 'PKR'\n | 'PLN'\n | 'PYG'\n | 'QAR'\n | 'RON'\n | 'RSD'\n | 'RUB'\n | 'RWF'\n | 'SAR'\n | 'SBD'\n | 'SCR'\n | 'SDG'\n | 'SEK'\n | 'SGD'\n | 'SHP'\n | 'SLL'\n | 'SOS'\n | 'SRD'\n | 'SSP'\n | 'STN'\n | 'SVC'\n | 'SYP'\n | 'SZL'\n | 'THB'\n | 'TJS'\n | 'TMT'\n | 'TND'\n | 'TOP'\n | 'TRY'\n | 'TTD'\n | 'TWD'\n | 'TZS'\n | 'UAH'\n | 'UGX'\n | 'USD'\n | 'USN'\n | 'UYI'\n | 'UYU'\n | 'UYW'\n | 'UZS'\n | 'VED'\n | 'VES'\n | 'VND'\n | 'VUV'\n | 'WST'\n | 'XAF'\n | 'XAG'\n | 'XAU'\n | 'XBA'\n | 'XBB'\n | 'XBC'\n | 'XBD'\n | 'XCD'\n | 'XDR'\n | 'XOF'\n | 'XPD'\n | 'XPF'\n | 'XPT'\n | 'XSU'\n | 'XUA'\n | 'XXX'\n | 'YER'\n | 'ZAR'\n | 'ZMW'\n | 'ZWL'\n\n/**\n * Enum representing the allowed ISO-4217 3-letter currency codes.\n * Provides a more readable way to reference currency codes.\n *\n * @example\n * const currency = CurrencyCodeEnum.MYR;\n * console.log(currency); // Output: \"MYR\"\n */\nexport enum CurrencyCodeEnum {\n AED = 'AED',\n AFN = 'AFN',\n ALL = 'ALL',\n AMD = 'AMD',\n ANG = 'ANG',\n AOA = 'AOA',\n ARS = 'ARS',\n AUD = 'AUD',\n AWG = 'AWG',\n AZN = 'AZN',\n BAM = 'BAM',\n BBD = 'BBD',\n BDT = 'BDT',\n BGN = 'BGN',\n BHD = 'BHD',\n BIF = 'BIF',\n BMD = 'BMD',\n BND = 'BND',\n BOB = 'BOB',\n BOV = 'BOV',\n BRL = 'BRL',\n BSD = 'BSD',\n BTN = 'BTN',\n BWP = 'BWP',\n BYN = 'BYN',\n BZD = 'BZD',\n CAD = 'CAD',\n CDF = 'CDF',\n CHE = 'CHE',\n CHF = 'CHF',\n CHW = 'CHW',\n CLF = 'CLF',\n CLP = 'CLP',\n CNY = 'CNY',\n COP = 'COP',\n COU = 'COU',\n CRC = 'CRC',\n CUC = 'CUC',\n CUP = 'CUP',\n CVE = 'CVE',\n CZK = 'CZK',\n DJF = 'DJF',\n DKK = 'DKK',\n DOP = 'DOP',\n DZD = 'DZD',\n EGP = 'EGP',\n ERN = 'ERN',\n ETB = 'ETB',\n EUR = 'EUR',\n FJD = 'FJD',\n FKP = 'FKP',\n GBP = 'GBP',\n GEL = 'GEL',\n GHS = 'GHS',\n GIP = 'GIP',\n GMD = 'GMD',\n GNF = 'GNF',\n GTQ = 'GTQ',\n GYD = 'GYD',\n HKD = 'HKD',\n HNL = 'HNL',\n HRK = 'HRK',\n HTG = 'HTG',\n HUF = 'HUF',\n IDR = 'IDR',\n ILS = 'ILS',\n INR = 'INR',\n IQD = 'IQD',\n IRR = 'IRR',\n ISK = 'ISK',\n JMD = 'JMD',\n JOD = 'JOD',\n JPY = 'JPY',\n KES = 'KES',\n KGS = 'KGS',\n KHR = 'KHR',\n KMF = 'KMF',\n KPW = 'KPW',\n KRW = 'KRW',\n KWD = 'KWD',\n KYD = 'KYD',\n KZT = 'KZT',\n LAK = 'LAK',\n LBP = 'LBP',\n LKR = 'LKR',\n LRD = 'LRD',\n LSL = 'LSL',\n LYD = 'LYD',\n MAD = 'MAD',\n MDL = 'MDL',\n MGA = 'MGA',\n MKD = 'MKD',\n MMK = 'MMK',\n MNT = 'MNT',\n MOP = 'MOP',\n MRU = 'MRU',\n MUR = 'MUR',\n MVR = 'MVR',\n MWK = 'MWK',\n MXN = 'MXN',\n MXV = 'MXV',\n MYR = 'MYR',\n MZN = 'MZN',\n NAD = 'NAD',\n NGN = 'NGN',\n NIO = 'NIO',\n NOK = 'NOK',\n NPR = 'NPR',\n NZD = 'NZD',\n OMR = 'OMR',\n PAB = 'PAB',\n PEN = 'PEN',\n PGK = 'PGK',\n PHP = 'PHP',\n PKR = 'PKR',\n PLN = 'PLN',\n PYG = 'PYG',\n QAR = 'QAR',\n RON = 'RON',\n RSD = 'RSD',\n RUB = 'RUB',\n RWF = 'RWF',\n SAR = 'SAR',\n SBD = 'SBD',\n SCR = 'SCR',\n SDG = 'SDG',\n SEK = 'SEK',\n SGD = 'SGD',\n SHP = 'SHP',\n SLL = 'SLL',\n SOS = 'SOS',\n SRD = 'SRD',\n SSP = 'SSP',\n STN = 'STN',\n SVC = 'SVC',\n SYP = 'SYP',\n SZL = 'SZL',\n THB = 'THB',\n TJS = 'TJS',\n TMT = 'TMT',\n TND = 'TND',\n TOP = 'TOP',\n TRY = 'TRY',\n TTD = 'TTD',\n TWD = 'TWD',\n TZS = 'TZS',\n UAH = 'UAH',\n UGX = 'UGX',\n USD = 'USD',\n USN = 'USN',\n UYI = 'UYI',\n UYU = 'UYU',\n UYW = 'UYW',\n UZS = 'UZS',\n VED = 'VED',\n VES = 'VES',\n VND = 'VND',\n VUV = 'VUV',\n WST = 'WST',\n XAF = 'XAF',\n XAG = 'XAG',\n XAU = 'XAU',\n XBA = 'XBA',\n XBB = 'XBB',\n XBC = 'XBC',\n XBD = 'XBD',\n XCD = 'XCD',\n XDR = 'XDR',\n XOF = 'XOF',\n XPD = 'XPD',\n XPF = 'XPF',\n XPT = 'XPT',\n XSU = 'XSU',\n XUA = 'XUA',\n XXX = 'XXX',\n YER = 'YER',\n ZAR = 'ZAR',\n ZMW = 'ZMW',\n ZWL = 'ZWL',\n}\n\n/**\n * Interface representing a currency entry.\n * Contains the ISO-4217 code and the currency name.\n */\nexport interface Currency {\n code: CurrencyCode\n name: string\n}\n"],"mappings":";;;;;;;;;;AAiMA,IAAY,gEAAL;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACD"}
|
package/dist/index11.cjs
CHANGED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
require('./formatIdValue-i67o4kyD.cjs');
|
|
2
|
-
const require_document = require('./document-BWReWH1w.cjs');
|
|
3
|
-
|
|
4
|
-
exports.calculateCertificateDigest = require_document.calculateCertificateDigest;
|
|
5
|
-
exports.calculateDocumentDigest = require_document.calculateDocumentDigest;
|
|
6
|
-
exports.calculateExpectedTaxAmount = require_document.calculateExpectedTaxAmount;
|
|
7
|
-
exports.calculateInvoiceTotals = require_document.calculateInvoiceTotals;
|
|
8
|
-
exports.calculateSignedPropertiesDigest = require_document.calculateSignedPropertiesDigest;
|
|
9
|
-
exports.canonicalizeJSON = require_document.canonicalizeJSON;
|
|
10
|
-
exports.createFixedRateTaxLineItem = require_document.createFixedRateTaxLineItem;
|
|
11
|
-
exports.createPercentageTaxLineItem = require_document.createPercentageTaxLineItem;
|
|
12
|
-
exports.createSignedInfoAndSign = require_document.createSignedInfoAndSign;
|
|
13
|
-
exports.createSignedProperties = require_document.createSignedProperties;
|
|
14
|
-
exports.extractCertificateInfo = require_document.extractCertificateInfo;
|
|
15
|
-
exports.generateCleanInvoiceObject = require_document.generateCleanInvoiceObject;
|
|
16
|
-
exports.generateCleanUBLDocument = require_document.generateCleanUBLDocument;
|
|
17
|
-
exports.generateCompleteDocument = require_document.generateCompleteDocument;
|
|
18
|
-
exports.isFixedRateTax = require_document.isFixedRateTax;
|
|
19
|
-
exports.isPercentageTax = require_document.isPercentageTax;
|
|
20
|
-
exports.signDocumentString = require_document.signDocumentString;
|
|
21
|
-
exports.sortObjectKeys = require_document.sortObjectKeys;
|
|
22
|
-
exports.transformDocumentForHashing = require_document.transformDocumentForHashing;
|
package/dist/index12.cjs
CHANGED
|
@@ -1,3 +1,25 @@
|
|
|
1
|
-
const require_formatIdValue = require('./formatIdValue-i67o4kyD.cjs');
|
|
2
1
|
|
|
3
|
-
|
|
2
|
+
//#region src/types/e-invoice.d.ts
|
|
3
|
+
/**
|
|
4
|
+
* Enum representing the allowed codes for e-Invoice types with descriptive names.
|
|
5
|
+
* Provides a more readable way to reference e-Invoice types compared to using raw codes.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* const invoiceCode = EInvoiceTypeCodeEnum.Invoice;
|
|
9
|
+
* console.log(invoiceCode); // Output: "01"
|
|
10
|
+
*/
|
|
11
|
+
let EInvoiceTypeCodeEnum = /* @__PURE__ */ function(EInvoiceTypeCodeEnum$1) {
|
|
12
|
+
EInvoiceTypeCodeEnum$1["Invoice"] = "01";
|
|
13
|
+
EInvoiceTypeCodeEnum$1["CreditNote"] = "02";
|
|
14
|
+
EInvoiceTypeCodeEnum$1["DebitNote"] = "03";
|
|
15
|
+
EInvoiceTypeCodeEnum$1["RefundNote"] = "04";
|
|
16
|
+
EInvoiceTypeCodeEnum$1["SelfBilledInvoice"] = "11";
|
|
17
|
+
EInvoiceTypeCodeEnum$1["SelfBilledCreditNote"] = "12";
|
|
18
|
+
EInvoiceTypeCodeEnum$1["SelfBilledDebitNote"] = "13";
|
|
19
|
+
EInvoiceTypeCodeEnum$1["SelfBilledRefundNote"] = "14";
|
|
20
|
+
return EInvoiceTypeCodeEnum$1;
|
|
21
|
+
}({});
|
|
22
|
+
|
|
23
|
+
//#endregion
|
|
24
|
+
exports.EInvoiceTypeCodeEnum = EInvoiceTypeCodeEnum;
|
|
25
|
+
//# sourceMappingURL=index12.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"
|
|
1
|
+
{"version":3,"file":"index12.cjs","names":[],"sources":["../src/types/e-invoice.d.ts"],"sourcesContent":["/**\n * Represents the allowed codes for e-Invoice types.\n * Based on the documentation: https://sdk.myinvois.hasil.gov.my/codes/e-invoice-types/\n */\nexport type EInvoiceTypeCode =\n | '01' // Invoice\n | '02' // Credit Note\n | '03' // Debit Note\n | '04' // Refund Note\n | '11' // Self-billed Invoice\n | '12' // Self-billed Credit Note\n | '13' // Self-billed Debit Note\n | '14' // Self-billed Refund Note\n\n/**\n * Interface representing an e-Invoice type entry.\n * Contains the code and its corresponding description.\n */\nexport interface EInvoiceType {\n code: EInvoiceTypeCode\n description: string\n}\n\n/**\n * Enum representing the allowed codes for e-Invoice types with descriptive names.\n * Provides a more readable way to reference e-Invoice types compared to using raw codes.\n *\n * @example\n * const invoiceCode = EInvoiceTypeCodeEnum.Invoice;\n * console.log(invoiceCode); // Output: \"01\"\n */\nexport enum EInvoiceTypeCodeEnum {\n Invoice = '01',\n CreditNote = '02',\n DebitNote = '03',\n RefundNote = '04',\n SelfBilledInvoice = '11',\n SelfBilledCreditNote = '12',\n SelfBilledDebitNote = '13',\n SelfBilledRefundNote = '14',\n}\n"],"mappings":";;;;;;;;;;AA+BA,IAAY,wEAAL;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACD"}
|
package/dist/index13.cjs
CHANGED