OT. Firma electrónica Costa Rica

2,899 views
Skip to first unread message

Jose Carlos Aguilar

unread,
Jan 16, 2018, 8:11:54 AM1/16/18
to Comunidad de Visual Foxpro en Español
Les adjunto una librería para el firmado electrónico de facturas en Costa Rica acorde a lo que pide Hacienda.

Primero registrar la libreria luego ejecutar desde Foxpro de la sgt manera:
 ol = CREATEOBJECT("firmadoxadescr")

MESSAGEBOX(ol.FirmarXAdes("E:\Ivancr\", ;
                           "xml_sinfirma.xml",;
                           "E:\IvanCr\" , ;
                           "firmadocr.xml","E:\IvanCr\certificado.p12","clacecertificado"))

Espero les sea de utilidad.

Saludos
firmadocr._rar

Diana sanchez

unread,
Jan 16, 2018, 8:29:16 AM1/16/18
to Comunidad de Visual Foxpro en Español
Toca Probar para ver si cumple los requisitos de Hacienda.
Gracias por compartir

Hernan Serrano

unread,
Jan 16, 2018, 8:31:46 AM1/16/18
to publice...@googlegroups.com
Gracias Hermano, justo yo estoy trabajando en los XML, segun los requisitos de hacienda.
Pero esto ayudara montones.

Gracias de verdad.



--
Tico Support S. A.
Tel. (506)8772-6170

Hernan Serrano

unread,
Jan 18, 2018, 8:47:16 AM1/18/18
to publice...@googlegroups.com
Ante todo muchas gracias por la ayuda brindada.

Te comento que ya supere la creacion del XML.En VFP.
Anoche mismo, ahora lo que estoy haciendo es llenando con datos de prueba.
Para su posterior encriptacion y envio a site de pruebas de hacienda.

ATTE

Hernan Serrano M.

Hernan Serrano

unread,
Jan 19, 2018, 8:41:01 AM1/19/18
to publice...@googlegroups.com
Esta libreira solo realiza el firmado?
Pasa a array byte y encripta en Base64?


Daniel Sánchez

unread,
Jan 19, 2018, 9:32:06 AM1/19/18
to Comunidad de Visual Foxpro en Español
Para que pases un dato a array base 64 (en otras palabras un string de vfp), solo debes convertir en vfp con strconv, lo pasa de 64 a 32 y viceversa, revisa las opciones disponibles.

Jose Carlos Aguilar

unread,
Jan 19, 2018, 4:23:16 PM1/19/18
to Comunidad de Visual Foxpro en Español
Solo el firmado en formato XADES - EPEs, .
Saludos

Hernan Serrano

unread,
Jan 20, 2018, 10:03:41 AM1/20/18
to publice...@googlegroups.com
Cuando trato de utilizarla me indica un error en la contraseña de la red.

Eso es por que no esta instalado el certificado del cliente en la computadora?
o a que se debe el error.

Otra si se trata de instalar el certificado. Me indica error en la contraseña.

Jose Carlos Aguilar

unread,
Jan 20, 2018, 10:05:41 AM1/20/18
to Comunidad de Visual Foxpro en Español
Primero q nada la libreria debe registrarse,  no hay que instalar nada, la libreria recibe los parametros, xml, certificado y clave.
Saludos

Hernan Serrano

unread,
Jan 20, 2018, 11:04:52 AM1/20/18
to publice...@googlegroups.com
Gracias Mi error. No habia instalado el certificado..


Gracias.
Message has been deleted

Geovanni Solís Perez

unread,
Jan 22, 2018, 10:38:29 AM1/22/18
to Comunidad de Visual Foxpro en Español
Saludos Jose Carlos, una pregunta pues aca no tenemos mucha experiencia,  esta libreria de la firma es una libreria "universal" o tiene algo específico para Costa Rica que si en algún momento hacienda cambiara algun detalle debamos depender de tu ayuda para realizar el ajuste en dicha librería, o con tu experiencia con  esto de la firma, es difícil que cambie?

Muchas Gracias por tu gran aporte.

Saludos

Geovanni Solis


Geovanni Solís Perez

unread,
Jan 22, 2018, 10:44:49 AM1/22/18
to Comunidad de Visual Foxpro en Español
Compañero, nosotros no hemos probado la dll, pero, en determinado momento, para enviar un xml a un proveedor (tercero), que es una salida momentánea mientas hacemos la comunicación directa, los caracteres especiales reventaban el envio del XML,  la Ñ y la ñ y las vocales tildadas, nos dan problema al generar el XML,  por lo tanto realizamos una rutina para eliminar dichos caracteres. Lo comento por aquello que sea esto tu problema,

Saludos
Geovanni Solis
Solisoft de Costa Rica.
 

El lunes, 22 de enero de 2018, 9:30:50 (UTC-6), Gregorik Domador escribió:
Saludos, Muchas Gracias a Jose Carlos Aguilar por su ayuda con este tema de la firma que de verdad ya me tiene aturdido.

Sin embargo, el web service aun me sigue respondiendo "La Firma no es válida".

¿Ya alguien mas probó la dll de forma definitiva y puede confirmar que Hacienda acepta la firma generada?

Yo la prueba que hice fue firmar el XML con la dll de Jose Carlos, convertir a base64 el xml final resultante (probe tanto manualmente via una pagina web de conversion como tmabien desde foxpro, mismo resultado), incrustar el Base64 obtenido dentro de la estructura del JSON y enviarlo al web service y me sigue respondiendo "La firma no es válida", asi quedo mi json resultante:

{"clave": "50622011800310112345600100001010000000001100000001",
"fecha": "2018-01-22T11:15:58-0600",
"emisor": {"tipoIdentificacion": "02",
"numeroIdentificacion": "3101123456"},
"receptor": {"tipoIdentificacion": "01",
"numeroIdentificacion": "123465789"},
"comprobanteXml": "<?xml version="1.0" encoding="utf-8"?><FacturaElectronica xmlns="https://tribunet.hacienda.go.cr/docs/esquemas/2017/v4.2/facturaElectronica">
<Clave>50622011800310112345600100001010000000001100000001</Clave>
<NumeroConsecutivo>00100001010000000001</NumeroConsecutivo>
<FechaEmision>2017-11-27T11:31:35-0600</FechaEmision>
<Emisor>
<Nombre>EMPRESA DE COSTA RICA</Nombre>
<Identificacion>
<Tipo>02</Tipo>
<Numero>3101123456</Numero>
</Identificacion>
<NombreComercial>EMPRESA DE COSTA RICA</NombreComercial>
<Ubicacion>
<Provincia>2</Provincia>
<Canton>03</Canton>
<Distrito>04</Distrito>
<Barrio>00</Barrio>
<OtrasSenas>COSTA RICA</OtrasSenas>
</Ubicacion>
<Telefono>
<CodigoPais>123</CodigoPais>
<NumTelefono>456789012345</NumTelefono>
</Telefono>
<CorreoElectronico>GDOMADOR@HOTMAIL.COM</CorreoElectronico>
</Emisor>
<Receptor>
<Nombre>CLIENTE DEMO</Nombre>
<Identificacion>
<Tipo>01</Tipo>
<Numero>123465789</Numero>
</Identificacion>
<IdentificacionExtranjero>N/A</IdentificacionExtranjero>
<NombreComercial>CLIENTE DEMO</NombreComercial>
<Ubicacion>
<Provincia>1</Provincia>
<Canton>01</Canton>
<Distrito>02</Distrito>
<Barrio>02</Barrio>
<OtrasSenas>DIRECCION DEMOSTRATIVA</OtrasSenas>
</Ubicacion>
<CorreoElectronico></CorreoElectronico>
</Receptor>
<CondicionVenta>01</CondicionVenta>
<PlazoCredito></PlazoCredito>
<MedioPago>01</MedioPago>
<DetalleServicio>
<LineaDetalle>
<NumeroLinea>1</NumeroLinea>
<Codigo>
<Tipo>04</Tipo>
<Codigo>01</Codigo>
</Codigo>
<Cantidad>2.000</Cantidad>
<UnidadMedida>Und</UnidadMedida>
<Detalle>ARTICULO SERVICIO DEMOSTRATIVO IMPUESTO 01</Detalle>
<PrecioUnitario>10.00000</PrecioUnitario>
<MontoTotal>20.00000</MontoTotal>
<MontoDescuento>0.00000</MontoDescuento>
<SubTotal>20.00000</SubTotal>
<Impuesto>
<Codigo>01</Codigo>
<Tarifa>13.00000</Tarifa>
<Monto>2.60000</Monto>
</Impuesto>
<MontoTotalLinea>22.60000</MontoTotalLinea>
</LineaDetalle>
<LineaDetalle>
<NumeroLinea>2</NumeroLinea>
<Codigo>
<Tipo>04</Tipo>
<Codigo>02</Codigo>
</Codigo>
<Cantidad>3.000</Cantidad>
<UnidadMedida></UnidadMedida>
<Detalle>ARTICULO DE SERVICIO DEMOSTRATIVO IMPUESTO 02</Detalle>
<PrecioUnitario>20.00000</PrecioUnitario>
<MontoTotal>60.00000</MontoTotal>
<MontoDescuento>0.00000</MontoDescuento>
<SubTotal>60.00000</SubTotal>
<Impuesto>
<Codigo>02</Codigo>
<Tarifa>10.00000</Tarifa>
<Monto>6.00000</Monto>
</Impuesto>
<MontoTotalLinea>66.00000</MontoTotalLinea>
</LineaDetalle>
</DetalleServicio>
<ResumenFactura>
<CodigoMoneda>CRC</CodigoMoneda>
<TipoCambio>0.00</TipoCambio>
<TotalServGravados>80.00000</TotalServGravados>
<TotalServExentos>0.00000</TotalServExentos>
<TotalMercanciasGravadas>0.00000</TotalMercanciasGravadas>
<TotalMercanciasExentas>0.00000</TotalMercanciasExentas>
<TotalGravado>80.00000</TotalGravado>
<TotalExento>0.00000</TotalExento>
<TotalVenta>80.00000</TotalVenta>
<TotalDescuentos>0.00000</TotalDescuentos>
<TotalVentaNeta>80.00000</TotalVentaNeta>
<TotalImpuesto>8.60000</TotalImpuesto>
<TotalComprobante>88.60000</TotalComprobante>
</ResumenFactura>
<Normativa>
<NumeroResolucion>DGT-R-48-2016</NumeroResolucion>
<FechaResolucion>20-02-2017 13:22:22</FechaResolucion>
</Normativa>
<ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#" Id="Signature-68948f90-cc8d-44b1-b490-b279e67701da"><ds:SignedInfo><ds:CanonicalizationMethod Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315" /><ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256" /><ds:Reference Id="Reference-9883a2b9-850d-49af-a74b-b83436c2e198" URI=""><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature" /></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256" /><ds:DigestValue>iVecX0+MtY55PgZUaC8EIs+gxjpgHlnvEM0FTPXtVtk=</ds:DigestValue></ds:Reference><ds:Reference Id="ReferenceKeyInfo" URI="#KeyInfoId-Signature-68948f90-cc8d-44b1-b490-b279e67701da"><ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256" /><ds:DigestValue>/LIvEsaQ1Tb9VChcYYnihNbGOqyIneX/DTSm4bEWJT0=</ds:DigestValue></ds:Reference><ds:Reference Type="http://uri.etsi.org/01903#SignedProperties" URI="#SignedProperties-Signature-68948f90-cc8d-44b1-b490-b279e67701da"><ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256" /><ds:DigestValue>2xN4SDqybmJqgc6eOOoT5ZwPfwTnvHMXENKAFI+9Sbo=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue Id="SignatureValue-68948f90-cc8d-44b1-b490-b279e67701da">SGhS7O1dIEuc4CebE9Zq8BeO+jETzYhUQmU28+H+HgZ7iIVyPDB7ppE2o9a4Fa0H1A1pVuRL+3/taBUMDbtR8O7TSHCkHvk9djIla24oiXa3hJekTCDYa2OslmIayrrKhiZqZYH9adc6R+my0k+fDgekn+fhHRHqz64qVmsZ4OZPdFF8Ejo5EXA4mLuLVXvjb7EVMCt+FNvbgUneb7ggPzafdRERTCiSeKAe5L8vSc15sGghNfcnaqfpXI9fYiOBk4TgeZcm2r1ZA6Jmn7QEYiESj5hFzYto0/MUWDxNoqyorCXCCyQJc+jCFBiA8RSe+80TlR+O6AvCdHtK2y+81w==</ds:SignatureValue><ds:KeyInfo Id="KeyInfoId-Signature-68948f90-cc8d-44b1-b490-b279e67701da"><ds:X509Data><ds:X509Certificate>MIIFbDCCA1SgAwIBAgIGAWBGwtHjMA0GCSqGSIb3DQEBCwUAMG4xCzAJBgNVBAYTAkNSMSkwJwYDVQQKDCBNSU5JU1RFUklPIERFIEhBQ0lFTkRBIC0gU0FOREJPWDEMMAoGA1UECwwDREdUMSYwJAYDVQQDDB1DQSBQRVJTT05BIEpVUklESUNBIC0gU0FOREJPWDAeFw0xNzEyMTExODA3NDFaFw0xOTEyMTExODA3NDFaMIGyMRkwFwYDVQQFExBDUEotMy0xMDEtNzI1NjU5MQkwBwYDVQQEDAAxKTAnBgNVBCoMIFRFQ0hOT0xPR1kgQ09SRSBTT0NJRURBRCBBTk9OSU1BMQswCQYDVQQGEwJDUjEZMBcGA1UECgwQUEVSU09OQSBKVVJJRElDQTEMMAoGA1UECwwDQ1BKMSkwJwYDVQQDDCBURUNITk9MT0dZIENPUkUgU09DSUVEQUQgQU5PTklNQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKozOAu9meXw288Jwgy87cuheApLXW7Ok7gAsHBYdUjZ6hYVfN0Uegzl/9G/nWQuSIMftsFH61k5UjuERrXzqztmEvdrKs4nMTbFlfoT3yW8UQ1ImcCRHdFDio4iUSKy7P0nScfs8OHcBPuPWlLc+fk+AGquxUtNf/e0qFV0y0XsE/nx4o0ozwaT3s/4yZW4yjOebmSy7FyT3tDg9OIBvOusdprUEnBRgRaaeD2e0qUyQE0sWz8sAXC7uxrw4gg5bpbdAVvOW687z763QBNhrfJmzubrOqILJFAHmGooOOH3FDIEWXmpL4MR8pQZGrl3gmDwRhQVwneAmYwyuA1IYmUCAwEAAaOByjCBxzAfBgNVHSMEGDAWgBSsKEX4L51IXywfAJDrMsWjB1OA4TAdBgNVHQ4EFgQUbmpFDutNDlly+xz6rcSall/S8m4wCwYDVR0PBAQDAgbAMBMGA1UdJQQMMAoGCCsGAQUFBwMEMGMGCCsGAQUFBwEBBFcwVTBTBggrBgEFBQcwAoZHaHR0cHM6Ly9wa2kuY29tcHJvYmFudGVzZWxlY3Ryb25pY29zLmdvLmNyL3N0YWcvaW50ZXJtZWRpYXRlLXBqLXBlbS5jcnQwDQYJKoZIhvcNAQELBQADggIBAJEhjdVqEYWTHTK74m8a217Om1n/sz6hBrdgXoaesz9+ge25rBcwy7ggKIYwK2lZb+NlgEVcEgsUQ02JVPGHV4Iw6sWKis7oKOasWWlOOOE88OTZrDTeZ1Z4FM24HXPPcXBChnLFS1VYCLkAXT5DTWRK7++ka7qM3xx+qdPogxVqPNUNSGN7Zl48XE7EHSuJiuQexwPISMIFBYn668Va1VpiRy7JkU3jzfpO4c2GSPRHFtDyqdlNMGeF2gS+KXnE/mKFNGJesNFhaKjqXSgiKUR74ulA0uUJaS8va0e95LdpnN6G3HjUofXNxnsWFa/T7s3im1n7E5PCCUU7+90AMKTZnMCMs3oQjfVjAuzm3JVUPDFAPqnkaHLdCh7MN6PfxOsJZwOjd0zKjJZ8AYvyCbrRc1+HkQ6jqi0U1eNHxpXuKHZq4cTbV8PGZL6b7mSUG+G12hm8DWi6Z7PdHZbRrusnfzqMUxPFSlqXrr5vdDzkxTMuF8tGo01VlHmZkw9QNGDZzq+0V2A0VkZM+VckupRLMY+qkYpozYUhS5SuN4R0NH7z66jZirDgu7UCSbsovnE36S+Qv+36S0teecs1h4byUKxMtjFFCfNzmK7Nm3WWEofDCPFzy+eVWEhrQSW58yRwDrmL4PpFE2zupd+rkJpiwEkZ/iOTye3r9aJAkgjY</ds:X509Certificate></ds:X509Data><ds:KeyValue><ds:RSAKeyValue><ds:Modulus>qjM4C72Z5fDbzwnCDLzty6F4Cktdbs6TuACwcFh1SNnqFhV83RR6DOX/0b+dZC5Igx+2wUfrWTlSO4RGtfOrO2YS92sqzicxNsWV+hPfJbxRDUiZwJEd0UOKjiJRIrLs/SdJx+zw4dwE+49aUtz5+T4Aaq7FS01/97SoVXTLRewT+fHijSjPBpPez/jJlbjKM55uZLLsXJPe0OD04gG866x2mtQScFGBFpp4PZ7SpTJATSxbPywBcLu7GvDiCDlult0BW85brzvPvrdAE2Gt8mbO5us6ogskUAeYaig44fcUMgRZeakvgxHylBkauXeCYPBGFBXCd4CZjDK4DUhiZQ==</ds:Modulus><ds:Exponent>AQAB</ds:Exponent></ds:RSAKeyValue></ds:KeyValue></ds:KeyInfo><ds:Object Id="XadesObjectId-ddb02efb-5b7b-4015-ae96-400c9fdb982a"><xades:QualifyingProperties xmlns:xades="http://uri.etsi.org/01903/v1.3.2#" Id="QualifyingProperties-82c3d55d-d4b6-46d8-89ff-d90c4530bae1" Target="#Signature-68948f90-cc8d-44b1-b490-b279e67701da"><xades:SignedProperties Id="SignedProperties-Signature-68948f90-cc8d-44b1-b490-b279e67701da"><xades:SignedSignatureProperties><xades:SigningTime>2018-01-22T10:50:19-04:00</xades:SigningTime><xades:SigningCertificate><xades:Cert><xades:CertDigest><ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256" /><ds:DigestValue>KoMV0TQ8b7jruMb8U/QF5cnIpvqVcezT1NAzBDecTs0=</ds:DigestValue></xades:CertDigest><xades:IssuerSerial><ds:X509IssuerName>CN=CA PERSONA JURIDICA - SANDBOX, OU=DGT, O=MINISTERIO DE HACIENDA - SANDBOX, C=CR</ds:X509IssuerName><ds:X509SerialNumber>1513015661027</ds:X509SerialNumber></xades:IssuerSerial></xades:Cert></xades:SigningCertificate><xades:SignaturePolicyIdentifier><xades:SignaturePolicyId><xades:SigPolicyId><xades:Identifier>https://tribunet.hacienda.go.cr/docs/esquemas/2016/v4/Resolucion%20Comprobantes%20Electronicos%20%20DGT-R-48-2016.pdf</xades:Identifier><xades:Description /></xades:SigPolicyId><xades:SigPolicyHash><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1" /><ds:DigestValue>V8lVVNGDCPen6VELRD1Ja8HARFk=</ds:DigestValue></xades:SigPolicyHash></xades:SignaturePolicyId></xades:SignaturePolicyIdentifier></xades:SignedSignatureProperties><xades:SignedDataObjectProperties><xades:DataObjectFormat ObjectReference="#Reference-9883a2b9-850d-49af-a74b-b83436c2e198"><xades:MimeType>text/xml</xades:MimeType><xades:Encoding>UTF-8</xades:Encoding></xades:DataObjectFormat></xades:SignedDataObjectProperties></xades:SignedProperties></xades:QualifyingProperties></ds:Object></ds:Signature></FacturaElectronica>"}

Probe todo desde postman e igual obtengo el mismo mensaje.

Sera que tengo un error en otra parte?, en el Base64?, me causo curiosidad lo de que hay que convertirlo en arrray de bytes, pero en foxpro es lo mismo que lo haga directamente sobre el string, o estoy equivocado?.


Message has been deleted

Jose Carlos Aguilar

unread,
Jan 22, 2018, 11:38:01 AM1/22/18
to Comunidad de Visual Foxpro en Español
He revisado tu XML   y al ver el XSD, tengo la impresion que el problema son los namespace (en teoría estos influyen al momento de los digest) 
<?xml version="1.0" encoding="utf-8" standalone="no"?><FacturaElectronica xmlns="https://tribunet.hacienda.go.cr/docs/esquemas/2017/v4.2/facturaElectronica" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> Dale una revisada Saludos


Gregorik Domador

unread,
Jan 22, 2018, 12:47:13 PM1/22/18
to Comunidad de Visual Foxpro en Español
Saludos por aca nuevamente, ya logre pasar la etapa de validación de firma y si esta correcta, ya los errores que tengo son propiamente de los campos del xml de la factura.

Jose Carlos Aguilar

unread,
Jan 22, 2018, 12:57:00 PM1/22/18
to Comunidad de Visual Foxpro en Español
Bien, me alegra que les sirva.
Saludos 

Gregorik Domador

unread,
Jan 22, 2018, 2:17:25 PM1/22/18
to Comunidad de Visual Foxpro en Español
Saludos nuevamente amigo Jose Carlos, queria preguntarte si esta libreria es de libre distribución y si no esta condicionada a una fecha en particular y que luego vaya a dejar de funcionar o a solicitar algun tipo de contribucion o se bloquee o algo asi, tu sabes tipo shareware. Te lo pregunto porque yo tengo mi desarrollo echo completamente en FoxPro y solo me faltaba la firma y no lograba producirla, obviamente ahora me doy cuenta que el formato de firma que yo estaba manejando y que era el mismo que esta publicado en la documentación de Hacienda, esta malo, el formato no incluia el modulus ni el exponent ni el digest del nodo keyinfo, obviamente nunca me iba dar correcta la firma, sin embargo ya yo tengo todo mi codigo fuente listo para calcular los digests y armar la estructura de la firma, todo echo en foxpro y utilizando comandos con el archivo openssl.exe y archivos temporales con los cuales voy paso a paso y manualmente armando la firma, todo un trabajon, pero ya lo tengo listo y solo me queda tratar de agregar lo que me falta en mi firma para que sea igual a la tuya y probar a ver si me resulta, pero en dado caso de no lograr reproducir exactamente tu firma, podria yo utilizar tu libreria para distribuirla libremente con mi aplicación?. hasta ahora solo tengo dudas con los id de los nodos, de donde salen estos ids, son dinamicos y los puedo crear yo mismo o viene de alguna parte?, tambien tengos dudas con el digest del certificado nodo <certdigest> de donde sale este digest?

Jose Carlos Aguilar

unread,
Jan 22, 2018, 2:29:40 PM1/22/18
to Comunidad de Visual Foxpro en Español
Estimado Gregory, si mal no recuerdo, me parece visto por otro foro, preguntando si se puede hacer en VFP lo del la firma y te dije que era un camino muy largo pero no imposible. Pero respondiendo a tu pregunta, la librería que publique no tiene ningun tipo de restriccion pero como las entidades tributarias cambian la politicas de firma y otras cosas , si hubiera algún cambio de hecho que la librería dejaria de funcionar, razón por la cual publique el código en c# de esa manera lo podrían modificar y compilar nuevamente. En todo caso lo único q pediría es que al menos hagan referencia a este servidor.

En foxpro con openssl si se puede hacer como dices es investigar, pero yo opte por utilizar esta arternativa más facil y efectiva (Para otros paises como colombia lo tengo en C#, java y hasta en PHP puro), solo es cuestión de tiempo de investigación.
 

Saludos

Gregorik Domador

unread,
Jan 22, 2018, 3:09:11 PM1/22/18
to Comunidad de Visual Foxpro en Español
Si claro, recuerdo tu comentario de otro foros, como te comente ya yo tengo todo echo en foxpro, solo me queda probar que me den los digest e incluir los que me faltan, la opcion de usar .net no es factible para nosotros, en estos momentos lo estoy probando porque cablee por dentro algunas cosas y lo hice funcionar a modo de prueba, pero para el entorno de producción nuestra aplicacion no debe utilizar librerias externas de .net, ya que esto implica tener que incluir en la distribución final el .net framework y actualmente este no es un prerequisito oficial para la utilización de nuestro software, sencillamente por politicas de la empresa no podemos ahora pedirle a los clientes que para poder ejecutar nuestro software deben tener instalado el framework, siempre ha sido politica que mientras menos cosas externas necesite la aplicacion es mejor, repito que no es mi politica sino de la empresa y lamentameblemente debo apegarme a ella.

Greivin Guevara

unread,
Jan 23, 2018, 12:21:38 AM1/23/18
to Comunidad de Visual Foxpro en Español
Muchisimas gracias, Jose Carlos, soy un poco nuevo en este asunto; probé la libreria y me funciono aparentemente. Soy un poco nuevo en este asunto, las otras librerias que vienen para que son especificamente?

El lunes, 22 de enero de 2018, 9:54:10 (UTC-6), Jose Carlos Aguilar escribió:
Les comento, es una librería adaptada para costa Rica, la verdad, tengo mis propias herramientas de validación y los calculos de los digest y todo aparentemente esta correcto.
Son 3 dlls, pero la que envia los parametros a las otras dos es firmadocr.dll.
las otras dos librerias son las que distribuye Hacienda en su facturador gratuito,
el código fuente es el sgte:


using System;
using FirmaXadesNet;
using System.IO;
using FirmaXadesNet.Signature.Parameters;
using FirmaXadesNet.Crypto;
using System.Runtime.InteropServices;
using System.EnterpriseServices;
using System.Security.Cryptography.X509Certificates;
namespace FirmadoXadescr
{
    [ClassInterface(ClassInterfaceType.AutoDual)]
    [ProgId("firmadoXadescr")]
    /* Permitimos que esta clase pueda ser exportada como interfaz COM, para ser utilizada en entornos no .NET también. */
    [Synchronization(SynchronizationOption.Required),
    JustInTimeActivation(true),
    ObjectPooling(Enabled = true)]
    public class FirmaXML
    {
        [AutoComplete(true)]
        public string FirmarXAdes(string CRUTA, string XMLFILE, string CRUTASALIDA, string XMLFILESALIDA, string crutanombreCertificado, string cClavecertificado)
        {
            string rRRpta;
            rRRpta = "ERROR";
            string ficheroFactura = CRUTA + XMLFILE;
            XadesService xadesService = new XadesService();
            SignatureParameters parametros = new SignatureParameters();
            // Política de firma 
            parametros.SignaturePolicyInfo = new SignaturePolicyInfo();
            parametros.SignaturePolicyInfo.PolicyIdentifier = "https://tribunet.hacienda.go.cr/docs/esquemas/2016/v4/Resolucion%20Comprobantes%20Electronicos%20%20DGT-R-48-2016.pdf";             parametros.SignaturePolicyInfo.PolicyHash = "V8lVVNGDCPen6VELRD1Ja8HARFk="; 
            parametros.SignaturePolicyInfo.PolicyUri = "";

            parametros.SignatureMethod = SignatureMethod.RSAwithSHA256;
            parametros.SigningDate =new DateTime ? (DateTime.Now);
            parametros.SignaturePackaging = SignaturePackaging.ENVELOPED;

            string cnomcert = crutanombreCertificado; 
            X509Certificate2 MontCertificat = new X509Certificate2(cnomcert, cClavecertificado);
            using (parametros.Signer = new Signer(MontCertificat))
            {
                using (FileStream fs = new FileStream(ficheroFactura, FileMode.Open))
                {
                    var docFirmado = xadesService.Sign(fs, parametros);
                    docFirmado.Save(CRUTASALIDA + XMLFILESALIDA);
                    rRRpta = "OK - Archivo firmado correctamente por JCAguilar- jcagu...@gmail.com";
                 }
            }
            return rRRpta;
        }
    }
}


Saludos

Gregorik Domador

unread,
Jan 24, 2018, 9:01:02 AM1/24/18
to Comunidad de Visual Foxpro en Español
Saludos Jose Carlos, te informo que ya logre realizar la firma enteramente desde FoxPro usando OpenSSL.exe para calcular los digest y el signature value, te agradezco inmensamente tu ayuda, tu ejemplo me ayudo a darme cuenta que el formato de firma que utilizaba estaba incorrecto y a partir de la firma correcta que se genera con tu libreria logre reproducir la mía tal cual y listo, eso era lo que me faltaba, definitivamente si hubiese tenido el formato de firma correcta esto hubiese estado listo desde hace mas de un mes, pero finalmente gracias a ti lo logré, te repito, inmensamente agradecido.

Jose Carlos Aguilar

unread,
Jan 24, 2018, 9:10:51 AM1/24/18
to Comunidad de Visual Foxpro en Español
Que bueno q te haya servido, eso demuestra que con el zorro todo es posible. Solo es cuestión de tiempo e investigación. 

Saludos.

Hernan Serrano

unread,
Jan 24, 2018, 10:00:03 AM1/24/18
to publice...@googlegroups.com
Compañeros.
El XSD que publique. Genera el XML.
La mejor forma de obtener el XML, es con visual studio.
Hay varios conversores online, pero son malos.

Ahora, el programa que les publique solamente lo tienen que modiicar para utilizar el XML y listo.

<?xml version="1.0" encoding="utf-8"?>
  <Clave>Clave1</Clave>
  <NumeroConsecutivo>NumeroConsecutivo1</NumeroConsecutivo>
  <FechaEmision>1900-01-01T01:01:01-06:00</FechaEmision>
  <Emisor>
    <Nombre>Nombre1</Nombre>
    <Identificacion>
      <Tipo>01</Tipo>
      <Numero>Numero1</Numero>
    </Identificacion>
    <NombreComercial>NombreComercial1</NombreComercial>
    <Ubicacion>
      <Provincia>1</Provincia>
      <Canton>C1</Canton>
      <Distrito>D1</Distrito>
      <Barrio>B1</Barrio>
      <OtrasSenas>OtrasSenas1</OtrasSenas>
    </Ubicacion>
    <Telefono xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:nil="true" />
    <Fax xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:nil="true" />
    <CorreoElectronico>CorreoElectronico1</CorreoElectronico>
  </Emisor>
  <Receptor>
    <Nombre>Nombre1</Nombre>
    <Identificacion>
      <Tipo>01</Tipo>
      <Numero>Numero1</Numero>
    </Identificacion>
    <IdentificacionExtranjero>IdentificacionExtra1</IdentificacionExtranjero>
    <NombreComercial>NombreComercial1</NombreComercial>
    <Ubicacion>
      <Provincia>1</Provincia>
      <Canton>C1</Canton>
      <Distrito>D1</Distrito>
      <Barrio>B1</Barrio>
      <OtrasSenas>OtrasSenas1</OtrasSenas>
    </Ubicacion>
    <Telefono>
      <CodigoPais>1</CodigoPais>
      <NumTelefono>1</NumTelefono>
    </Telefono>
    <Fax>
      <CodigoPais>1</CodigoPais>
      <NumTelefono>1</NumTelefono>
    </Fax>
    <CorreoElectronico>CorreoElectronico1</CorreoElectronico>
  </Receptor>
  <CondicionVenta>01</CondicionVenta>
  <PlazoCredito>PlazoCred1</PlazoCredito>
  <MedioPago>01</MedioPago>
  <MedioPago>02</MedioPago>
  <MedioPago>03</MedioPago>
  <DetalleServicio>
    <LineaDetalle>
      <NumeroLinea>1</NumeroLinea>
      <Codigo>
        <Tipo>01</Tipo>
        <Codigo>Codigo1</Codigo>
      </Codigo>
      <Codigo>
        <Tipo>02</Tipo>
        <Codigo>Codigo2</Codigo>
      </Codigo>
      <Codigo>
        <Tipo>03</Tipo>
        <Codigo>Codigo3</Codigo>
      </Codigo>
      <Cantidad>1</Cantidad>
      <UnidadMedida>Sp</UnidadMedida>
      <UnidadMedidaComercial>UnidadMedidaComerci1</UnidadMedidaComercial>
      <Detalle>Detalle1</Detalle>
      <PrecioUnitario>0</PrecioUnitario>
      <MontoTotal>0</MontoTotal>
      <MontoDescuento>0</MontoDescuento>
      <NaturalezaDescuento>NaturalezaDescuento1</NaturalezaDescuento>
      <SubTotal>0</SubTotal>
      <Impuesto>
        <Codigo>01</Codigo>
        <Tarifa>1</Tarifa>
        <Monto>0</Monto>
        <Exoneracion>
          <TipoDocumento>01</TipoDocumento>
          <NumeroDocumento>NumeroDocumento1</NumeroDocumento>
          <NombreInstitucion>NombreInstitucion1</NombreInstitucion>
          <FechaEmision>1900-01-01T01:01:01-06:00</FechaEmision>
          <MontoImpuesto>0</MontoImpuesto>
          <PorcentajeCompra>1</PorcentajeCompra>
        </Exoneracion>
      </Impuesto>
      <Impuesto>
        <Codigo>02</Codigo>
        <Tarifa>-99.99</Tarifa>
        <Monto>-10000000000000</Monto>
        <Exoneracion>
          <TipoDocumento>02</TipoDocumento>
          <NumeroDocumento>NumeroDocumento2</NumeroDocumento>
          <NombreInstitucion>NombreInstitucion2</NombreInstitucion>
          <FechaEmision>0001-01-01T00:00:00-06:00</FechaEmision>
          <MontoImpuesto>-10000000000000</MontoImpuesto>
          <PorcentajeCompra>-999</PorcentajeCompra>
        </Exoneracion>
      </Impuesto>
      <Impuesto>
        <Codigo>03</Codigo>
        <Tarifa>99.99</Tarifa>
        <Monto>10000000000000</Monto>
        <Exoneracion>
          <TipoDocumento>03</TipoDocumento>
          <NumeroDocumento>NumeroDocumento3</NumeroDocumento>
          <NombreInstitucion>NombreInstitucion3</NombreInstitucion>
          <FechaEmision>9999-12-31T23:59:59.9999999-06:00</FechaEmision>
          <MontoImpuesto>10000000000000</MontoImpuesto>
          <PorcentajeCompra>999</PorcentajeCompra>
        </Exoneracion>
      </Impuesto>
      <MontoTotalLinea>0</MontoTotalLinea>
    </LineaDetalle>
    <LineaDetalle>
      <NumeroLinea>79228162514264337593543950335</NumeroLinea>
      <Codigo>
        <Tipo>04</Tipo>
        <Codigo>Codigo4</Codigo>
      </Codigo>
      <Codigo>
        <Tipo>99</Tipo>
        <Codigo>Codigo5</Codigo>
      </Codigo>
      <Codigo>
        <Tipo>01</Tipo>
        <Codigo>Codigo6</Codigo>
      </Codigo>
      <Cantidad>-10000000000000</Cantidad>
      <UnidadMedida>m</UnidadMedida>
      <UnidadMedidaComercial>UnidadMedidaComerci2</UnidadMedidaComercial>
      <Detalle>Detalle2</Detalle>
      <PrecioUnitario>-10000000000000</PrecioUnitario>
      <MontoTotal>-10000000000000</MontoTotal>
      <MontoDescuento>-10000000000000</MontoDescuento>
      <NaturalezaDescuento>NaturalezaDescuento2</NaturalezaDescuento>
      <SubTotal>-10000000000000</SubTotal>
      <Impuesto>
        <Codigo>04</Codigo>
        <Tarifa>0.99</Tarifa>
        <Monto>-0.0000000000001</Monto>
        <Exoneracion>
          <TipoDocumento>04</TipoDocumento>
          <NumeroDocumento>NumeroDocumento4</NumeroDocumento>
          <NombreInstitucion>NombreInstitucion4</NombreInstitucion>
          <FechaEmision>1899-11-30T01:01:01-06:00</FechaEmision>
          <MontoImpuesto>-0.0000000000001</MontoImpuesto>
          <PorcentajeCompra>0</PorcentajeCompra>
        </Exoneracion>
      </Impuesto>
      <Impuesto>
        <Codigo>05</Codigo>
        <Tarifa>1.01</Tarifa>
        <Monto>0.0000000000001</Monto>
        <Exoneracion>
          <TipoDocumento>05</TipoDocumento>
          <NumeroDocumento>NumeroDocumento5</NumeroDocumento>
          <NombreInstitucion>NombreInstitucion5</NombreInstitucion>
          <FechaEmision>1900-02-02T01:01:01-06:00</FechaEmision>
          <MontoImpuesto>0.0000000000001</MontoImpuesto>
          <PorcentajeCompra>2</PorcentajeCompra>
        </Exoneracion>
      </Impuesto>
      <Impuesto>
        <Codigo>06</Codigo>
        <Tarifa>-99.98</Tarifa>
        <Monto>-9999999999999.9999999999999</Monto>
        <Exoneracion>
          <TipoDocumento>99</TipoDocumento>
          <NumeroDocumento>NumeroDocumento6</NumeroDocumento>
          <NombreInstitucion>NombreInstitucion6</NombreInstitucion>
          <FechaEmision>0001-02-02T00:00:00-06:00</FechaEmision>
          <MontoImpuesto>-9999999999999.9999999999999</MontoImpuesto>
          <PorcentajeCompra>-998</PorcentajeCompra>
        </Exoneracion>
      </Impuesto>
      <MontoTotalLinea>-10000000000000</MontoTotalLinea>
    </LineaDetalle>
    <LineaDetalle>
      <NumeroLinea>2</NumeroLinea>
      <Codigo>
        <Tipo>02</Tipo>
        <Codigo>Codigo7</Codigo>
      </Codigo>
      <Codigo>
        <Tipo>03</Tipo>
        <Codigo>Codigo8</Codigo>
      </Codigo>
      <Codigo>
        <Tipo>04</Tipo>
        <Codigo>Codigo9</Codigo>
      </Codigo>
      <Cantidad>10000000000000</Cantidad>
      <UnidadMedida>kg</UnidadMedida>
      <UnidadMedidaComercial>UnidadMedidaComerci3</UnidadMedidaComercial>
      <Detalle>Detalle3</Detalle>
      <PrecioUnitario>10000000000000</PrecioUnitario>
      <MontoTotal>10000000000000</MontoTotal>
      <MontoDescuento>10000000000000</MontoDescuento>
      <NaturalezaDescuento>NaturalezaDescuento3</NaturalezaDescuento>
      <SubTotal>10000000000000</SubTotal>
      <Impuesto>
        <Codigo>07</Codigo>
        <Tarifa>99.98</Tarifa>
        <Monto>9999999999999.9999999999999</Monto>
        <Exoneracion>
          <TipoDocumento>01</TipoDocumento>
          <NumeroDocumento>NumeroDocumento7</NumeroDocumento>
          <NombreInstitucion>NombreInstitucion7</NombreInstitucion>
          <FechaEmision>9999-11-29T23:59:59.9999999-06:00</FechaEmision>
          <MontoImpuesto>9999999999999.9999999999999</MontoImpuesto>
          <PorcentajeCompra>998</PorcentajeCompra>
        </Exoneracion>
      </Impuesto>
      <Impuesto>
        <Codigo>08</Codigo>
        <Tarifa>0.98</Tarifa>
        <Monto>-0.0000000000002</Monto>
        <Exoneracion>
          <TipoDocumento>02</TipoDocumento>
          <NumeroDocumento>NumeroDocumento8</NumeroDocumento>
          <NombreInstitucion>NombreInstitucion8</NombreInstitucion>
          <FechaEmision>1899-10-29T01:01:01-06:00</FechaEmision>
          <MontoImpuesto>-0.0000000000002</MontoImpuesto>
          <PorcentajeCompra>-1</PorcentajeCompra>
        </Exoneracion>
      </Impuesto>
      <Impuesto>
        <Codigo>09</Codigo>
        <Tarifa>1.02</Tarifa>
        <Monto>0.0000000000002</Monto>
        <Exoneracion>
          <TipoDocumento>03</TipoDocumento>
          <NumeroDocumento>NumeroDocumento9</NumeroDocumento>
          <NombreInstitucion>NombreInstitucion9</NombreInstitucion>
          <FechaEmision>1900-03-06T01:01:01-06:00</FechaEmision>
          <MontoImpuesto>0.0000000000002</MontoImpuesto>
          <PorcentajeCompra>3</PorcentajeCompra>
        </Exoneracion>
      </Impuesto>
      <MontoTotalLinea>10000000000000</MontoTotalLinea>
    </LineaDetalle>
  </DetalleServicio>
  <ResumenFactura>
    <CodigoMoneda>AED</CodigoMoneda>
    <TipoCambio>0</TipoCambio>
    <TotalServGravados>0</TotalServGravados>
    <TotalServExentos>0</TotalServExentos>
    <TotalMercanciasGravadas>0</TotalMercanciasGravadas>
    <TotalMercanciasExentas>0</TotalMercanciasExentas>
    <TotalGravado>0</TotalGravado>
    <TotalExento>0</TotalExento>
    <TotalVenta>0</TotalVenta>
    <TotalDescuentos>0</TotalDescuentos>
    <TotalVentaNeta>0</TotalVentaNeta>
    <TotalImpuesto>0</TotalImpuesto>
    <TotalComprobante>0</TotalComprobante>
  </ResumenFactura>
  <InformacionReferencia>
    <TipoDoc>01</TipoDoc>
    <Numero>Numero1</Numero>
    <FechaEmision>1900-01-01T01:01:01-06:00</FechaEmision>
    <Codigo>01</Codigo>
    <Razon>Razon1</Razon>
  </InformacionReferencia>
  <InformacionReferencia>
    <TipoDoc>02</TipoDoc>
    <Numero>Numero2</Numero>
    <FechaEmision>0001-01-01T00:00:00-06:00</FechaEmision>
    <Codigo>02</Codigo>
    <Razon>Razon2</Razon>
  </InformacionReferencia>
  <InformacionReferencia>
    <TipoDoc>03</TipoDoc>
    <Numero>Numero3</Numero>
    <FechaEmision>9999-12-31T23:59:59.9999999-06:00</FechaEmision>
    <Codigo>03</Codigo>
    <Razon>Razon3</Razon>
  </InformacionReferencia>
  <Normativa>
    <NumeroResolucion>NumeroResolu1</NumeroResolucion>
    <FechaResolucion>FechaResolucion1</FechaResolucion>
  </Normativa>
  <Otros>
    <OtroTexto codigo="codigo1">OtroTexto1</OtroTexto>
    <OtroTexto codigo="codigo2">OtroTexto2</OtroTexto>
    <OtroTexto codigo="codigo3">OtroTexto3</OtroTexto>
    <OtroContenido codigo="codigo1">
      <any_element xmlns="otherNS">anyType</any_element>
    </OtroContenido>
    <OtroContenido codigo="codigo2">
      <any_element xmlns="otherNS">anyType</any_element>
    </OtroContenido>
    <OtroContenido codigo="codigo3">
      <any_element xmlns="otherNS">anyType</any_element>
    </OtroContenido>
  </Otros>
  <Signature Id="ID1" xmlns="http://www.w3.org/2000/09/xmldsig#">
    <SignedInfo Id="ID2">
      <CanonicalizationMethod Algorithm="http://uri1">text</CanonicalizationMethod>
      <SignatureMethod Algorithm="http://uri1">text<HMACOutputLength>1</HMACOutputLength></SignatureMethod>
      <Reference Id="ID3" URI="http://uri1" Type="http://uri1">
        <Transforms>
          <Transform Algorithm="http://uri1">text<any_element xmlns="otherNS">anyType</any_element><XPath>XPath1</XPath><any_element xmlns="otherNS">anyType</any_element></Transform>
          <Transform Algorithm="http://uri2">text<any_element xmlns="otherNS">anyType</any_element><XPath>XPath2</XPath><any_element xmlns="otherNS">anyType</any_element></Transform>
          <Transform Algorithm="http://uri3">text<any_element xmlns="otherNS">anyType</any_element><XPath>XPath3</XPath><any_element xmlns="otherNS">anyType</any_element></Transform>
        </Transforms>
        <DigestMethod Algorithm="http://uri1">text</DigestMethod>
        <DigestValue>AAECAwQFBgcICQoLDA0ODw==</DigestValue>
      </Reference>
      <Reference Id="ID4" URI="http://uri2" Type="http://uri2">
        <Transforms>
          <Transform Algorithm="http://uri4">text<any_element xmlns="otherNS">anyType</any_element><XPath>XPath4</XPath><any_element xmlns="otherNS">anyType</any_element></Transform>
          <Transform Algorithm="http://uri5">text<any_element xmlns="otherNS">anyType</any_element><XPath>XPath5</XPath><any_element xmlns="otherNS">anyType</any_element></Transform>
          <Transform Algorithm="http://uri6">text<any_element xmlns="otherNS">anyType</any_element><XPath>XPath6</XPath><any_element xmlns="otherNS">anyType</any_element></Transform>
        </Transforms>
        <DigestMethod Algorithm="http://uri2">text</DigestMethod>
        <DigestValue>AAECAwQFBgcICQoLDA0ODw==</DigestValue>
      </Reference>
      <Reference Id="ID5" URI="http://uri3" Type="http://uri3">
        <Transforms>
          <Transform Algorithm="http://uri7">text<any_element xmlns="otherNS">anyType</any_element><XPath>XPath7</XPath><any_element xmlns="otherNS">anyType</any_element></Transform>
          <Transform Algorithm="http://uri8">text<any_element xmlns="otherNS">anyType</any_element><XPath>XPath8</XPath><any_element xmlns="otherNS">anyType</any_element></Transform>
          <Transform Algorithm="http://uri9">text<any_element xmlns="otherNS">anyType</any_element><XPath>XPath9</XPath><any_element xmlns="otherNS">anyType</any_element></Transform>
        </Transforms>
        <DigestMethod Algorithm="http://uri3">text</DigestMethod>
        <DigestValue>AAECAwQFBgcICQoLDA0ODw==</DigestValue>
      </Reference>
    </SignedInfo>
    <SignatureValue Id="ID6">AAECAwQFBgcICQoLDA0ODw==</SignatureValue>
    <KeyInfo Id="ID7">text<KeyName>KeyName1</KeyName><KeyValue>text<DSAKeyValue><P>AAECAwQFBgcICQoLDA0ODw==</P><Q>AAECAwQFBgcICQoLDA0ODw==</Q><G>AAECAwQFBgcICQoLDA0ODw==</G><Y>AAECAwQFBgcICQoLDA0ODw==</Y><J>AAECAwQFBgcICQoLDA0ODw==</J><Seed>AAECAwQFBgcICQoLDA0ODw==</Seed><PgenCounter>AAECAwQFBgcICQoLDA0ODw==</PgenCounter></DSAKeyValue></KeyValue><RetrievalMethod URI="http://uri1" Type="http://uri1" /></KeyInfo>
    <Object Id="ID8" MimeType="MimeType1" Encoding="http://uri1">text<any_element xmlns="https://tribunet.hacienda.go.cr/docs/esquemas/2017/v4.2/facturaElectronica">anyType</any_element><any_element xmlns="https://tribunet.hacienda.go.cr/docs/esquemas/2017/v4.2/facturaElectronica">anyType</any_element><any_element xmlns="https://tribunet.hacienda.go.cr/docs/esquemas/2017/v4.2/facturaElectronica">anyType</any_element></Object>
    <Object Id="ID9" MimeType="MimeType2" Encoding="http://uri2">text<any_element xmlns="https://tribunet.hacienda.go.cr/docs/esquemas/2017/v4.2/facturaElectronica">anyType</any_element><any_element xmlns="https://tribunet.hacienda.go.cr/docs/esquemas/2017/v4.2/facturaElectronica">anyType</any_element><any_element xmlns="https://tribunet.hacienda.go.cr/docs/esquemas/2017/v4.2/facturaElectronica">anyType</any_element></Object>
    <Object Id="ID10" MimeType="MimeType3" Encoding="http://uri3">text<any_element xmlns="https://tribunet.hacienda.go.cr/docs/esquemas/2017/v4.2/facturaElectronica">anyType</any_element><any_element xmlns="https://tribunet.hacienda.go.cr/docs/esquemas/2017/v4.2/facturaElectronica">anyType</any_element><any_element xmlns="https://tribunet.hacienda.go.cr/docs/esquemas/2017/v4.2/facturaElectronica">anyType</any_element></Object>
  </Signature>
</FacturaElectronica>
    …
Ese es el xml generado con Visual Studio. Es el de la factura.
Compañeros. Ya consequi un proyecto funcional para la firma del XML. Esta probado, creo que la biblioteca que anda por ahi. No es funcional.
 Este es el link.
Para bajar el proyecto esta en c sharp

Hernan Serrano

unread,
Jan 24, 2018, 10:15:05 AM1/24/18
to publice...@googlegroups.com
Tienes un ejemplo del codigo. Que puedas compartir.

El 24 de enero de 2018, 8:01, Gregorik Domador <gregori...@gmail.com> escribió:
Saludos Jose Carlos, te informo que ya logre realizar la firma enteramente desde FoxPro usando OpenSSL.exe para calcular los digest y el signature value, te agradezco inmensamente tu ayuda, tu ejemplo me ayudo a darme cuenta que el formato de firma que utilizaba estaba incorrecto y a partir de la firma correcta que se genera con tu libreria logre reproducir la mía tal cual y listo, eso era lo que me faltaba, definitivamente si hubiese tenido el formato de firma correcta esto hubiese estado listo desde hace mas de un mes, pero finalmente gracias a ti lo logré, te repito, inmensamente agradecido.



Hernan Serrano

unread,
Jan 24, 2018, 10:45:51 AM1/24/18
to publice...@googlegroups.com
Otra pregunta Gregorik. Ya enviastes los documentos al site de pruebas de Tributacion y te dieron el visto bueno.

"Una vez firmado el documento no se puede agregar nada más al mismo porque genera espacios en blanco, hay que firmarlo, encriptarlo y enviarlo de una vez"
Esto es lo que me recomiendan unos amigos que ya lo han logrado.

Gregorik Domador

unread,
Jan 24, 2018, 12:32:24 PM1/24/18
to Comunidad de Visual Foxpro en Español
Si, ya obtengo status de "Accepted" y el xml de respuesta firmado por hacienda.

Oscar Melendez

unread,
Jan 24, 2018, 12:36:11 PM1/24/18
to publice...@googlegroups.com

Gregorik Domador podes compartirlo??

Gregorik Domador

unread,
Jan 24, 2018, 12:53:20 PM1/24/18
to Comunidad de Visual Foxpro en Español
Mmmmm, dejame ver las implicaciones del caso, porque trabajo para una casa de software y ellos tienen el derecho de autor sobre todo lo que hago, podria verme yo en un problema por compartir ese codigo publicamente ya que dentro del mismo tambien se usan rutinas que no fueron echas por mi y que son propiedad tambien de la empresa, es decir cosas echas por otros programadores de la empresa a lo largo de los años.

Oscar Melendez

unread,
Jan 24, 2018, 1:01:16 PM1/24/18
to publice...@googlegroups.com
yo lo que ocupo practicamente es el envio del xml y la respuesta del servidor lo demas me las puedo apañar

Hernan Serrano

unread,
Jan 24, 2018, 1:25:06 PM1/24/18
to publice...@googlegroups.com
Yo termino lo del xml. Y estoy trabajando con el envio a hacienda. Esta semana espero este listo.

Voy a apurar el paso..

Hernan Serrano

unread,
Jan 24, 2018, 1:26:02 PM1/24/18
to publice...@googlegroups.com
Gregorik, entiendo las implicaciones del caso. Tranquilo. Pero es bueno saber que desde Fox, Todo se puede.


Gregorik Domador

unread,
Jan 24, 2018, 1:46:57 PM1/24/18
to Comunidad de Visual Foxpro en Español
Te puedo colaborar con esto, pero es solo un granito de arena de todo lo que hay que hacer, supongo que ya tienen token, clave y xml, listo al igual que una funcion que te arme el json del request, en fin son tantas cosas...

    **Función que ejecuta y consume el servicio del API
    *---------------------------------------------------------
    Function EjecutaAPI(pTipoRequest, pRequest, pAuthorization, pBody)
        *pTipoRequest   : Token=1,Recepcion=2,Recepcion/Clave=3,Comprobantes=4,Comprobantes/Clave=5
        *pRequest        : Se recibe por referencia el objeto HTTP que se obtuvo en CreaRequest
        *pAuthorization    : El token obtenido con la funcion BuscaToken, solo cuando aplica.
        *pBody             : El contenido a enviar en el cuerpo del Request
        Try
            pRequest.setRequestHeader("cache-control", "private")
            If !Empty(pAuthorization)
                pRequest.setRequestHeader("Authorization", "bearer " + pAuthorization)
            Endif
            pRequest.Send(pBody)
            This.iStatus = pRequest.Status
        Catch To loErr
            * --- Si entra aqui es porque el error fue de conectividad a internet, no un error del webservice ---
            This.iStatus = -1
        Endtry
        Do Case
            Case This.iStatus = 200 Or (pTipoRequest = 2 And This.iStatus = 201)
                &&Estos 2 códigos (200,201) implican la aceptación y respuesta correcta del request
                This.sResponse = Strtran(Alltrim(pRequest.responseText), "'", "")
                Return .T.
            Case pTipoRequest = 2 And This.iStatus = 202
                &&Este código (202) implica la aceptación de la recepción pero el fallo en el procesamiento del mismo
                &&los detalles del error deben ser obtenidos mediante el método Recepcion/Clave
                This.sResponse = Strtran(Alltrim(pRequest.responseText), "'", "")
                If Empty(This.sResponse)
                    This.sResponse = Alltrim(pRequest.StatusText)
                Endif
                Return .T.
            Case This.iStatus = -1
                This.sError  = "Error: " + Transform(loErr.ErrorNo,"9999999999") + This.CRLF +  "Mensaje: " + loErr.Message
                Return .F.
            Otherwise
                If Inlist(This.iRequestType, 3, 5) And This.iStatus = 404
                    &&NO ocurrio un error, sino que NO se encontró la recepcion/comprobante solicitado
                    This.sResponse  = Str(This.iStatus,3,0) + " " + Alltrim(pRequest.StatusText) + This.CRLF + pRequest.getResponseHeader("X-Error-Cause") + This.CRLF + pRequest.responseText
                    Return .T.
                Else
                    This.sResponse  = Str(This.iStatus,3,0) + " " + Alltrim(pRequest.StatusText) + This.CRLF + pRequest.getResponseHeader("X-Error-Cause") + This.CRLF + pRequest.responseText
                    If "recibido anteriormente"$This.sResponse
                        Return .T.
                    Else
                        Return .F.
                    Endif
                Endif
        Endcase
    Endfunc

    **Función que crea el Request para la API
    *----------------------------------------------------------
    Function CreaRequest(pTipoRequest, pClave)
        ** pTipoRequest: Define el tipo de Request que puedo crear
        **                1: Token
        **                2: Recepcion
        **                3: Recepcion/Clave
        **                4: Comprobantes
        **                5: Comprobantes/Clave
        ** pClave       : Clave del Documento a consultar (Solo para el Request tipo 3 y 5)
        This.iRequestType = pTipoRequest
        Try
            oAPIRequest = Createobject('Msxml2.ServerXMLHTTP.6.0')
            Do Case
                Case pTipoRequest = 1 &&Token
                    oAPIRequest.Open("POST", This.sURL_Token, .F.)
                    oAPIRequest.setRequestHeader("content-type", "application/x-www-form-urlencoded")
                Case pTipoRequest = 2 &&Recepcion
                    oAPIRequest.Open("POST", This.sURL_API + "/recepcion", .F.)
                    oAPIRequest.setRequestHeader("Content-Type", "application/json")
                Case pTipoRequest = 3 &&Recepcion/Clave
                    oAPIRequest.Open("GET", This.sURL_API + "/recepcion/" + pClave, .F.)
                    oAPIRequest.setRequestHeader("Content-Type", "application/json")
                Case pTipoRequest = 4 &&Comprobantes
                    oAPIRequest.Open("GET", This.sURL_API + "/comprobantes", .F.)
                    oAPIRequest.setRequestHeader("Content-Type", "application/x-www-form-urlencoded")
                Case pTipoRequest = 5 &&Comprobantes/Clave
                    oAPIRequest.Open("GET", This.sURL_API + "/comprobantes/" + pClave + "", .F.)
                    oAPIRequest.setRequestHeader("Content-Type", "application/x-www-form-urlencoded")
                Otherwise
                    This.sError = "Error: No es posible crear el request tipo " + Str(pTipoRequest, 1, 0)
                    This.iStatus = -1
                    oAPIRequest = Null
            Endcase
        Catch To loErr
            This.sError = "Error: " + Transform(loErr.ErrorNo,"9999999999") + This.CRLF +  "Mensaje: " + loErr.Message
            This.iStatus = -1
            oAPIRequest = Null
        Endtry
        Return oAPIRequest
    Endfunc
    *---------------------------------------------------


Las referencias a "THIS" son porque estos metodos estan dentro de una clase, bastante extensa, como te dije son muchas cosas por ahcer.

Hernan Serrano

unread,
Jan 24, 2018, 2:06:11 PM1/24/18
to publice...@googlegroups.com
Correcto, hay que revisar el armado del XML.
Que debe estar listo para enviarse.
Ya la conexion con tributacion no hay problema. Ya lo logramos, de hecho hasta el refresh token se puede hacer.
La firma digital, ya nos proporcionaron una libreria que lo hace.
Si puedes colaborar con el armado del JSON, para enviar a Hacienda el XML, eso no seria un granito de Arena, seria un meteorito, compañero.

Si puedes ayudar con eso seria genial...

Gracias de ante mano.

Pd:
Estoy trabajando con la firma en VFP, pero por razones de tiempo por ahora utilizaremos las librerias de C Sharp. Pero despues publicare. Si lo logro como firmar con VFP.

Gregorik Domador

unread,
Jan 24, 2018, 2:22:04 PM1/24/18
to Comunidad de Visual Foxpro en Español
Ahi va el Meteorito...

**Función que arma el JSon que irá incluido en el cuerpo del request.
    *--------------------------------------------------------------------
    Function GenerarJSonRecepcion(pTipoDoc, pNumDoc, pClave)
        Local sJSon, sXML
        sJSon = ""
        If !Eof('tmpCursor')
            sJSon  = [{"clave": "] + pClave + [",] + This.LF
            sJSon  = sJSon + ["fecha": "] + Str(Year(Date()),4,0) + "-" + Padl(Alltrim(Str(Month(Date()),2,0)),2,"0") + "-" + Padl(Alltrim(Str(Day(Date()),2,0)),2,"0") + "T" + Time() + [Z",] + This.LF
            sJSon  = sJSon + ["emisor": {"tipoIdentificacion": "] + Padl(Alltrim(Transform(tmpCursor.tipoid,"99")),2,"0") + [",] + This.LF&&Cédula Física=01,Cédula Jurídica=02,DIMEX=03,NITE=04
            tmpNumID = ""
            Do Case
                Case tmpCursor.tipoid = 1 &&Cédula Física
                    tmpNumID = Substr(Alltrim(tmpEmisorCfg.nrofiscal1),1,9)
                Case tmpCursor.tipoid = 2 Or tmpCursor.tipoid  = 4 &&Cédula Jurídica o NITE
                    tmpNumID = Padl(Substr(Alltrim(tmpEmisorCfg.nrofiscal1),1,10),10,"0")
                Case tmpCursor.tipoid = 3 &&DIMEX
                    tmpNumID = Substr(Alltrim(tmpEmisorCfg.nrofiscal1),1,12)
            Endcase
            sJSon = sJSon + ["numeroIdentificacion": "] + tmpNumID + ["},] + This.LF
            sJSon = sJSon + ["receptor": {"tipoIdentificacion": "] + Padl(Alltrim(Transform(tmpCursor.tipoid,"99")),2,"0") + [",] + This.LF&&Cédula Física=01,Cédula Jurídica=02,DIMEX=03,NITE=04
            tmpNumID = ""
            Do Case
                Case tmpCursor.tipoid = 1 &&Cédula Física
                    tmpNumID = Substr(Alltrim(tmpCursor.cedula),1,9)
                    If Empty(tmpNumID)
                        tmpNumID = Substr(Alltrim(tmpCursor.rif),1,9)
                    Endif
                Case tmpCursor.tipoid = 2 &&Cédula Jurídica
                    tmpNumID = Padl(Substr(Alltrim(tmpCursor.cedula),1,10),10,"0")
                    If Empty(tmpNumID)
                        tmpNumID = Substr(Alltrim(tmpCursor.rif),1,9)
                    Endif
                Case tmpCursor.tipoid = 3 &&DIMEX
                    tmpNumID = Substr(Alltrim(tmpCursor.rif),1,12)
                Case tmpCursor.tipoid = 4 &&NITE
                    tmpNumID = Padl(Substr(Alltrim(tmpCursor.rif),1,10),10,"0")
                Otherwise
                    tmpNumID = Substr(Alltrim(tmpCursor.cedula),1,9)
                    If Empty(tmpNumID)
                        tmpNumID = Substr(Alltrim(tmpCursor.rif),1,9)
                    Endif
            Endcase
            sJSon = sJSon + ["numeroIdentificacion": "] + tmpNumID + ["},] + This.LF
            sXML  = This.GenerarXMLRecepcion(pTipoDoc, pNumDoc, pClave)
            sXML  = Strtran(This.EncodeStringBase64(sXML), Chr(0), "")
            sJSon = sJSon + ["comprobanteXml": "] + sXML + ["}]
        Endif
        Return sJSon
    Endfunc
    *--------------------------------------------------------------------------------------------------------

Gregorik Domador

unread,
Jan 24, 2018, 2:38:43 PM1/24/18
to Comunidad de Visual Foxpro en Español
Alguien podria proporcionarme un XML valido que contenga el nodo <Referencia>, el que se usa para Notas de Debito y Credito.
Si incluyen tambien el XML de la factura original a la afecta seria super fenomenal.

Oscar Melendez

unread,
Jan 24, 2018, 2:40:59 PM1/24/18
to publice...@googlegroups.com
Este lo paso un compañero del foro vea a ver si le sirve
sinfirna.xml

Hernan Serrano

unread,
Jan 24, 2018, 2:45:03 PM1/24/18
to publice...@googlegroups.com
Gracias compañero por el meteorito.

En la noche veo el tema de los xml, y te envio alguno que te pueda servir.

Gregorik Domador

unread,
Jan 24, 2018, 3:03:17 PM1/24/18
to Comunidad de Visual Foxpro en Español
Gracias por el XML, pero no tiene el nodo <Referencia>, necesito el XML de Nota de Credito o Debito, el nodo Referencia va entre <ResumenFactura> y <Normativa>

Hernan Serrano

unread,
Jan 27, 2018, 9:00:34 AM1/27/18
to publice...@googlegroups.com
Te adjunto el codigo de creacion encriptacion y firmado del .xml.
Ya estoy haciendo pruebas de envio a Hacienda.

Pd:
Nodo referencia. Solo que en blanco.
crear factura electronica 4.2a.prg

Jose Carlos Aguilar

unread,
Jan 27, 2018, 10:37:42 AM1/27/18
to Comunidad de Visual Foxpro en Español
Para aquellos que estén interesados en la firma para costa rica en PHP puro sin librerias de terceros, me escriben en Privado.
Saludos

Hernan Serrano

unread,
Jan 28, 2018, 9:34:06 PM1/28/18
to publice...@googlegroups.com
Podrias enviarme el codigo. Me interesa aprender php.

ATTe
Gracias

Hernan Serrano

unread,
Jan 28, 2018, 9:44:05 PM1/28/18
to publice...@googlegroups.com
Gregorik, podrias indicarme si no es mucha molestia.
El orden en que se hace el proceso del tu sistema: Ejemplo. Creacion API, parametros api, creacion xml, encriptación xml. etc.
Para saber que orden utilizan ustedes.
Lo otro, cuales son los paramentros que utilizan para el envio del comprobante: Yo tengo
oHTTP = CREATEOBJECT('Msxml2.ServerXMLHTTP.6.0')
oHTTP.OPEN(cMETHOD, cURL, .F.)
oHTTP.setRequestHeader ("Authorization", "Bearer " + cPARAM1)
*SE ENVIA EL JSON
oHTTP.SEND(cDATA)

En donde cMethod = 'POST', cURL (el de hacienda /recepcion), cParam1='token', cData (Json)
Por favor me podrias indicar si esto esta bien.

ATTE
Hernan Serrano M



El 24 de enero de 2018, 13:38, Gregorik Domador <gregori...@gmail.com> escribió:
Alguien podria proporcionarme un XML valido que contenga el nodo <Referencia>, el que se usa para Notas de Debito y Credito.
Si incluyen tambien el XML de la factura original a la afecta seria super fenomenal.

Hernan Serrano

unread,
Jan 28, 2018, 10:48:49 PM1/28/18
to publice...@googlegroups.com

Compañeros, ya logre el envio a Tributacion.
Excepto que no me devuelve error. (Creo que es aceptacion.)
Apenas depure el codigo lo comparto.

ATTE
Hernan

Hernan Serrano

unread,
Jan 29, 2018, 8:27:53 AM1/29/18
to publice...@googlegroups.com
El JSON, devuelto trae el mensaje. En este caso rechazado. Pero ahora hay que revisar para ver por que no lo esta aceptando. Tarea para hoy.

El 28 de enero de 2018, 21:48, Hernan Serrano <hernan.serr...@gmail.com> escribió:

Compañeros, ya logre el envio a Tributacion.
Excepto que no me devuelve error. (Creo que es aceptacion.)
Apenas depure el codigo lo comparto.

ATTE
Hernan

Eduardo Venegas

unread,
Jan 31, 2018, 3:18:02 PM1/31/18
to Comunidad de Visual Foxpro en Español
Tengo una duda, sigo los pasos que indicas en este doc, pero aun así me da [La firma del comprobante electrónico no es válida]
Por que podria ser el problema?

Jose Carlos Aguilar

unread,
Jan 31, 2018, 3:46:31 PM1/31/18
to Comunidad de Visual Foxpro en Español
Enviar archivo sin firma y firmado para analizar.

Diego Varela

unread,
Feb 1, 2018, 5:15:49 PM2/1/18
to Comunidad de Visual Foxpro en Español
Jose Carlos Aguilar

En esta sección del código:

parametros.SignaturePolicyInfo.PolicyIdentifier = "https://tribunet.hacienda.go.cr/docs/esquemas/2016/v4/Resolucion%20Comprobantes%20Electronicos%20%20DGT-R-48-2016.pdf";             parametros.SignaturePolicyInfo.PolicyHash = "V8lVVNGDCPen6VELRD1Ja8HARFk="; 

En la propiedad PolicyIdentifier deseo poner la url del documento de resolución vigente, creo que la propiedad PolicyHash también cambiaría, de hecho hice la prueba y el API de hacienda me retorna el mensaje de que la firma no es válida... Al reversar el cambio y poner los valores "originales" ahí si me lo recibe el api de hacienda.

La pregunta mía principalmente es que deseo entender cual es la importancia o reelevacia de los valores de estas 2 propiedades PolicyIdentifier y PolicyHash. Además deseo saber si es verdaderamente posible cambiar el valor de esos atributos.

Saludos

Jose Carlos Aguilar

unread,
Feb 1, 2018, 5:23:45 PM2/1/18
to Comunidad de Visual Foxpro en Español
PolicyHasch es el valor en sha1 (tambien podria ser sha2) y base64 del archivo pdf en cuestion, por supuesto si la entidad cambia las politicas de firma ese valor cambiarian. 
Además por eso publique el código para que en caso cambie uds puedan recompilar la solucion.
Saludos

Diego Varela

unread,
Feb 1, 2018, 5:33:35 PM2/1/18
to Comunidad de Visual Foxpro en Español
Jose Carlos Aguilar:

Usted dice: "es el valor en sha1 (tambien podria ser sha2) y base64 del archivo pdf en cuestion".

Como puedo generar el sha1 del pdf v4.2? es que deseo entender esta parte creo que es de lo más importante para poder darle mantenimiento a la solución a lo largo del tiempo.

Jose Carlos Aguilar

unread,
Feb 2, 2018, 9:18:33 AM2/2/18
to Comunidad de Visual Foxpro en Español
Bueno, aquellos que les interesa en PHP, comparti en el grupo de whatsapp CRlibre , el codigo en PHP puro,  en ese grupo se las compartiran de seguro.
Suerte   y saludos, espero haber contribuido en algo con Uds.

Michael Bianchini

unread,
Feb 2, 2018, 2:22:21 PM2/2/18
to Comunidad de Visual Foxpro en Español

Gracias, me encantaría recibir el código pero no pertenezco al grupo de Whatsapp (el número de TicoSupport no funciona).  Si tuvieras otra forma de pasarlo? Pura Vida!

Hernan Serrano

unread,
Feb 2, 2018, 2:44:43 PM2/2/18
to publice...@googlegroups.com
Cual es tu numero. Yo he pasado el codigo por todos los hilos de FActuracion electrónica.

Hernan Serrano

unread,
Feb 2, 2018, 2:47:17 PM2/2/18
to publice...@googlegroups.com
Diego Varela. A voz ya te esta aceptando los documentos hacienda. O te los esta rechazando.

Si te los esta aceptando. Me podrias brindar un XML, de los que te acepta para poder compararlo con los mios.

Hernan Serrano

unread,
Feb 3, 2018, 8:39:23 AM2/3/18
to publice...@googlegroups.com
Imágenes integradas 1

Ya logre enviar los documentos a hacienda, comuniquense conmigo, para enviar los detalles del logro. Lo unico que les solicito es una colaboracion por estar en este proyecto las cuentas se me juntaron.

Hernan Serrano

unread,
Feb 3, 2018, 8:41:36 AM2/3/18
to publice...@googlegroups.com
Imágenes integradas 1

El 3 de febrero de 2018, 7:39, Hernan Serrano <hernan.serr...@gmail.com> escribió:
Imágenes integradas 1

Ya logre enviar los documentos a hacienda, comuniquense conmigo, para enviar los detalles del logro. Lo unico que les solicito es una colaboracion por estar en este proyecto las cuentas se me juntaron.

El 2 de febrero de 2018, 13:47, Hernan Serrano <hernan.serrano.morales@gmail.com> escribió:
Diego Varela. A voz ya te esta aceptando los documentos hacienda. O te los esta rechazando.

Si te los esta aceptando. Me podrias brindar un XML, de los que te acepta para poder compararlo con los mios.

El 1 de febrero de 2018, 16:33, Diego Varela <dvare...@gmail.com> escribió:
Jose Carlos Aguilar:

Usted dice: "es el valor en sha1 (tambien podria ser sha2) y base64 del archivo pdf en cuestion".

Como puedo generar el sha1 del pdf v4.2? es que deseo entender esta parte creo que es de lo más importante para poder darle mantenimiento a la solución a lo largo del tiempo.



--
Tico Support S. A.
Tel. (506)8772-6170



--
Tico Support S. A.
Tel. (506)8772-6170



--
Tico Support S. A.
Tel. (506)8819-4369

Greivin Guevara

unread,
Feb 4, 2018, 5:30:47 PM2/4/18
to Comunidad de Visual Foxpro en Español
Usando este metodo, me responden desde hacienda que esta invalida la firma. Alguien la ha usado y ha logrado hacer que funcione? Muchisimas gracias si alguien me puede ayudar
            parametros.SignaturePolicyInfo.PolicyIdentifier = "https://tribunet.hacienda.go.cr/docs/esquemas/2016/v4/Resolucion%20Comprobantes%20Electronicos%20%20DGT-R-48-2016.pdf";             parametros.SignaturePolicyInfo.PolicyHash = "V8lVVNGDCPen6VELRD1Ja8HARFk="; 
            parametros.SignaturePolicyInfo.PolicyUri = "";

            parametros.SignatureMethod = SignatureMethod.RSAwithSHA256;
            parametros.SigningDate =new DateTime ? (DateTime.Now);
            parametros.SignaturePackaging = SignaturePackaging.ENVELOPED;

            string cnomcert = crutanombreCertificado; 
            X509Certificate2 MontCertificat = new X509Certificate2(cnomcert, cClavecertificado);
            using (parametros.Signer = new Signer(MontCertificat))
            {
                using (FileStream fs = new FileStream(ficheroFactura, FileMode.Open))
                {
                    var docFirmado = xadesService.Sign(fs, parametros);
                    docFirmado.Save(CRUTASALIDA + XMLFILESALIDA);
                    rRRpta = "OK - Archivo firmado correctamente por JCAguilar- jcagu...@gmail.com";
                 }
            }
            return rRRpta;
        }
    }
}

Hernan Serrano

unread,
Feb 4, 2018, 10:10:06 PM2/4/18
to publice...@googlegroups.com
Es el que utilizo. Y a mi me lo acepta perfectamente. El certificado estara bien. Por que no lo vuelves a bajar.

Greivin Guevara

unread,
Feb 5, 2018, 9:57:26 PM2/5/18
to Comunidad de Visual Foxpro en Español
Ya lo probé y no, esta raro, hay alguna posibilidad de que la conversión en base64 produzca un error en la firma?

Hernan Serrano

unread,
Feb 6, 2018, 9:00:12 AM2/6/18
to publice...@googlegroups.com
Correcto. Si envias caracteres de mas. Eso invalida la firma.

Ronald Chacon

unread,
Feb 23, 2018, 11:51:13 AM2/23/18
to Comunidad de Visual Foxpro en Español

Buenas amigo, yo estoy desarrollando  el sistema de factura electronica en .net, ya pude realizar envio del json, al consultar el estado me devuelve rechazado. No se ud o ustedes saben de cuales son os motivos del xq devuelve el estado rechazado, muchas gracias

El sábado, 3 de febrero de 2018, 7:41:36 (UTC-6), Hernan Serrano escribió:
Imágenes integradas 1

El 3 de febrero de 2018, 7:39, Hernan Serrano <hernan.serr...@gmail.com> escribió:
Imágenes integradas 1

Ya logre enviar los documentos a hacienda, comuniquense conmigo, para enviar los detalles del logro. Lo unico que les solicito es una colaboracion por estar en este proyecto las cuentas se me juntaron.

El 2 de febrero de 2018, 13:47, Hernan Serrano <hernan.serr...@gmail.com> escribió:
Diego Varela. A voz ya te esta aceptando los documentos hacienda. O te los esta rechazando.

Si te los esta aceptando. Me podrias brindar un XML, de los que te acepta para poder compararlo con los mios.

El 1 de febrero de 2018, 16:33, Diego Varela <dvare...@gmail.com> escribió:
Jose Carlos Aguilar:

Usted dice: "es el valor en sha1 (tambien podria ser sha2) y base64 del archivo pdf en cuestion".

Como puedo generar el sha1 del pdf v4.2? es que deseo entender esta parte creo que es de lo más importante para poder darle mantenimiento a la solución a lo largo del tiempo.



--
Tico Support S. A.
Tel. (506)8772-6170



--
Tico Support S. A.
Tel. (506)8772-6170

Hernan Serrano

unread,
Feb 23, 2018, 11:53:32 AM2/23/18
to publice...@googlegroups.com
Tienes que hacer la consulta. En modo consulta. Te devuelve el json. En la repsuesta viene un atributo que es el xml en base 64 con los errores que tienes. Debes decodificar y ver que errores te arroja el xml.

Diego Varela

unread,
Feb 23, 2018, 11:54:30 AM2/23/18
to publice...@googlegroups.com
Hola yo pude arreglarlo agregando las anotaciones faltantes al xml. Se las puedo indicar.... Me avisan...

Ronald Chacon

unread,
Feb 23, 2018, 11:56:05 AM2/23/18
to Comunidad de Visual Foxpro en Español
Gracias amigo vamos a revisar ese punto.

Hernan Serrano

unread,
Feb 23, 2018, 11:56:48 AM2/23/18
to publice...@googlegroups.com
Compañeros. Recuerden que antes de ofrecer pescado. Hay que enseñarle a la gente a pescar.

Yo puedo hacerle todo el trabajo al compañero. Pero la idea es que en el proceso aprendan todos los pormenores para que si les piden luego una asesoria. Con propiedad puedan ofrecerla y cobrar obviamente por ella.

Greivin Guevara

unread,
Feb 23, 2018, 12:06:22 PM2/23/18
to Comunidad de Visual Foxpro en Español
Ya logré enviar y todo, la factura esta bien, solo que solo obtengo estado de recibido.

Hernan Serrano

unread,
Feb 23, 2018, 12:08:25 PM2/23/18
to publice...@googlegroups.com
Hay dos procesos. Envio del documento como tal.

Y luego tenemos que hacer un proceso de consulta.
Cuando consultamos. El sistema de tributación devuelve un JSON. En ese json, nos devuelven un xml cifrado en Base 64. Ese JSON hay que descifrarlo. Y ahi estan los errores que el sistema te esta indicando.

Diego Varela

unread,
Feb 23, 2018, 12:15:57 PM2/23/18
to publice...@googlegroups.com
Esto es lo de las anotaciones en el xml
Ojo yo estoy usando la version 4.1
20180223_105905.jpg

Hernan Serrano

unread,
Feb 23, 2018, 12:44:47 PM2/23/18
to publice...@googlegroups.com
Nuevamente compañero. Creo que todas las versiones es asi:
1. Envio de documento a Hacienda. (Casi siempre es status es aceptado.)
2. Consulta del Estado del Documento (En este caso: Aceptado, Rechazado)
    Si es rechazado. El sistema de tributación te envia un JSON en la respuesta.

El 23 de febrero de 2018, 11:15, Diego Varela <dvare...@gmail.com> escribió:
Esto es lo de las anotaciones en el xml
Ojo yo estoy usando la version 4.1

Diego Varela

unread,
Feb 25, 2018, 3:30:58 PM2/25/18
to publice...@googlegroups.com
Claro el problema es asi, el xml que uno convierte en base64 debe llevar unas anotaciones de los esquemas del elemento FacturaElectronica y del elemento Signature.

El tema es que estoy el 99% seguro que el webservice de hacienda ocupa que el xml llevar esas anotaciones para poder decodificarlo y procesarlo...

En la foto que adjunté se denota pero eso es en csharp, le voy a mostrar a continuación como es que tiene que queda el xml (4.1) configurado en el elemento root FacturaElectronica.


Nótese el namespace xmlns:ds y el attributo xsi:schemaLocatiom y en este último ponga atención al formato del valor: primero una url(solo para namespace declaration) y luego la url con la ubicacion del fichero xsd.
Eso fue lo que yo tuve que agregar para eliminar el error de firma digital invalida. Otro detalle; vea que estoy usando la version 4.1, entonces, en teoria con la version 4.2 seria exactamente igual.

El namespace xmlns:ds es para el Elemento Signature
El attribute xsi:schemaLocation es para el elemento principal o root FacturaElectronica.


Lo importante creo yo es salir de la bronca de ese mensaje de firma no valida, ya el resto son fixes de datos...

Haga usted mismo la prueba y me informa como le fue.

Saludos y mucha suerte a todos.

Hernan Serrano

unread,
Apr 10, 2018, 9:55:49 AM4/10/18
to Comunidad de Visual Foxpro en Español
Buenos dias Jose.
Tal vez me puedes orientar. Estoy haciendo la firma en C sharp. Pero a  la hora de compilar el proyecto me da el siguiente warning. Y como quiero hacer una dll. Eso me da problemas por que la dll no funciona el warning es el siguiente:
No se puede cargar el archivo de ensamblado Microsoft.Xades Version= 1.0.5.0 Culture=neutral Public key token = null ni una de sus dependencias. Se necesita un ensamblado con nombre seguro.

Daniel Ramos Mora

unread,
Jun 8, 2018, 9:06:16 PM6/8/18
to Comunidad de Visual Foxpro en Español
Primero felicitarlo y agradecerle Jose, me funcionó perfecto. Una consulta, si por algún motivo Hacienda cambia algo vos actualizarias el dll y nos informarías?

Saludos Cordiales,

El martes, 16 de enero de 2018, 7:11:54 (UTC-6), jose carlos aguilar escribió:
Les adjunto una librería para el firmado electrónico de facturas en Costa Rica acorde a lo que pide Hacienda.

Primero registrar la libreria luego ejecutar desde Foxpro de la sgt manera:
 ol = CREATEOBJECT("firmadoxadescr")

MESSAGEBOX(ol.FirmarXAdes("E:\Ivancr\", ;
                           "xml_sinfirma.xml",;
                           "E:\IvanCr\" , ;
                           "firmadocr.xml","E:\IvanCr\certificado.p12","clacecertificado"))

Espero les sea de utilidad.

Saludos

Hendell Mora

unread,
Jun 8, 2018, 9:16:33 PM6/8/18
to publice...@googlegroups.com
Podrias reenviar la dll.


Hendell

Daniel Ramos Mora

unread,
Jun 8, 2018, 9:21:58 PM6/8/18
to publice...@googlegroups.com
Lo puso Jose al principio de la cola

monica....@gmail.com

unread,
Jul 26, 2018, 7:52:25 PM7/26/18
to Comunidad de Visual Foxpro en Español
Hola, a donde puedo ver el codigo de esa libreria?

Hernan Serrano

unread,
Jul 27, 2018, 10:29:06 AM7/27/18
to publice...@googlegroups.com
Esa libreria es el aporte de uno de nuestros compañeros. Por favor si puedes poner los creditos eso seria genial. 

Por que suena a que te estas acreditando el aporte.....
--
Tico Support S. A.
Tel. (506)8819-4369

Monica Escrich

unread,
Jul 27, 2018, 10:47:41 AM7/27/18
to publice...@googlegroups.com
por supuesto pongo los creditos si la utilizo, no te preocupes

rodolfolopezp

unread,
Oct 23, 2018, 3:48:21 AM10/23/18
to Comunidad de Visual Foxpro en Español


Hola, e acabo de unir a la factura digital y estuve viendo sus conversaciones.
   Yo estoy en C#, utilizo la DLL FIRMADOCR, cn la cual firmo el XML.
   Pero hasta el momento me dice firma invalida .
   Yo pongo el código como usted en este apartado, y me lo firma, es eso únicamente lo que se debe hacer?. La DLL la conveirte a base 64 de una vez o hay que            hacerlo uno mismo?

    Gracias
 
Saludos

Diego Varela

unread,
Oct 23, 2018, 1:20:16 PM10/23/18
to publice...@googlegroups.com
Le recomiendo este sitio web


Ahi puede subir el XML que firma y validar... este link le permite ir corrigiendo errores hasta finalmente alcanzar la firma válida.
Reply all
Reply to author
Forward
0 new messages