Requisitos previos
- Un monedero EVM en Base controlado por el agente (clave privada en una variable de entorno o gestor de secretos).
- Una pequeña cantidad de ETH en Base para gas (el staking son dos transacciones:
approvey luegostake). - Cualquier cantidad no nula de VVV para hacer staking. El endpoint de minteo solo requiere que el monedero tenga un saldo de sVVV no nulo, por lo que 1 VVV es suficiente para acuñar una clave. Consulta Pagar la inferencia para saber qué necesitas para llamar realmente a los endpoints de pago.
Pasos
Haz staking de VVV con Venice
Haz staking del VVV en el Smart Contract de staking de Venice en 
Cuando se confirma la segunda transacción, el saldo de VVV del monedero disminuye y su saldo de sVVV aumenta en la misma cantidad. El endpoint de minteo lee el saldo de sVVV para confirmar que el monedero tiene staking.
0x321b7ff75154472B18EDb199033fF4D116F340Ff. Son dos transacciones:approve(spender, amount)en el token VVV, dondespenderes el contrato de staking.stake(amount)en el contrato de staking.

Solicita un token de validación
Llama a La respuesta contiene un campo
GET /api/v1/api_keys/generate_web3_key para obtener un token de corta duración firmado por Venice. El endpoint no está autenticado.token. El token expira 15 minutos después de su emisión, así que fírmalo y envíalo bastante antes.Firma el token con el monedero de staking
Firma la cadena del token sin procesar con el monedero que tiene el VVV en staking. Es un
personal_sign estándar sobre los bytes del token. Tanto ethers.Wallet.signMessage(token) como account.signMessage({ message: token }) de viem producen la firma correcta.Acuña la API key
Haz Campos obligatorios:
POST de la dirección, la firma y el token al mismo endpoint, junto con el tipo de clave que quieras.address, signature, token, apiKeyType (INFERENCE o ADMIN).Campos opcionales: description, expiresAt, consumptionLimit (limita el gasto total en esta clave, denominado en usd, vcu o diem).En caso de éxito, la respuesta contiene la cadena apiKey acuñada. Guárdala en el almacén de secretos del agente y úsala como un token Bearer normal (Authorization: Bearer <key>).Ejemplo de extremo a extremo
El ejemplo siguiente usa un monedero real desde una variable de entorno en lugar de uno generado aleatoriamente. Un monedero aleatorio no tiene VVV en staking y el minteo se rechazará con el errorWallet has no staked VVV on Base.
Referencia de errores
El endpoint devuelve mensajes de error específicos y accionables. Mapéalos en el agente para que pueda decidir si reintentar, solicitar un nuevo token o detenerse.| Estado | El mensaje de error contiene | Significado | Qué hacer |
|---|---|---|---|
400 | Invalid wallet address | El campo address no es una dirección EVM válida. | Corrige la dirección y reenvía. |
400 | JWT has expired | El token de validación expiró antes de firmarlo y enviarlo. | Solicita un nuevo token, fírmalo y envíalo de inmediato. |
400 | JWT signature is invalid | El token no fue firmado por Venice (probablemente alterado o fabricado). | Usa siempre un token nuevo del endpoint GET. |
400 | JWT claims are invalid | El emisor o la audiencia del token no coinciden con lo que Venice espera. | Usa el token sin modificar devuelto por el endpoint GET. |
400 | JWT is malformed | El token enviado no es un JWT. | Asegúrate de enviar la cadena token exacta devuelta por el endpoint GET. |
400 | Wallet signature does not match | La signature no coincide con la address para el token dado. | Firma los bytes del token sin procesar con el monedero propietario de address. |
400 | Could not verify wallet signature | La llamada RPC para verificar la firma falló (transitorio). | Reintenta con backoff. |
400 | Wallet has no staked VVV on Base | El monedero tiene saldo de sVVV cero. | Haz staking de VVV primero y reintenta. |
Pagar la inferencia
Acuñar una clave y poder llamar a endpoints de pago con ella son dos cosas distintas. Una clave recién acuñada se autentica correctamente, pero no puede llamar a endpoints de pago (como/chat/completions) hasta que la cuenta del monedero tenga un saldo gastable.
La clave acuñada puede gastar de la cuenta de usuario en este orden de prioridad: DIEM, luego créditos incluidos y luego USD.
| Fuente de financiación | ¿Autónoma? | Cómo |
|---|---|---|
| DIEM por staking de VVV | Sí | La asignación diaria de DIEM del monedero es proporcional a su parte en la piscina de staking. La cuenta necesita al menos 0,1 DIEM en staking para que cualquier DIEM sea gastable. Cantidades mayores en staking obtienen proporcionalmente más DIEM diario, renovado cada época (00:00 UTC). |
| USD vía Stripe | No (navegador) | Inicia sesión en venice.ai con el mismo monedero (Sign-In-With-Ethereum). El dashboard encuentra el registro de usuario existente. Añade créditos en Settings, API. |
| Suscripción cripto de Coinbase | No (navegador) | Inicio de sesión con el mismo monedero y luego suscríbete a través del dashboard. El flujo redirige a Coinbase Commerce para el pago real, por lo que no se puede automatizar por script. |
| Onramp de Coinbase | No (navegador) | Inicio de sesión con el mismo monedero y luego usa el widget de onramp en el dashboard. Alojado en la UI de Coinbase. |
- Hacer más staking de VVV para que la asignación diaria de DIEM cubra el gasto del agente. La clave acuñada lo recoge automáticamente.
- Usa el flujo de monedero x402 en lugar de la API key. Con x402, el agente firma un mensaje Sign-In-With-X por solicitud, recarga directamente con USDC en Base o Solana mediante
POST /api/v1/x402/top-upy paga por solicitud. El saldo de USDC x402 está vinculado al monedero, no al usuario, por lo que no aparece como saldo para la clave Bearer acuñada, pero sí permite que el mismo monedero pague la inferencia de forma programática.
Recursos relacionados
Cripto y agentes
Usa Venice tanto como proveedor de modelos como capa RPC de blockchain para agentes autónomos.
Autenticación de monedero x402
Paga por solicitud con USDC en Base o Solana, sin necesidad de API key.
Endpoint Generate Web3 API Key
Referencia del endpoint de minteo.
Guía estándar de API Key
Para los usuarios que prefieren acuñar una clave desde el dashboard.