# Cloudflare Workers

### Requisitos previos

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

* [Obtener un access\_token de Afip SDK](https://app.afipsdk.com)
* Tener instalado [Wrangler CLI](https://developers.cloudflare.com/workers/wrangler/install-and-update/)

### 1. Instalación

Creá un nuevo Worker con Wrangler e instalá la librería de Afip SDK.

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

```bash
npm create cloudflare@latest afipsdk
cd afipsdk
npm install @afipsdk/afip.js
```

{% endtab %}
{% endtabs %}

Agregá el access token de AfipSDK como secreto del Worker.

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

```bash
wrangler secret put AFIPSDK_ACCESS_TOKEN
```

{% endtab %}
{% endtabs %}

Luego modificá el archivo `worker-configuration.d.ts`.

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

```typescript
interface Env {
		AFIPSDK_ACCESS_TOKEN: string;
		//AFIP_CERT: string;
		//AFIP_KEY: string;
	}
```

{% 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](#usar-tu-propio-certificado-opcional), al final te mostramos cómo.

{% tabs %}
{% tab title="src/index.ts" %}

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

let afip: Afip;

export default {
	async fetch(request: Request, env: Env): Promise<Response> {
		if (!afip) {
			afip = new Afip({
				CUIT: 20409378472,
				access_token: env.AFIPSDK_ACCESS_TOKEN,
			});
		}

		// 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 los secrets 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 %}

Asignar el valor obtenido en su correspondiente secret:

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

```bash
wrangler secret put AFIP_CERT
wrangler secret put AFIP_KEY
```

{% endtab %}
{% endtabs %}

Luego los leemos desde el parámetro `env` en la función:

{% tabs %}
{% tab title="src/index.ts" %}
{% code fullWidth="true" %}

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

let afip: Afip;

export default {
	async fetch(request: Request, env: Env): Promise<Response> {
		if (!afip) {
			// Certificado y Key almacenados como secrets del Worker
			afip = new Afip({
				cert: atob(env.AFIP_CERT),
				key: atob(env.AFIP_KEY),
				CUIT: 20111111112,
				access_token: env.AFIPSDK_ACCESS_TOKEN, // Obtenido de https://app.afipsdk.com
			});
		}
	},
};
```

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