# Vercel Functions

### 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

Agregá la librería de Afip SDK en Node.js.

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

```bash
npm install @afipsdk/afip.js
```

{% endtab %}
{% endtabs %}

Agregá una variable de ambiente para el access token de AfipSDK.

{% tabs %}
{% tab title=".env.local" %}

```bash
#Obtenido de https://app.afipsdk.com
AFIPSDK_ACCESS_TOKEN=TU_ACCESS_TOKEN 

```

{% endtab %}
{% endtabs %}

### 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](https://github.com/AfipSDK/afip-gitbook/blob/main/integracion/serverless/vercel-functions.js.md#usar-tu-propio-certificado-opcional), al final te mostramos cómo.

Crea un archivo en tu proyecto de Next.js en, por ejemplo, `app/api/afipsdk/route.ts`.

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

```javascript
import Afip from '@afipsdk/afip.js';

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

export async function POST() {
	// 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" %}

Y luego lo agregamos a la instancia de la clase Afip.

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

```javascript
import fs from 'fs';
import Afip from '@afipsdk/afip.js';

// Certificado (Puede estar guardado en archivos, DB, etc)
const cert = fs.readFileSync('ruta/a/certificado.crt', {encoding: 'utf8'});

// Key (Puede estar guardado en archivos, DB, etc)
const key = fs.readFileSync('ruta/a/key.key', {encoding: 'utf8'});

// CUIT del certificado
const CUIT = 20111111112;

const afip = new Afip({
	cert,
	key,
	CUIT,
	access_token: process.env.AFIPSDK_ACCESS_TOKEN, // Obtenido de https://app.afipsdk.com
});
```

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