AutoIt
AutoIt
XML-DSig Add EncapsulatedTimestamp when Signing
See more XML Digital Signatures Examples
Demonstrates how to add an EncapsulatedTimestamp at the time of creating an XML signature.Note: This example requires Chilkat v9.5.0.90 or greater.
Chilkat AutoIt Downloads
Local $bSuccess = False
; This example requires the Chilkat API to have been previously unlocked.
; See Global Unlock Sample for sample code.
$bSuccess = True
; Create the folllowing XML to be signed...
; Use this online tool to generate code from sample XML:
; Generate Code to Create XML
; <p:FatturaElettronica xmlns:ds="http://www.w3.org/2000/09/xmldsig#" xmlns:p="http://ivaservizi.agenziaentrate.gov.it/docs/xsd/fatture/v1.2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" versione="FPR12" xsi:schemaLocation="http://ivaservizi.agenziaentrate.gov.it/docs/xsd/fatture/v1.2 http://www.fatturapa.gov.it/export/fatturazione/sdi/fatturapa/v1.2/Schema_del_file_xml_FatturaPA_versione_1.2.xsd">
; <FatturaElettronicaHeader>
; <DatiTrasmissione>
; <IdTrasmittente>
; <IdPaese>IT</IdPaese>
; <IdCodice>01234567890</IdCodice>
; </IdTrasmittente>
; <ProgressivoInvio>00001</ProgressivoInvio>
; <FormatoTrasmissione>FPR12</FormatoTrasmissione>
; <CodiceDestinatario>0000000</CodiceDestinatario>
; <PECDestinatario>betagamma@pec.it</PECDestinatario>
; </DatiTrasmissione>
; <CedentePrestatore>
; <DatiAnagrafici>
; <IdFiscaleIVA>
; <IdPaese>IT</IdPaese>
; <IdCodice>01234567890</IdCodice>
; </IdFiscaleIVA>
; <Anagrafica>
; <Denominazione>ALPHA SRL</Denominazione>
; </Anagrafica>
; <RegimeFiscale>RF19</RegimeFiscale>
; </DatiAnagrafici>
; <Sede>
; <Indirizzo>VIALE ROMA 543</Indirizzo>
; <CAP>07100</CAP>
; <Comune>SASSARI</Comune>
; <Provincia>SS</Provincia>
; <Nazione>IT</Nazione>
; </Sede>
; </CedentePrestatore>
; <CessionarioCommittente>
; <DatiAnagrafici>
; <CodiceFiscale>09876543210</CodiceFiscale>
; <Anagrafica>
; <Denominazione>AMMINISTRAZIONE BETA</Denominazione>
; </Anagrafica>
; </DatiAnagrafici>
; <Sede>
; <Indirizzo>VIA TORINO 38-B</Indirizzo>
; <CAP>00145</CAP>
;
; <Comune>ROMA</Comune>
; <Provincia>RM</Provincia>
; <Nazione>IT</Nazione>
; </Sede>
; <StabileOrganizzazione>
; <Indirizzo>VIA CASELLE</Indirizzo>
; <NumeroCivico>4/D</NumeroCivico>
; <CAP>25027</CAP>
; <Comune>QUINZANO D'OGLIO</Comune>
; <Provincia>BS</Provincia>
; <Nazione>IT</Nazione>
; </StabileOrganizzazione>
; <RappresentanteFiscale>
; <IdFiscaleIVA>
; <IdPaese>DE</IdPaese>
; <IdCodice>DE12345</IdCodice>
; </IdFiscaleIVA>
; <Denominazione>RFCC - DENOMINAZIONE</Denominazione>
; </RappresentanteFiscale>
; </CessionarioCommittente>
; </FatturaElettronicaHeader>
; <FatturaElettronicaBody>
; <DatiGenerali>
; <DatiGeneraliDocumento>
; <TipoDocumento>TD01</TipoDocumento>
; <Divisa>EUR</Divisa>
; <Data>2022-03-03</Data>
; <Numero>123</Numero>
; <Causale>LA FATTURA FA RIFERIMENTO AD UNA OPERAZIONE AAAA</Causale>
; <Causale>SEGUE DESCRIZIONE CAUSALE NEL CASO IN CUI NON SIANO STATI SUFFICIENTI 200 CARATTERI AAAAAAAAAAA BBBBBBBBBBBBBBBBB</Causale>
; </DatiGeneraliDocumento>
; <DatiOrdineAcquisto>
; <RiferimentoNumeroLinea>1</RiferimentoNumeroLinea>
; <IdDocumento>66685</IdDocumento>
; <NumItem>1</NumItem>
; <CodiceCUP>123abc</CodiceCUP>
; <CodiceCIG>456def</CodiceCIG>
; </DatiOrdineAcquisto>
; <DatiContratto>
; <RiferimentoNumeroLinea>1</RiferimentoNumeroLinea>
; <IdDocumento>123</IdDocumento>
; <Data>2022-01-01</Data>
; <NumItem>5</NumItem>
; <CodiceCUP>123abc</CodiceCUP>
; <CodiceCIG>456def</CodiceCIG>
; </DatiContratto>
; <DatiConvenzione>
; <RiferimentoNumeroLinea>1</RiferimentoNumeroLinea>
; <IdDocumento>456</IdDocumento>
; <NumItem>5</NumItem>
; <CodiceCUP>123abc</CodiceCUP>
; <CodiceCIG>456def</CodiceCIG>
; </DatiConvenzione>
; <DatiRicezione>
; <RiferimentoNumeroLinea>1</RiferimentoNumeroLinea>
; <IdDocumento>789</IdDocumento>
; <NumItem>5</NumItem>
; <CodiceCUP>123abc</CodiceCUP>
; <CodiceCIG>456def</CodiceCIG>
; </DatiRicezione>
; <DatiTrasporto>
; <DatiAnagraficiVettore>
; <IdFiscaleIVA>
; <IdPaese>IT</IdPaese>
; <IdCodice>24681012141</IdCodice>
; </IdFiscaleIVA>
; <Anagrafica>
; <Denominazione>Trasporto spa</Denominazione>
; </Anagrafica>
; </DatiAnagraficiVettore>
; <DataOraConsegna>2022-03-01T14:26:39</DataOraConsegna>
; </DatiTrasporto>
; </DatiGenerali>
; <DatiBeniServizi>
; <DettaglioLinee>
; <NumeroLinea>1</NumeroLinea>
; <Descrizione>DESCRIZIONE DELLA FORNITURA</Descrizione>
; <Quantita>5.005</Quantita>
; <PrezzoUnitario>1.00</PrezzoUnitario>
; <PrezzoTotale>5.00</PrezzoTotale>
; <AliquotaIVA>22.00</AliquotaIVA>
; </DettaglioLinee>
; <DatiRiepilogo>
; <AliquotaIVA>22.00</AliquotaIVA>
; <ImponibileImporto>5.00</ImponibileImporto>
; <Imposta>1.10</Imposta>
; <EsigibilitaIVA>I</EsigibilitaIVA>
; </DatiRiepilogo>
; </DatiBeniServizi>
; <DatiPagamento>
; <CondizioniPagamento>TP01</CondizioniPagamento>
; <DettaglioPagamento>
; <ModalitaPagamento>MP01</ModalitaPagamento>
; <DataScadenzaPagamento>2017-02-18</DataScadenzaPagamento>
; <ImportoPagamento>6.10</ImportoPagamento>
; </DettaglioPagamento>
; </DatiPagamento>
; </FatturaElettronicaBody>
; </p:FatturaElettronica>
$oXmlToSign = ObjCreate("Chilkat.Xml")
$oXmlToSign.Tag = "p:FatturaElettronica"
$oXmlToSign.AddAttribute("xmlns:ds","http://www.w3.org/2000/09/xmldsig#")
$oXmlToSign.AddAttribute("xmlns:p","http://ivaservizi.agenziaentrate.gov.it/docs/xsd/fatture/v1.2")
$oXmlToSign.AddAttribute("xmlns:xsi","http://www.w3.org/2001/XMLSchema-instance")
$oXmlToSign.AddAttribute("versione","FPR12")
$oXmlToSign.AddAttribute("xsi:schemaLocation","http://ivaservizi.agenziaentrate.gov.it/docs/xsd/fatture/v1.2 http://www.fatturapa.gov.it/export/fatturazione/sdi/fatturapa/v1.2/Schema_del_file_xml_FatturaPA_versione_1.2.xsd")
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|DatiTrasmissione|IdTrasmittente|IdPaese","IT"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|DatiTrasmissione|IdTrasmittente|IdCodice","01234567890"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|DatiTrasmissione|ProgressivoInvio","00001"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|DatiTrasmissione|FormatoTrasmissione","FPR12"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|DatiTrasmissione|CodiceDestinatario","0000000"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|DatiTrasmissione|PECDestinatario","betagamma@pec.it"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|DatiAnagrafici|IdFiscaleIVA|IdPaese","IT"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|DatiAnagrafici|IdFiscaleIVA|IdCodice","01234567890"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|DatiAnagrafici|Anagrafica|Denominazione","ALPHA SRL"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|DatiAnagrafici|RegimeFiscale","RF19"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|Sede|Indirizzo","VIALE ROMA 543"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|Sede|CAP","07100"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|Sede|Comune","SASSARI"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|Sede|Provincia","SS"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CedentePrestatore|Sede|Nazione","IT"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|DatiAnagrafici|CodiceFiscale","09876543210"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|DatiAnagrafici|Anagrafica|Denominazione","AMMINISTRAZIONE BETA"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|Sede|Indirizzo","VIA TORINO 38-B"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|Sede|CAP","00145"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|Sede|Comune","ROMA"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|Sede|Provincia","RM"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|Sede|Nazione","IT"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|StabileOrganizzazione|Indirizzo","VIA CASELLE"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|StabileOrganizzazione|NumeroCivico","4/D"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|StabileOrganizzazione|CAP","25027"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|StabileOrganizzazione|Comune","QUINZANO D'OGLIO"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|StabileOrganizzazione|Provincia","BS"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|StabileOrganizzazione|Nazione","IT"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|RappresentanteFiscale|IdFiscaleIVA|IdPaese","DE"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|RappresentanteFiscale|IdFiscaleIVA|IdCodice","DE12345"
$oXmlToSign.UpdateChildContent "FatturaElettronicaHeader|CessionarioCommittente|RappresentanteFiscale|Denominazione","RFCC - DENOMINAZIONE"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiGeneraliDocumento|TipoDocumento","TD01"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiGeneraliDocumento|Divisa","EUR"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiGeneraliDocumento|Data","2022-03-03"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiGeneraliDocumento|Numero","123"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiGeneraliDocumento|Causale","LA FATTURA FA RIFERIMENTO AD UNA OPERAZIONE AAAA"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiGeneraliDocumento|Causale[1]","SEGUE DESCRIZIONE CAUSALE NEL CASO IN CUI NON SIANO STATI SUFFICIENTI 200 CARATTERI AAAAAAAAAAA BBBBBBBBBBBBBBBBB"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiOrdineAcquisto|RiferimentoNumeroLinea","1"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiOrdineAcquisto|IdDocumento","66685"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiOrdineAcquisto|NumItem","1"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiOrdineAcquisto|CodiceCUP","123abc"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiOrdineAcquisto|CodiceCIG","456def"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiContratto|RiferimentoNumeroLinea","1"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiContratto|IdDocumento","123"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiContratto|Data","2022-01-01"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiContratto|NumItem","5"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiContratto|CodiceCUP","123abc"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiContratto|CodiceCIG","456def"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiConvenzione|RiferimentoNumeroLinea","1"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiConvenzione|IdDocumento","456"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiConvenzione|NumItem","5"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiConvenzione|CodiceCUP","123abc"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiConvenzione|CodiceCIG","456def"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiRicezione|RiferimentoNumeroLinea","1"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiRicezione|IdDocumento","789"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiRicezione|NumItem","5"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiRicezione|CodiceCUP","123abc"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiRicezione|CodiceCIG","456def"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiTrasporto|DatiAnagraficiVettore|IdFiscaleIVA|IdPaese","IT"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiTrasporto|DatiAnagraficiVettore|IdFiscaleIVA|IdCodice","24681012141"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiTrasporto|DatiAnagraficiVettore|Anagrafica|Denominazione","Trasporto spa"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiGenerali|DatiTrasporto|DataOraConsegna","2022-03-01T14:26:39"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DettaglioLinee|NumeroLinea","1"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DettaglioLinee|Descrizione","DESCRIZIONE DELLA FORNITURA"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DettaglioLinee|Quantita","5.005"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DettaglioLinee|PrezzoUnitario","1.00"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DettaglioLinee|PrezzoTotale","5.00"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DettaglioLinee|AliquotaIVA","22.00"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DatiRiepilogo|AliquotaIVA","22.00"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DatiRiepilogo|ImponibileImporto","5.00"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DatiRiepilogo|Imposta","1.10"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiBeniServizi|DatiRiepilogo|EsigibilitaIVA","I"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiPagamento|CondizioniPagamento","TP01"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiPagamento|DettaglioPagamento|ModalitaPagamento","MP01"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiPagamento|DettaglioPagamento|DataScadenzaPagamento","2017-02-18"
$oXmlToSign.UpdateChildContent "FatturaElettronicaBody|DatiPagamento|DettaglioPagamento|ImportoPagamento","6.10"
$oGen = ObjCreate("Chilkat.XmlDSigGen")
$oGen.SigLocation = "p:FatturaElettronica"
$oGen.SigLocationMod = 0
$oGen.SigId = "signature-5580-7534-6530-8286"
$oGen.AddSignatureNamespace("xadesv1410","http://uri.etsi.org/01903/v1.4.1")
$oGen.AddSignatureNamespace("xades","http://uri.etsi.org/01903/v1.3.2#")
; xmlRoot tag = p:FatturaElettronica
; has xmlns:ds!
$oGen.SigValueId = "signature-value-5957-3819-1360-0727"
$oGen.SignedInfoCanonAlg = "EXCL_C14N"
$oGen.SignedInfoDigestMethod = "sha256"
; Set the KeyInfoId before adding references..
$oGen.KeyInfoId = "key-info-7422-1087-7530-8569"
; Create the following signed properties object to be added to the signature:
; Use this online tool to generate code from sample XML:
; Generate Code to Create XML
; <xades:QualifyingProperties Target="#signature-5580-7534-6530-8286">
; <xades:SignedProperties Id="signed-properties-1545-8800-2160-3000">
; <xades:SignedSignatureProperties>
; <xades:SigningTime>TO BE GENERATED BY CHILKAT</xades:SigningTime>
; <xades:SigningCertificate>
; <xades:Cert>
; <xades:CertDigest>
; <ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
; <ds:DigestValue>TO BE GENERATED BY CHILKAT</ds:DigestValue>
;
; </xades:CertDigest>
; <xades:IssuerSerial>
; <ds:X509IssuerName>TO BE GENERATED BY CHILKAT</ds:X509IssuerName>
; <ds:X509SerialNumber>TO BE GENERATED BY CHILKAT</ds:X509SerialNumber>
; </xades:IssuerSerial>
; </xades:Cert>
; </xades:SigningCertificate>
; </xades:SignedSignatureProperties>
; </xades:SignedProperties>
; <xades:UnsignedProperties>
; <xades:UnsignedSignatureProperties>
; <xades:SignatureTimeStamp Id="signature-timestamp-5561-8212-3316-5191">
; <ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
; <xades:EncapsulatedTimeStamp Encoding="http://uri.etsi.org/01903/v1.2.2#DER">TO BE GENERATED BY CHILKAT</xades:EncapsulatedTimeStamp>
; </xades:SignatureTimeStamp>
; </xades:UnsignedSignatureProperties>
; </xades:UnsignedProperties>
; </xades:QualifyingProperties>
; Note: Chilkat will automatically fill in the values marked as "TO BE GENERATED BY CHILKAT" at the time of signing.
; The EncapsulatedTimestamp will be automatically generated.
$oObject1 = ObjCreate("Chilkat.Xml")
$oObject1.Tag = "xades:QualifyingProperties"
$oObject1.AddAttribute("Target","#signature-5580-7534-6530-8286")
$oObject1.UpdateAttrAt("xades:SignedProperties",True,"Id","signed-properties-1545-8800-2160-3000")
$oObject1.UpdateChildContent "xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningTime","TO BE GENERATED BY CHILKAT"
$oObject1.UpdateAttrAt("xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificateV2|xades:Cert|xades:CertDigest|ds:DigestMethod",True,"Algorithm","http://www.w3.org/2001/04/xmlenc#sha256")
$oObject1.UpdateChildContent "xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificateV2|xades:Cert|xades:CertDigest|ds:DigestValue","TO BE GENERATED BY CHILKAT"
$oObject1.UpdateChildContent "xades:SignedProperties|xades:SignedSignatureProperties|xades:SigningCertificateV2|xades:Cert|xades:IssuerSerialV2","TO BE GENERATED BY CHILKAT"
$oObject1.UpdateAttrAt("xades:UnsignedProperties|xades:UnsignedSignatureProperties|xades:SignatureTimeStamp",True,"Id","signature-timestamp-5561-8212-3316-5191")
$oObject1.UpdateAttrAt("xades:UnsignedProperties|xades:UnsignedSignatureProperties|xades:SignatureTimeStamp|ds:CanonicalizationMethod",True,"Algorithm","http://www.w3.org/2001/10/xml-exc-c14n#")
$oObject1.UpdateAttrAt("xades:UnsignedProperties|xades:UnsignedSignatureProperties|xades:SignatureTimeStamp|xades:EncapsulatedTimeStamp",True,"Encoding","http://uri.etsi.org/01903/v1.2.2#DER")
$oObject1.UpdateChildContent "xades:UnsignedProperties|xades:UnsignedSignatureProperties|xades:SignatureTimeStamp|xades:EncapsulatedTimeStamp","TO BE GENERATED BY CHILKAT"
$oGen.AddObject("signature-object-8923-2359-1722-2161",$oObject1.GetXml(),"","")
; -------- Reference 1 --------
; <ds:Transforms>
; <ds:Transform Algorithm="http://www.w3.org/2002/06/xmldsig-filter2">
; <dsig-xpath:XPath xmlns:dsig-xpath="http://www.w3.org/2002/06/xmldsig-filter2" Filter="subtract">/descendant::ds:Signature</dsig-xpath:XPath>
; </ds:Transform>
; <ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
; </ds:Transforms>
$oXml1 = ObjCreate("Chilkat.Xml")
$oXml1.Tag = "ds:Transforms"
$oXml1.UpdateAttrAt("ds:Transform",True,"Algorithm","http://www.w3.org/2002/06/xmldsig-filter2")
$oXml1.UpdateAttrAt("ds:Transform|dsig-xpath:XPath",True,"xmlns:dsig-xpath","http://www.w3.org/2002/06/xmldsig-filter2")
$oXml1.UpdateAttrAt("ds:Transform|dsig-xpath:XPath",True,"Filter","subtract")
$oXml1.UpdateChildContent "ds:Transform|dsig-xpath:XPath","/descendant::ds:Signature"
$oXml1.UpdateAttrAt("ds:Transform[1]",True,"Algorithm","http://www.w3.org/2001/10/xml-exc-c14n#")
$oGen.AddSameDocRef2("","sha256",$oXml1,"")
; -------- Reference 2 --------
; <ds:Transforms>
; <ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
; </ds:Transforms>
$oXml2 = ObjCreate("Chilkat.Xml")
$oXml2.Tag = "ds:Transforms"
$oXml2.UpdateAttrAt("ds:Transform",True,"Algorithm","http://www.w3.org/2001/10/xml-exc-c14n#")
$oGen.AddObjectRef2("signed-properties-1545-8800-2160-3000","sha256",$oXml2,"http://uri.etsi.org/01903#SignedProperties")
; Provide a certificate + private key. (PFX password is test123)
$oCert = ObjCreate("Chilkat.Cert")
$bSuccess = $oCert.LoadPfxFile("qa_data/pfx/cert_test123.pfx","test123")
If ($bSuccess <> True) Then
ConsoleWrite($oCert.LastErrorText & @CRLF)
Exit
EndIf
$oGen.SetX509Cert($oCert,True)
$oGen.KeyInfoType = "X509Data+KeyValue"
$oGen.X509Type = "Certificate"
; Load XML to be signed...
$oSbXml = ObjCreate("Chilkat.StringBuilder")
$oXmlToSign.GetXmlSb($oSbXml)
$oGen.Behaviors = "IndentedSignature,OmitAlreadyDefinedSigNamespace"
; -------------------------------------------------------------------------------------------
; To have the EncapsulatedTimeStamp automatically added, we only need to do 2 things.
; 1) Add the <xades:EncapsulatedTimeStamp Encoding="http://uri.etsi.org/01903/v1.2.2#DER">TO BE GENERATED BY CHILKAT</xades:EncapsulatedTimeStamp>
; to the unsigned properties.
; 2) Specify the TSA URL (Timestamping Authority URL).
; Here we specify the TSA URL:
; -------------------------------------------------------------------------------------------
$oJsonTsa = ObjCreate("Chilkat.JsonObject")
$oJsonTsa.UpdateString("timestampToken.tsaUrl","http://timestamp.digicert.com")
$oJsonTsa.UpdateBool("timestampToken.requestTsaCert",True)
$oGen.SetTsa($oJsonTsa)
; Sign the XML...
$bSuccess = $oGen.CreateXmlDSigSb($oSbXml)
If ($bSuccess <> True) Then
ConsoleWrite($oGen.LastErrorText & @CRLF)
Exit
EndIf
; Save the signed XML to a file.
$bSuccess = $oSbXml.WriteFile("qa_output/signedXml.xml","utf-8",False)
; ----------------------------------------
; Verify the signatures we just produced...
$oVerifier = ObjCreate("Chilkat.XmlDSig")
$bSuccess = $oVerifier.LoadSignatureSb($oSbXml)
If ($bSuccess <> True) Then
ConsoleWrite($oVerifier.LastErrorText & @CRLF)
Exit
EndIf
; Add "VerifyEncapsulatedTimeStamp" to the UncommonOptions to also verify any EncapsulatedTimeStamps
$oVerifier.UncommonOptions = "VerifyEncapsulatedTimeStamp"
Local $iNumSigs = $oVerifier.NumSignatures
Local $iVerifyIdx = 0
While $iVerifyIdx < $iNumSigs
$oVerifier.Selector = $iVerifyIdx
Local $bVerified = $oVerifier.VerifySignature(True)
If ($bVerified <> True) Then
ConsoleWrite($oVerifier.LastErrorText & @CRLF)
Exit
EndIf
$iVerifyIdx = $iVerifyIdx + 1
Wend
ConsoleWrite("All signatures were successfully verified." & @CRLF)