# Deno Deploy

### Requisitos previos

Para poder seguir esta guía, primero necesitarás:

* [Obtener un access\_token de Afip SDK](https://app.afipsdk.com)

### 1. Instalación

Deno Deploy no requiere instalación de dependencias. Podés importar paquetes de npm directamente usando el prefijo `npm:`.

Agrega el access token de AfipSDK como variable de entorno desde el dashboard de Deno Deploy, en la sección **Settings > Environment Variables** de tu proyecto.

### 2. Crear una instancia de la clase Afip

Para usar los Web Services de ARCA se necesita un certificado digital, pero con Afip SDK podés empezar en modo desarrollo usando el CUIT 20-40937847-2 sin necesidad de uno.

Si preferís [usar tu propio certificado](#usar-tu-propio-certificado-opcional), al final te mostramos cómo.

En Deno Deploy, los paquetes npm se importan con el prefijo `npm:`.

{% tabs %}
{% tab title="main.ts" %}

```typescript
import Afip from 'npm:@afipsdk/afip.js';

const afip = new Afip({
  CUIT: 20409378472,
  access_token: Deno.env.get('AFIPSDK_ACCESS_TOKEN'),
});

Deno.serve(async (_req: Request) => {
  // Tu llamada de afipSDK aqui
});
```

{% endtab %}
{% endtabs %}

### 3. Llamar al método del Web Service que necesites

Con la instancia creada ya podés realizar las llamadas a los Web Services que necesites.

{% content-ref url="../../siguientes-pasos/web-services" %}
[web-services](https://docs.afipsdk.com/siguientes-pasos/web-services)
{% endcontent-ref %}

Si el Web Service que necesitás no se encuentra en la lista de la documentación, podés llamarlo siguiendo esta guía:

{% content-ref url="../../siguientes-pasos/web-services/otro-web-service" %}
[otro-web-service](https://docs.afipsdk.com/siguientes-pasos/web-services/otro-web-service)
{% endcontent-ref %}

Podés usar la referencia de la API para obtener ejemplos de cómo usar los métodos de todos los web services de ARCA.

{% embed url="<https://afipsdk.com/docs/api-reference/introduction/>" %}

***

### Usar tu propio certificado <sup><sub>(Opcional)<sub></sup>

Primero, obtenemos el certificado siguiendo esta guía.

{% embed url="<https://afipsdk.com/blog/como-obtener-certificado-para-web-services-arca/>" fullWidth="false" %}

Para agregar las variables de ambiente primero debemos obtener el valor de .cert y .key en base64 (guardalo ya que se nos pedirá luego). En la consola ejecutaremos este comando para copiar el valor al portapapeles:

{% tabs %}
{% tab title="Git Bash" %}

```bash
base64 -w 0 afip-cert.crt | clip
base64 -w 0 afip-key.key | clip
```

{% endtab %}

{% tab title="Linux" %}

```bash
base64 -w 0 afip-cert.crt | xclip -selection clipboard
base64 -w 0 afip-key.key | xclip -selection clipboard
```

{% endtab %}
{% endtabs %}

El valor del certificado y la key deben almacenarse como **variables de entorno** del proyecto desde el dashboard de Deno Deploy, en la sección **Settings > Environment Variables**.

Y luego los leemos desde las variables de entorno en la función:

{% tabs %}
{% tab title="main.ts" %}
{% code fullWidth="true" %}

```typescript
import Afip from 'npm:@afipsdk/afip.js';

// Certificado y Key almacenados como variables de entorno
const afip = new Afip({
  cert: atob(Deno.env.get('AFIP_CERT')),
  key: atob(Deno.env.get('AFIP_KEY')),
  CUIT: 20111111112,
  access_token: Deno.env.get('AFIPSDK_ACCESS_TOKEN'), // Obtenido de https://app.afipsdk.com
});

```

{% endcode %}
{% endtab %}
{% endtabs %}
