# Archivo

## Introducción

Una consulta de estado de documento electrónico es un servicio que permite verificar el estado actual de un documento, como una factura electrónica, y tiene la misma validez legal que una verificación de estado realizada de manera tradicional. Este servicio es crucial para asegurar que el documento se ha creado, enviado y almacenado digitalmente. Además, este procedimiento electrónico debe contener todos los datos fiscales necesarios que permitan confirmar el estado del documento entre el emisor y el receptor, garantizando así la transparencia y la correcta gestión de las transacciones electrónicas.

**Beneficios de la Facturación Electrónica**

* **Eficiencia Operativa:** La automatización del proceso de facturación reduce la carga administrativa, disminuyendo los errores humanos y acelerando las transacciones.
* **Reducción de Costos:** Menores gastos en papel, impresión, envío y almacenamiento de documentos físicos.
* **Acceso y Gestión Simplificados:** El almacenamiento digital facilita la búsqueda y gestión de documentos, lo que es especialmente útil para auditorías y cumplimiento fiscal.

## Autenticación

Para acceder al servicio de facturación electrónica a través de nuestra API SOAP deben de identificarse y autenticarse usando una credencial única denominada **Clave**.

La autenticación se realiza incluyendo la credencial en el cuerpo del mensaje SOAP, dentro del nodo `<Clave>`. A continuación, se describe la estructura de la solicitud.

Ejemplo:

```xml
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:emis="https://ec.edocnube.com/api/emision" xmlns:com="https://ec.edocnube.com/api/emision/compretencion" xmlns:ext="https://ec.edocnube.com/api/emision/extensiones">
   <soapenv:Header/>
   <soapenv:Body>
      <emis:EmitirFactura>
         <emis:Clave>{CLAVE_VALOR}</Clave>
         <emis:Factura/>
      </emis:EmitirFactura>
   </soapenv:Body>
</soapenv:Envelope>
```

<table><thead><tr><th width="165">Elemento</th><th>Descripción</th></tr></thead><tbody><tr><td>Clave</td><td><strong>Requerido.</strong> Credencial única proporcionada a la empresa para autenticarse. Esta clave es específica y debe mantenerse confidencial.</td></tr></tbody></table>

{% tabs %}
{% tab title="JavaScript" %}

```javascript
 url = '/URL_SOAP_EMISION/EmitirDocumentoService.svc?wsdl';

// XML del mensaje SOAP
const soapRequest = `
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:emis="https://ec.edocnube.com/api/emision" xmlns:com="https://ec.edocnube.com/api/emision/compretencion" xmlns:ext="https://ec.edocnube.com/api/emision/extensiones">
   <soapenv:Header/>
   <soapenv:Body>
      <emis:EmitirFactura>
         <emis:Clave>{CLAVE_VALOR}</Clave>
         <emis:Factura/>
      </emis:EmitirFactura>
   </soapenv:Body>
</soapenv:Envelope>
`;

// Configuración de la solicitud HTTP
const headers = {
  'Content-Type': 'text/xml; charset=utf-8', // Tipo de contenido para SOAP
  SOAPAction: 'http://tempuri.org/EmitirDocumentoService/EmitirFactura', // Acción SOAP específica
};

// Realizar la solicitud con fetch
fetch(url, {
  method: 'POST',
  headers: headers,
  body: soapRequest,
})
  .then((response) => {
    if (!response.ok) {
      throw new Error(`HTTP error! status: ${response.status}`);
    }
    return response.text();
  })
  .then((data) => {
    console.log('Respuesta SOAP:', data);
  })
  .catch((error) => {
    console.error('Error en la solicitud SOAP:', error.message);
  });

```

{% endtab %}

{% tab title="PHP" %}

```php
<?php
// URL del servicio WSDL
$wsdl = "/URL_SOAP_EMISION/EmitirDocumentoService.svc?wsdl";

try {
    // Crear un cliente SOAP
    $client = new SoapClient($wsdl, [
        'trace' => true,       // Habilitar trazas para depuración
        'cache_wsdl' => WSDL_CACHE_NONE, // No cachear el WSDL
        'exceptions' => true   // Lanzar excepciones en errores
    ]);

    // Parámetros para el método
    $params = [
        "Clave" => "{CLAVE_VALOR}", // Credencial única
        "Factura" => null
    ];

    // Llamar al método
    $response = $client->__soapCall("EmitirFactura", [$params]);

    // Mostrar la respuesta
    echo "Respuesta SOAP:\n";
    print_r($response);
} catch (SoapFault $fault) {
    // Manejo de errores
    echo "Error SOAP: " . $fault->getMessage() . "\n";
    echo "Código de error: " . $fault->faultcode . "\n";
    echo "Detalles:\n" . $fault->detail . "\n";
}
?>

```

{% endtab %}

{% tab title="C#" %}

```csharp
using System;
using System.Net.Http;
using System.Text;
using System.Threading.Tasks;

class Program
{
    static async Task Main(string[] args)
    {
        string url = "/URL_SOAP_EMISION/EmitirDocumentoService.svc";
        string soapAction = "http://tempuri.org/EmitirDocumentoService/EmitirFactura";
        
        string soapEnvelope = @"<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:emis="https://ec.edocnube.com/api/emision" xmlns:com="https://ec.edocnube.com/api/emision/compretencion" xmlns:ext="https://ec.edocnube.com/api/emision/extensiones">
           <soapenv:Header/>
           <soapenv:Body>
              <emis:EmitirFactura>
                 <emis:Clave>{CLAVE_VALOR}</Clave>
                 <emis:Factura/>
              </emis:EmitirFactura>
           </soapenv:Body>
        </soapenv:Envelope>";

        using (HttpClient client = new HttpClient())
        {
            var request = new HttpRequestMessage(HttpMethod.Post, url)
            {
                Content = new StringContent(soapEnvelope, Encoding.UTF8, "text/xml")
            };
            request.Headers.Add("SOAPAction", soapAction);

            HttpResponseMessage response = await client.SendAsync(request);
            string responseContent = await response.Content.ReadAsStringAsync();

            Console.WriteLine("Respuesta del servidor:");
            Console.WriteLine(responseContent);
        }
    }
}

```

{% endtab %}

{% tab title="Python" %}

```python
import requests

# URL del servicio SOAP
url = "/URL_SOAP_EMISION/EmitirDocumentoService.svc"

# Cabeceras HTTP
headers = {
    "Content-Type": "text/xml; charset=utf-8",
    "SOAPAction": "http://tempuri.org/EmitirDocumentoService/EmitirFactura"
}

# Cuerpo del mensaje SOAP
soap_body = """<?xml version="1.0" encoding="utf-8"?>
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:emis="https://ec.edocnube.com/api/emision" xmlns:com="https://ec.edocnube.com/api/emision/compretencion" xmlns:ext="https://ec.edocnube.com/api/emision/extensiones">
   <soapenv:Header/>
   <soapenv:Body>
      <emis:EmitirFactura>
         <emis:Clave>{CLAVE_VALOR}</Clave>
         <emis:Factura/>
      </emis:EmitirFactura>
   </soapenv:Body>
</soapenv:Envelope>"""

try:
    # Enviar la solicitud POST
    response = requests.post(url, data=soap_body, headers=headers)

    # Verificar el estado de la respuesta
    if response.status_code == 200:
        print("Respuesta del servidor:")
        print(response.text)
    else:
        print(f"Error en la solicitud: {response.status_code}")
        print(response.text)

except requests.exceptions.RequestException as e:
    print(f"Error al realizar la solicitud: {e}")

```

{% endtab %}

{% tab title="Curl" %}

```bash
curl -X POST "/URL_SOAP_EMISION/EmitirDocumentoService.svc" \
-H "Content-Type: text/xml; charset=utf-8" \
-H "SOAPAction: http://tempuri.org/EmitirDocumentoService/EmitirFactura" \
-d '<?xml version="1.0" encoding="utf-8"?>
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:emis="https://ec.edocnube.com/api/emision" xmlns:com="https://ec.edocnube.com/api/emision/compretencion" xmlns:ext="https://ec.edocnube.com/api/emision/extensiones">
   <soapenv:Header/>
   <soapenv:Body>
      <emis:EmitirFactura>
         <emis:Clave>{CLAVE_VALOR}</Clave>
         <emis:Factura/>
      </emis:EmitirFactura>
   </soapenv:Body>
</soapenv:Envelope>'

```

{% endtab %}
{% endtabs %}

## Consulta el archivo del documento electrónico

En esta sección, abordaremos los detalles técnicos específicos del proceso de consulta de archivo de documentos electrónicos utilizando la tecnología SOAP. Exploraremos cómo este enfoque facilita la integración eficiente y segura de los sistemas de gestión documental dentro de las infraestructuras empresariales existentes, asegurando la conformidad con los estándares legales y fiscales relevantes. Nos centraremos en la implementación de SOAP para describir las interacciones entre los sistemas y los métodos empleados para la recuperación y visualización de documentos electrónicos.

## Estados eDoc

La gestión adecuada de los estados eDoc es crucial en el sistema de facturación electrónica, ya que cada estado refleja una etapa específica en el proceso de validación y envío de documentos a la entidad tributaria. A continuación, se presenta una tabla que describe cada uno de los estados eDoc, proporcionando claridad sobre las acciones necesarias según el estado en que se encuentre el documento.

<table><thead><tr><th width="88" align="center">Valor</th><th>Descripción</th><th>Causa</th><th>Solución</th></tr></thead><tbody><tr><td align="center">2</td><td>Documento autorizado por el ente tributario</td><td>Documento autorizado por el SRI</td><td>Ninguna</td></tr><tr><td align="center">3</td><td>Documento no autorizado por el ente tributario</td><td>Documento no superó la validación debido al incumplimiento de las reglas de negocio establecidas por el SRI</td><td>Realizar la corrección de los datos del documento y emitirlo nuevamente</td></tr><tr><td align="center">4</td><td>Error al emitir o consultar el documento en eDoc</td><td>Ha ocurrido un error en eDoc, el cual ha sido identificado con un código para su seguimiento y solución</td><td>Levantar un ticket de atención en el portal de soporte técnico de GuruSoft</td></tr><tr><td align="center">5</td><td>Documento en espera de autorización por parte del ente tributario</td><td>eDoc no pudo establecer una conexión con el SRI para consultar la autorización del documento, se realizará una reconsulta automática posteriormente</td><td>Realizar la consulta del estado del documento mediante la API correspondiente, una vez transcurrido un intervalo de tiempo adecuado</td></tr><tr><td align="center">6</td><td>Documento rechazado por el ente tributario</td><td>Documento no cumplió con las validaciones de estructura y/o formato XML requeridas por el SRI</td><td>Realizar la corrección de los datos del documento y emitirlo nuevamente</td></tr><tr><td align="center">7</td><td>Documento en espera de recepción por parte del ente tributario</td><td>eDoc no pudo establecer una conexión con el SRI para transmitir el documento, se realizará un reenvío automático posteriormente</td><td>Realizar la consulta del estado del documento mediante la API correspondiente, una vez transcurrido un intervalo de tiempo adecuado</td></tr><tr><td align="center">11</td><td>Documento anulado en eDoc</td><td>Documento ha sido anulado por el emisor mediante el portal web del SRI</td><td>Una vez alcanzado este estado, el documento no puede ser modificado ni revertido</td></tr><tr><td align="center">15</td><td>Solicitud de emisión o consulta rechazada por eDoc</td><td>Solicitud de emisión o consulta no cumplió con las validaciones de estructura y/o formato XML requeridas por eDoc</td><td>Realizar la corrección de los datos del documento y emitirlo nuevamente</td></tr><tr><td align="center">18</td><td>Documento no encontrado en eDoc</td><td>Documento consultado no fue encontrando en eDoc</td><td>Realizar la corrección de los parámetros de la consulta y repetir el proceso</td></tr></tbody></table>

## Diccionario de datos

{% embed url="<https://wiki.edocnube.com/diccionario/Documentation/FromXml?classname=&p1=AJkuNFFcBIW7i1zn63Wd0zMug5qnw8YUIJVZZ4GV6wKJLsD/zqmX3g7ojWIfC7B6g7sCzj3eGRxTklfJ+lpnkcR7fXoHZszbiUl1yOPVS6JaBlwF/lISIm/ED8KEQVmI&p2=EoWbYb/FBQ7+HIWWn+AakB3g3J1gzmJ9kA8zwIvk7Vw=&p3=ASz1RE4QhWU=&p4=L5lbnPmTSNE=&p5=42yljgltFnM=&p6=0h6AVWZOsDA=>" %}

## Consumo

### Request

{% tabs %}
{% tab title="JavaScript" %}

```javascript
 url = '/URL_SOAP_EMISION/ConsultarDocumentoService.svc?wsdl';

// XML del mensaje SOAP
const soapRequest = `
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:con="https://ec.edocnube.com/api/emision/consulta" xmlns:arc="https://ec.edocnube.com/api/emision/consulta/archivo">
   <soapenv:Header/>
   <soapenv:Body>
      <emis:ConsultarArchivo>
         <emis:Clave>{CLAVE_VALOR}</Clave>
         <emis:ConsultaArchivo/>
      </emis:ConsultarArchivo>
   </soapenv:Body>
</soapenv:Envelope>
`;

// Configuración de la solicitud HTTP
const headers = {
  'Content-Type': 'text/xml; charset=utf-8', // Tipo de contenido para SOAP
  SOAPAction: 'http://tempuri.org/ConsultarDocumentoService/ConsultarArchivo', // Acción SOAP específica
};

// Realizar la solicitud con fetch
fetch(url, {
  method: 'POST',
  headers: headers,
  body: soapRequest,
})
  .then((response) => {
    if (!response.ok) {
      throw new Error(`HTTP error! status: ${response.status}`);
    }
    return response.text();
  })
  .then((data) => {
    console.log('Respuesta SOAP:', data);
  })
  .catch((error) => {
    console.error('Error en la solicitud SOAP:', error.message);
  });

```

{% endtab %}

{% tab title="PHP" %}

```php
<?php
// URL del servicio WSDL
$wsdl = "/URL_SOAP_EMISION/ConsultarDocumentoService.svc?wsdl";

try {
    // Crear un cliente SOAP
    $client = new SoapClient($wsdl, [
        'trace' => true,       // Habilitar trazas para depuración
        'cache_wsdl' => WSDL_CACHE_NONE, // No cachear el WSDL
        'exceptions' => true   // Lanzar excepciones en errores
    ]);

    // Parámetros para el método
    $params = [
        "Clave" => "{CLAVE_VALOR}", // Credencial única
        "ConsultaArchivo" => null
    ];

    // Llamar al método
    $response = $client->__soapCall("ConsultarArchivo", [$params]);

    // Mostrar la respuesta
    echo "Respuesta SOAP:\n";
    print_r($response);
} catch (SoapFault $fault) {
    // Manejo de errores
    echo "Error SOAP: " . $fault->getMessage() . "\n";
    echo "Código de error: " . $fault->faultcode . "\n";
    echo "Detalles:\n" . $fault->detail . "\n";
}
?>

```

{% endtab %}

{% tab title="C#" %}

```csharp
using System;
using System.Net.Http;
using System.Text;
using System.Threading.Tasks;

class Program
{
    static async Task Main(string[] args)
    {
        string url = "/URL_SOAP_EMISION/ConsultarDocumentoService.svc";
        string soapAction = "http://tempuri.org/ConsultarDocumentoService/ConsultarArchivo";
        
        string soapEnvelope = @"<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:con="https://ec.edocnube.com/api/emision/consulta" xmlns:arc="https://ec.edocnube.com/api/emision/consulta/archivo">
           <soapenv:Header/>
           <soapenv:Body>
              <emis:ConsultarArchivo>
                 <emis:Clave>{CLAVE_VALOR}</Clave>
                 <emis:ConsultaArchivo/>
              </emis:ConsultarArchivo>
           </soapenv:Body>
        </soapenv:Envelope>";

        using (HttpClient client = new HttpClient())
        {
            var request = new HttpRequestMessage(HttpMethod.Post, url)
            {
                Content = new StringContent(soapEnvelope, Encoding.UTF8, "text/xml")
            };
            request.Headers.Add("SOAPAction", soapAction);

            HttpResponseMessage response = await client.SendAsync(request);
            string responseContent = await response.Content.ReadAsStringAsync();

            Console.WriteLine("Respuesta del servidor:");
            Console.WriteLine(responseContent);
        }
    }
}

```

{% endtab %}

{% tab title="Python" %}

```python
import requests

# URL del servicio SOAP
url = "/URL_SOAP_EMISION/ConsultarDocumentoService.svc"

# Cabeceras HTTP
headers = {
    "Content-Type": "text/xml; charset=utf-8",
    "SOAPAction": "http://tempuri.org/ConsultarDocumentoService/ConsultarArchivo"
}

# Cuerpo del mensaje SOAP
soap_body = """<?xml version="1.0" encoding="utf-8"?>
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:con="https://ec.edocnube.com/api/emision/consulta" xmlns:arc="https://ec.edocnube.com/api/emision/consulta/archivo">
   <soapenv:Header/>
   <soapenv:Body>
      <emis:ConsultarArchivo>
         <emis:Clave>{CLAVE_VALOR}</Clave>
         <emis:ConsultaArchivo/>
      </emis:ConsultarArchivo>
   </soapenv:Body>
</soapenv:Envelope>"""

try:
    # Enviar la solicitud POST
    response = requests.post(url, data=soap_body, headers=headers)

    # Verificar el estado de la respuesta
    if response.status_code == 200:
        print("Respuesta del servidor:")
        print(response.text)
    else:
        print(f"Error en la solicitud: {response.status_code}")
        print(response.text)

except requests.exceptions.RequestException as e:
    print(f"Error al realizar la solicitud: {e}")
```

{% endtab %}

{% tab title="Curl" %}

```bash
curl -X POST "/URL_SOAP_EMISION/ConsultarDocumentoService.svc" \
-H "Content-Type: text/xml; charset=utf-8" \
-H "SOAPAction: http://tempuri.org/ConsultarDocumentoService/ConsultarArchivo" \
-d '<?xml version="1.0" encoding="utf-8"?>
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:con="https://ec.edocnube.com/api/emision/consulta" xmlns:arc="https://ec.edocnube.com/api/emision/consulta/archivo">
   <soapenv:Header/>
   <soapenv:Body>
      <emis:ConsultarArchivo>
         <emis:Clave>{CLAVE_VALOR}</Clave>
         <emis:ConsultaArchivo/>
      </emis:ConsultarArchivo>
   </soapenv:Body>
</soapenv:Envelope>'
```

{% endtab %}
{% endtabs %}

### Response

En una comunicación SOAP, las respuestas HTTP pueden variar según el estado y el contenido de la comunicación:

* **200 (OK)**: La solicitud se procesó correctamente y devuelve un mensaje SOAP en XML con los detalles de la respuesta.

Estas respuestas permiten manejar adecuadamente los distintos escenarios de comunicación.

{% tabs %}
{% tab title="Estado HTTP 200" %}

```xml
<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
   <s:Body>
      <ConsultarArchivoResponse xmlns="https://ec.edocnube.com/api/emision/consulta" xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
         <Archivo>﻿<autorizacion>
  <estado>AUTORIZADO</estado>
  <numeroAutorizacion>2404202501099273796400110010150000000224276851318</numeroAutorizacion>
  <fechaAutorizacion>09/06/2025 17:29:24</fechaAutorizacion>
  <ambiente>PRUEBAS</ambiente>
  <comprobante><![CDATA[<?xml version="1.0" encoding="UTF-8"?>
<factura id="comprobante" version="1.0.0">
  <infoTributaria>
    <ambiente>1</ambiente>
    <tipoEmision>1</tipoEmision>
    <razonSocial>GuruSoft S.A.</razonSocial>
    <nombreComercial>GuruSoft S.A.</nombreComercial>
    <ruc>0992737964001</ruc>
    <claveAcceso>2404202501099273796400110010150000000224276851318</claveAcceso>
    <codDoc>01</codDoc>
    <estab>001</estab>
    <ptoEmi>015</ptoEmi>
    <secuencial>000000022</secuencial>
    <dirMatriz>Av de las Americas 510 Edificio Sky Building Piso 4 Oficina 409 Guayaquil – Ecuador</dirMatriz>
    <contribuyenteRimpe>CONTRIBUYENTE RÉGIMEN RIMPE</contribuyenteRimpe>
  </infoTributaria>
  <infoFactura>
    <fechaEmision>24/04/2025</fechaEmision>
    <dirEstablecimiento>Av de las Americas 510 Edificio Sky Building Piso 4 Oficina 409 Guayaquil – Ecuador</dirEstablecimiento>
    <obligadoContabilidad>SI</obligadoContabilidad>
    <tipoIdentificacionComprador>05</tipoIdentificacionComprador>
    <guiaRemision>001-001-000000001</guiaRemision>
    <razonSocialComprador>José Zambrano Ortega</razonSocialComprador>
    <identificacionComprador>0929136869</identificacionComprador>
    <direccionComprador>Durán, Urb. La Martina</direccionComprador>
    <totalSinImpuestos>1000.00</totalSinImpuestos>
    <totalDescuento>0.00</totalDescuento>
    <totalConImpuestos>
      <totalImpuesto>
        <codigo>2</codigo>
        <codigoPorcentaje>4</codigoPorcentaje>
        <baseImponible>1000.00</baseImponible>
        <valor>150.00</valor>
      </totalImpuesto>
    </totalConImpuestos>
    <propina>0.00</propina>
    <importeTotal>1150.00</importeTotal>
    <moneda>DOLAR</moneda>
    <pagos>
      <pago>
        <formaPago>01</formaPago>
        <total>1000.00</total>
      </pago>
    </pagos>
  </infoFactura>
  <detalles>
    <detalle>
      <codigoPrincipal>EDOC01</codigoPrincipal>
      <codigoAuxiliar>?</codigoAuxiliar>
      <descripcion>eDoc Empresarial EC</descripcion>
      <cantidad>1.00</cantidad>
      <precioUnitario>1000.00</precioUnitario>
      <descuento>0.00</descuento>
      <precioTotalSinImpuesto>1000.00</precioTotalSinImpuesto>
      <detallesAdicionales>
        <detAdicional nombre="Tipo de licencia" valor="Nube"></detAdicional>
      </detallesAdicionales>
      <impuestos>
        <impuesto>
          <codigo>2</codigo>
          <codigoPorcentaje>4</codigoPorcentaje>
          <tarifa>15.00</tarifa>
          <baseImponible>1000.00</baseImponible>
          <valor>150.00</valor>
        </impuesto>
      </impuestos>
    </detalle>
  </detalles>
  <infoAdicional>
    <campoAdicional nombre="Dato 1">Valor 1</campoAdicional>
    <campoAdicional nombre="Email">jose.zambrano@guru-soft.com</campoAdicional>
    <campoAdicional nombre="Email">?</campoAdicional>
  </infoAdicional>
<ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#" xmlns:etsi="http://uri.etsi.org/01903/v1.3.2#" Id="Signature532086">
<ds:SignedInfo Id="Signature-SignedInfo35200">
<ds:CanonicalizationMethod Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"></ds:CanonicalizationMethod>
<ds:SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1"></ds:SignatureMethod>
<ds:Reference Id="SignedPropertiesID72554" Type="http://uri.etsi.org/01903#SignedProperties" URI="#Signature532086-SignedProperties246456">
<ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"></ds:DigestMethod>
<ds:DigestValue>Y6vqm6h4z+gri4LJgswD9ZbGGf0=</ds:DigestValue>
</ds:Reference>
<ds:Reference URI="#Certificate1278405">
<ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"></ds:DigestMethod>
<ds:DigestValue>b3kLpjE/iLZnLGQcBTuM1zg6q34=</ds:DigestValue>
</ds:Reference>
<ds:Reference Id="Reference-ID-211715" URI="#comprobante">
<ds:Transforms>
<ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"></ds:Transform>
</ds:Transforms>
<ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"></ds:DigestMethod>
<ds:DigestValue>ZuQLHLl0X+ElXCCGXGqhKyG3iR0=</ds:DigestValue>
</ds:Reference>
</ds:SignedInfo>
<ds:SignatureValue Id="SignatureValue730945">
v0nns+KgDkzSzj3VtTJyBGXgpV7tQ4fgvs3WeVdAUbo9lPmWBDf+d+WQFc0lOqxfCmAYYZTm8ypj
kosDoUHfioYlbWEd/DOAWiureyCjwz3DbCsG8NAx0Vhfde3ESLW+tsq+mLKOzRHNAQDNGp4ZazaH
reDd1wqRMmtDW7EEjU7znodWYigda/HpsLuy7K0PqcRHdT0uvor2bdCw6jlp2jjb2R8PtPewo9jA
82XaQ6LSWagJZP939t3iHcJN/UmuLpXRVRONI9VjE2XwhfmYSRsUwhMfh6/nNyngKGLY2050Oefc
14b5FYjXoh5aXFLCmgT4Yz9MaGMsUXxlkW6vpw==
</ds:SignatureValue>
<ds:KeyInfo Id="Certificate1278405">
<ds:X509Data>
<ds:X509Certificate>
MIILdDCCCVygAwIBAgIMA0eHjrAyO559yToPMA0GCSqGSIb3DQEBCwUAMIG5MRYwFAYDVQQFEw0x
NzkyNjAxMjE1MDAxMQswCQYDVQQGEwJFQzE2MDQGA1UEChMtQU5GQUMgQVVUT1JJREFEIERFIENF
UlRJRklDQUNJT04gRUNVQURPUiBDLkEuMSUwIwYDVQQLExxBTkYgQXV0b3JpZGFkIGludGVybWVk
aWEgIEVDMTMwMQYDVQQDEypBTkYgSGlnaCBBc3N1cmFuY2UgRWN1YWRvciBJbnRlcm1lZGlhdGUg
Q0EwHhcNMjQwNTAxMTgyNjA3WhcNMjYwNTAxMTgyNjA3WjCCAZcxFjAUBgNVBAoMDUdVUlVTT0ZU
IFMuQS4xGjAYBgorBgEEAYKkQgoEDAowOTE4NDA1NDQwMSgwJgYDVQQLDB9DZXJ0aWZpY2FkbyBQ
ZXJzb25hIEp1cmlkaWNhIEVDMRgwFgYDVQQqDA9IRUNUT1IgR0VPVkFOTlkxFjAUBgNVBGETDTA5
OTI3Mzc5NjQwMDExCzAJBgNVBAYTAkVDMRMwEQYDVQQFEwowOTE4NDA1NDQwMRcwFQYDVQQEDA5N
T05URVJPIENPUlRFWjEyMDAGA1UEAwwpMDkxODQwNTQ0MCBIRUNUT1IgR0VPVkFOTlkgTU9OVEVS
TyBDT1JURVoxGDAWBgNVBAwMD0dFUkVOVEUgR0VORVJBTDEqMCgGCSqGSIb3DQEJARYbZmluYW5j
aWVyby5lY0BndXJ1LXNvZnQuY29tMSswKQYDVQQNDCJDZXJ0aWZpY2FkbyBwYXJhIFBlcnNvbmEg
SnVyw61kaWNhMQ8wDQYDVQQIDAZHVUFZQVMxEjAQBgNVBAcMCUdVQVlBUVVJTDCCASIwDQYJKoZI
hvcNAQEBBQADggEPADCCAQoCggEBANbzLbewdOf2PG++O0a7LIZw0YlkWt2nCOJYosxYPnsF2sog
7WljDPQxDLAq94+nFnUBLF+2JfAL9L6m540RnNqObq9CJAYqW+1IsN9MRL++YN3sYUlmqecBSsx0
QMr9LF8qXdoZMFTCR6+CuU8XtjjTBA9kGGbwSljig3hJfuqBjb0gWFOtByOmYUM3aEMYxMnf2w5y
HRCzLtofdg865WBtpEYAjwWQdHvIMLGFbYZjWBx6Las5vo9xwILJHBta0dV0vdeBOPsPFc7GmpAe
D8M4ANXWceR1SPLs8itLNmJpifP5npgNCFHLv82pH1AdrHIYwk4YCSv41ofsM57sz0ECAwEAAaOC
BZkwggWVMB8GA1UdIwQYMBaAFJKu1MuCtJnG0XsRbGXqxU1oIfmsMB0GA1UdDgQWBBSqMebWYJMR
+aldE3LgVFi11ZMzizCCAQAGA1UdEQSB+DCB9YEbZmluYW5jaWVyby5lY0BndXJ1LXNvZnQuY29t
pIHVMIHSMR8wHQYKKwYBBAGCpEIKAQwPSEVDVE9SIEdFT1ZBTk5ZMRcwFQYKKwYBBAGCpEIKAgwH
TU9OVEVSTzEWMBQGCisGAQQBgqRCCgMMBkNPUlRFWjEaMBgGCisGAQQBgqRCCgQMCjA5MTg0MDU0
NDAxGTAXBgkrBgEEAYGPHAEMCkEtMDEwNTIwMjQxMjAwBgNVBAMMKTA5MTg0MDU0NDAgSEVDVE9S
IEdFT1ZBTk5ZIE1PTlRFUk8gQ09SVEVaMRMwEQYDVQQFDAowOTE4NDA1NDQwMA4GA1UdDwEB/wQE
AwIGwDAdBgNVHSUEFjAUBggrBgEFBQcDAgYIKwYBBQUHAwQwUAYDVR0fBEkwRzBFoEOgQYY/aHR0
cDovL2NybC5hbmYuZXMvY3JsL0FORkhpZ2hBc3N1cmFuY2VFY3VhZG9ySW50ZXJtZWRpYXRlQ0Eu
Y3JsMIIBAwYDVR0gBIH7MIH4MIHfBgwrBgEEAYKkQgIFAQMwgc4wKAYIKwYBBQUHAgEWHGh0dHA6
Ly93d3cuYW5mLmVzL2RvY3VtZW50b3MwgaEGCCsGAQUFBwICMIGUDIGRQ2VydGlmaWNhZG8gY29u
Zm9ybWUgYSBsYSBsZWdpc2xhY2nDs24gZGUgZmlybWEgZWxlY3Ryw7NuaWNhLiBBbnRlcyBkZSBh
Y2VwdGFybG8gY29tcHJ1ZWJlIGludGVncmlkYWQsIGxpbWl0YWNpb25lcywgdmlnZW5jaWEgeSB1
c29zIGF1dG9yaXphZG9zLjAJBgcEAIvsQAEBMAkGB2CFVAEDBQgwgZsGCCsGAQUFBwEBBIGOMIGL
MCcGCCsGAQUFBzABhhtodHRwOi8vb2NzcC5hbmYuZXMvc3BhaW4vQVYwYAYIKwYBBQUHMAKGVGh0
dHA6Ly93d3cuYW5mLmVzL2VzL2NlcnRpZmljYXRlcy1kb3dubG9hZC9BTkZIaWdoQXNzdXJhbmNl
RWN1YWRvckludGVybWVkaWF0ZUNBLmNlcjAMBgNVHRMBAf8EAjAAMCgGCSsGAQQBgY8cEwQbDBk2
MDczNjgwNDA2MTctNDg0NjU2NDczNDQwMBUGCisGAQQBgY8cEwIEBwwFMzc0NDIwKQYKKwYBBAGC
pEITAQQbDBk0ODQ2NTY0NzM0NDAtNDc2ODE5NzQ3MDk1MBoGCisGAQQBgqRCAwEEDAwKMDkxODQw
NTQ0MDAdBgorBgEEAYKkQgMKBA8MDUdVUlVTT0ZUIFMuQS4wHQYKKwYBBAGCpEIDCwQPDA0wOTky
NzM3OTY0MDAxMBIGCisGAQQBgqRCAwwEBAwCRUMwHwYKKwYBBAGCpEIDAgQRDA9IRUNUT1IgR0VP
VkFOTlkwHgYKKwYBBAGCpEIDAwQQDA5NT05URVJPIENPUlRFWjAfBgorBgEEAYKkQgMFBBEMD0dF
UkVOVEUgR0VORVJBTDAZBgorBgEEAYKkQgMJBAsMCUdVQVlBUVVJTDAXBgorBgEEAYKkQioBBAkM
B1VJTy0wMDMwEwYKKwYBBAGCpEIuAQQFDAM3MzAwUAYKKwYBBAGCpEIvAQRCDEBlZmYwNGY0YWZj
NGRkODQ0NWM3MjgzYzUwOTJiMDAyMGFmMzJlYzc4NmFjYTNhNjBkZDY1Nzk3OGFhN2IwZTYwMEQG
CCsGAQUFBwEDBDgwNjAIBgYEAI5GAQEwEwYGBACORgEGMAkGBwQAjkYBBgEwCQYHBACL7EkBATAK
BggrBgEFBQcLAjANBgkqhkiG9w0BAQsFAAOCAgEAGEANmWSvXsQx8ihg8P+oTlHGbG3IRMABo6v5
4U7tg4+BuZGRJNy6k7ojo/DZugx/VQ2WC+8kEw1DePRZohZ1WdJZf7Qd4xA6F8Jod7jsCFs+Ogm/
4eW9FKVypU4bmcMgQ60RXuAU+qwWVSJG/EQlDhw/2OOwKvbbbI3dzDL0IacHGukO9K68jyBosYA8
FScW+C5/GYn1tgoZgoNG2lu1M4G37GmeQz/4PdMyELu1+gykevLGBWEOOV9n2yAcvKhx8mrh6BZu
zymQogvUEH322a1vu6jtOnHsfK1Ki7gnOkNEJoh3g/WeckPJ/s5alnG8/87r+iW/ZnOC/usp+EGr
brOa3Bo7rbBiJ7zlMLZDyVKW2GMQW+0HvLvJGgNZTFCXC81VxDb1U52yR7UCliDsyzXnwAnFRTwP
B/r21AsMa5mk5VTlFxWkA0XurpkPKmmbNB+5OoDJZIdSmIO0wsYtS1q1ulyLfHzLXGuNllCWV1aV
Pczu/6LjsgjpOPIUduqD5+fEpADqJFXFW16HZCWMWeW9VnWPLvBgXgaCqbbW4iWQ/hAeQcjOKhTL
Rabn5vXHCT/nlXiG87REhJJt/3+8CVFb9zHfILUcPN0H0ogMhLi9XOrBd5bZ2axkzIm0P0k/r0WL
ydJPge7ce4omvdJQFGPhy7ZWiAbVgh5o/3iQFkc=
</ds:X509Certificate>
</ds:X509Data>
<ds:KeyValue>
<ds:RSAKeyValue>
<ds:Modulus>
1vMtt7B05/Y8b747RrsshnDRiWRa3acI4liizFg+ewXayiDtaWMM9DEMsCr3j6cWdQEsX7Yl8Av0
vqbnjRGc2o5ur0IkBipb7Uiw30xEv75g3exhSWap5wFKzHRAyv0sXypd2hkwVMJHr4K5Txe2ONME
D2QYZvBKWOKDeEl+6oGNvSBYU60HI6ZhQzdoQxjEyd/bDnIdELMu2h92DzrlYG2kRgCPBZB0e8gw
sYVthmNYHHotqzm+j3HAgskcG1rR1XS914E4+w8VzsaakB4PwzgA1dZx5HVI8uzyK0s2YmmJ8/me
mA0IUcu/zakfUB2schjCThgJK/jWh+wznuzPQQ==
</ds:Modulus>
<ds:Exponent>AQAB</ds:Exponent>
</ds:RSAKeyValue>
</ds:KeyValue>
</ds:KeyInfo>
<ds:Object Id="Signature532086-Object674359"><etsi:QualifyingProperties Target="#Signature532086"><etsi:SignedProperties Id="Signature532086-SignedProperties246456"><etsi:SignedSignatureProperties><etsi:SigningTime>2025-06-09T17:30:32-05:00</etsi:SigningTime><etsi:SigningCertificate><etsi:Cert><etsi:CertDigest><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"></ds:DigestMethod><ds:DigestValue>zpgzRTU8rMlZ9DKjG972WmrtVH0=</ds:DigestValue></etsi:CertDigest><etsi:IssuerSerial><ds:X509IssuerName>CN=ANF High Assurance Ecuador Intermediate CA,OU=ANF Autoridad intermedia  EC,O=ANFAC AUTORIDAD DE CERTIFICACION ECUADOR C.A.,C=EC,2.5.4.5=#130d31373932363031323135303031</ds:X509IssuerName><ds:X509SerialNumber>1014928914265795597850720783</ds:X509SerialNumber></etsi:IssuerSerial></etsi:Cert></etsi:SigningCertificate></etsi:SignedSignatureProperties><etsi:SignedDataObjectProperties><etsi:DataObjectFormat ObjectReference="#Reference-ID-211715"><etsi:Description>GuruSoft S.A Tel.045109312</etsi:Description><etsi:MimeType>text/xml</etsi:MimeType></etsi:DataObjectFormat></etsi:SignedDataObjectProperties></etsi:SignedProperties></etsi:QualifyingProperties></ds:Object></ds:Signature></factura>]]></comprobante>
</autorizacion></Archivo>
      </ConsultarArchivoResponse>
   </s:Body>
</s:Envelope>
```

{% endtab %}
{% endtabs %}
