Prérequis
- Un portefeuille EVM sur Base contrôlé par l’agent (clé privée dans une variable d’environnement ou un gestionnaire de secrets).
- Une petite quantité d’ETH sur Base pour les frais de gas (le staking est constitué de deux transactions :
approvepuisstake). - Une quantité non nulle de VVV à staker. L’endpoint de création requiert seulement que le portefeuille ait un solde sVVV non nul, donc 1 VVV suffit pour générer une clé. Voir Payer pour l’inférence pour ce dont vous avez réellement besoin pour appeler les endpoints payants.
Étapes
Staker du VVV avec Venice
Stakez le VVV dans le Smart Contract de Staking Venice à l’adresse 
Lorsque la deuxième transaction est confirmée, le solde VVV du portefeuille diminue et son solde sVVV augmente du même montant. L’endpoint de création lit le solde sVVV pour confirmer que le portefeuille est staké.
0x321b7ff75154472B18EDb199033fF4D116F340Ff. Il s’agit de deux transactions :approve(spender, amount)sur le token VVV, oùspenderest le contrat de staking.stake(amount)sur le contrat de staking.

Demander un token de validation
Appelez La réponse contient un champ
GET /api/v1/api_keys/generate_web3_key pour obtenir un token à courte durée de vie signé par Venice. L’endpoint n’est pas authentifié.token. Le token expire 15 minutes après son émission, signez-le donc et soumettez-le bien avant.Signer le token avec le portefeuille de staking
Signez la chaîne brute du token avec le portefeuille qui détient le VVV staké. Il s’agit d’un
personal_sign standard sur les octets du token. À la fois ethers.Wallet.signMessage(token) et account.signMessage({ message: token }) de viem produisent la signature correcte.Créer la clé API
Faites un Champs requis :
POST de l’adresse, de la signature et du token au même endpoint, avec le type de clé que vous souhaitez.address, signature, token, apiKeyType (INFERENCE ou ADMIN).Champs optionnels : description, expiresAt, consumptionLimit (plafonne la dépense totale sur cette clé, libellée en usd, vcu ou diem).En cas de succès, la réponse contient la chaîne apiKey créée. Stockez-la dans le secret store de l’agent et utilisez-la comme un token Bearer normal (Authorization: Bearer <key>).Exemple de bout en bout
L’exemple ci-dessous utilise un vrai portefeuille depuis une variable d’environnement plutôt qu’un portefeuille généré aléatoirement. Un portefeuille aléatoire n’a pas de VVV staké et la création sera rejetée avec l’erreurWallet has no staked VVV on Base.
Référence des erreurs
L’endpoint renvoie des messages d’erreur spécifiques et exploitables. Mappez-les dans l’agent pour qu’il puisse décider de réessayer, demander un nouveau token ou s’arrêter.| Statut | Le message d’erreur contient | Ce que cela signifie | Que faire |
|---|---|---|---|
400 | Invalid wallet address | Le champ address n’est pas une adresse EVM valide. | Corrigez l’adresse et resoumettez. |
400 | JWT has expired | Le token de validation a expiré avant que vous ne le signiez et le soumettiez. | Demandez un nouveau token, signez-le et soumettez-le immédiatement. |
400 | JWT signature is invalid | Le token n’a pas été signé par Venice (probablement modifié ou fabriqué). | Utilisez toujours un nouveau token de l’endpoint GET. |
400 | JWT claims are invalid | L’émetteur ou l’audience du token ne correspond pas à ce que Venice attend. | Utilisez le token non modifié renvoyé par l’endpoint GET. |
400 | JWT is malformed | Le token soumis n’est pas un JWT. | Assurez-vous d’envoyer exactement la chaîne token renvoyée par l’endpoint GET. |
400 | Wallet signature does not match | La signature ne correspond pas à l’address pour le token donné. | Signez les octets bruts du token avec le portefeuille qui possède address. |
400 | Could not verify wallet signature | L’appel RPC pour vérifier la signature a échoué (transitoire). | Réessayez avec backoff. |
400 | Wallet has no staked VVV on Base | Le portefeuille a un solde sVVV nul. | Stakez d’abord du VVV, puis réessayez. |
Payer pour l’inférence
Générer une clé et pouvoir appeler des endpoints payants avec elle sont deux choses distinctes. Une clé fraîchement créée s’authentifie correctement mais ne peut pas appeler les endpoints payants (comme/chat/completions) tant que le compte du portefeuille n’a pas un solde dépensable.
La clé créée peut dépenser depuis le compte utilisateur dans cet ordre de priorité : DIEM, puis crédits groupés, puis USD.
| Source de financement | Autonome ? | Comment |
|---|---|---|
| DIEM depuis le staking VVV | Oui | L’allocation quotidienne de DIEM du portefeuille est proportionnelle à sa part dans le pool de staking. Le compte a besoin d’au moins 0,1 DIEM staké pour que tout DIEM soit dépensable. Les enjeux plus importants rapportent proportionnellement plus de DIEM quotidiens, rafraîchis à chaque epoch (00:00 UTC). |
| USD via Stripe | Non (navigateur) | Connectez-vous à venice.ai avec le même portefeuille (Sign-In-With-Ethereum). Le tableau de bord trouve l’enregistrement utilisateur existant. Ajoutez des crédits dans Settings, API. |
| Abonnement crypto Coinbase | Non (navigateur) | Même connexion par portefeuille, puis abonnez-vous via le tableau de bord. Le flux redirige vers Coinbase Commerce pour le paiement effectif, il ne peut donc pas être piloté depuis un script. |
| Onramp Coinbase | Non (navigateur) | Même connexion par portefeuille, puis utilisez le widget onramp dans le tableau de bord. Hébergé sur l’UI de Coinbase. |
- Staker plus de VVV pour que l’allocation quotidienne de DIEM couvre la dépense de l’agent. La clé créée le récupère automatiquement.
- Utiliser le flux portefeuille x402 au lieu de la clé API. Avec x402, l’agent signe un message Sign-In-With-X par requête, recharge directement avec de l’USDC sur Base ou Solana via
POST /api/v1/x402/top-up, et paie par requête. Le solde USDC x402 est lié au portefeuille, pas à l’utilisateur, donc il n’apparaît pas comme solde pour la clé Bearer créée, mais cela permet au même portefeuille de payer l’inférence de manière programmatique.
Ressources connexes
Crypto et agents
Utilisez Venice à la fois comme fournisseur de modèle et comme couche RPC blockchain pour les agents autonomes.
Authentification par portefeuille x402
Payez par requête avec de l’USDC sur Base ou Solana, sans clé API requise.
Endpoint de génération de clé API Web3
Référence de l’endpoint pour l’endpoint de création.
Guide de clé API standard
Pour les utilisateurs qui préfèrent générer une clé depuis le tableau de bord.