# Internacional

## GET /api/quantis/v2/rates/international/

Devuelve tasas de cambio para aproximadamente 170 monedas del mundo relativas al USD, obtenidas de openexchangerates.

| | |
|---|---|
| **Método** | `GET` |
| **URL** | `https://app.vzla.io/api/quantis/v2/rates/international/` |
| **Autenticación** | `Authorization: Bearer vzlaio_...` |
| **Parámetros** | Ninguno |

### Solicitud

```bash
curl --request GET \
  --url 'https://app.vzla.io/api/quantis/v2/rates/international/' \
  --header 'Authorization: Bearer vzlaio_TU_TOKEN_AQUI'
```

---

### Respuesta

#### `data`

| Campo | Tipo | Descripción |
|---|---|---|
| `timestamp` | string (datetime ISO 8601) | Cuándo se obtuvieron estos datos de openexchangerates |
| `base` | string | Siempre `"USD"` — todas las tasas son relativas a 1 USD |
| `rates` | object | Mapa de código de moneda → tasa de cambio (número) |

Los valores de tasa son números, no strings. El objeto `rates` contiene aproximadamente 170 códigos de moneda.

#### `meta`

| Campo | Tipo | Descripción |
|---|---|---|
| `source` | string | Siempre `"openexchangerates"` |

---

### Encabezados de respuesta

| Encabezado | Descripción |
|---|---|
| `X-API-Version` | `2.0` |
| `X-Quota-Limit` | Tu límite mensual de solicitudes |
| `X-Quota-Remaining` | Solicitudes restantes este mes |
| `X-Quota-Reset` | Timestamp ISO 8601 del próximo reinicio de cuota |
| `X-Request-ID` | UUID de esta solicitud |

---

### Ejemplo de respuesta

```json
{
  "data": {
    "timestamp": "2026-05-06T19:46:46.339127+00:00",
    "base": "USD",
    "rates": {
      "AED": 3.67315,
      "ARS": 1387.7501,
      "BRL": 4.9412,
      "CLP": 896.65,
      "COP": 3713.473403,
      "EUR": 0.851096,
      "GBP": 0.735602,
      "JPY": 144.886,
      "MXN": 19.5831,
      "PEN": 3.65965
    }
  },
  "meta": {
    "source": "openexchangerates"
  }
}
```

Arriba se muestra solo un subconjunto representativo de las ~170 monedas disponibles.

---

### Códigos de estado HTTP

| Código | Significado |
|---|---|
| `200 OK` | Éxito. |
| `401 Unauthorized` | Token ausente o inválido. |
| `405 Method Not Allowed` | Solo se admite GET. |
| `429 Too Many Requests` | Cuota mensual agotada. |
| `500 Internal Server Error` | Error del servidor. Reintenta después de un momento. |

#### 401 — sin encabezado Authorization

```json
{
  "error": {
    "code": "auth_missing",
    "message": "Authentication credentials were not provided"
  }
}
```

#### 401 — token inválido

```json
{
  "error": {
    "code": "auth_token_unknown",
    "message": "Invalid token format"
  }
}
```

#### 429

```json
{
  "error": {
    "code": "quota_exceeded",
    "message": "Monthly quota limit exceeded.",
    "details": {
      "reset_at": "2026-06-01T00:00:00Z"
    }
  }
}
```
**Note:** Este endpoint tiene caché de **30 minutos**.