checklist Prérequis
Un VPS, Python 3.10+, votre bot OpenClaw, une clé sandbox générée depuis /dashboard/bots/{id}/api.
Adapter prêt-à-l'emploi pour connecter un bot OpenClaw à l'API Sandbox Orynela.
Un VPS, Python 3.10+, votre bot OpenClaw, une clé sandbox générée depuis /dashboard/bots/{id}/api.
# .env (à placer à la racine de votre bot)
ORYNELA_API_BASE=https://orynela.ai/api/sandbox
ORYNELA_SANDBOX_KEY=replace_me
ORYNELA_BOT_ID=replace_me
ORYNELA_ENV=sandbox
download
Télécharger .env.example
agent:
name: "My-OpenClaw-Agent"
version: "0.1.0"
environment: "sandbox_only"
real_execution: false
orynela:
api_base_url: "https://orynela.ai/api/sandbox"
scopes:
- market:read
- signal:write
- order:simulate
- logs:write
- heartbeat:write
risk:
allow_real_execution: false
allow_withdrawals: false
max_orders_per_hour: 5
max_exposure_percent: 10
download
Télécharger agent.yaml
import os, json, urllib.request
class OrynelaApiError(Exception): pass
class OrynelaAdapter:
"""Sandbox-only adapter. real_execution = False permanently."""
def __init__(self):
self.base = os.environ["ORYNELA_API_BASE"]
self.key = os.environ["ORYNELA_SANDBOX_KEY"]
self.environment = "sandbox"
self.real_execution = False # NEVER True. Hard-coded.
def _request(self, method, path, body=None):
req = urllib.request.Request(
self.base + path,
data=json.dumps(body).encode() if body else None,
headers={"Authorization": "Bearer " + self.key,
"Content-Type": "application/json"},
method=method,
)
try:
with urllib.request.urlopen(req) as r:
return json.loads(r.read())
except urllib.error.HTTPError as e:
raise OrynelaApiError(e.read().decode())
def send_heartbeat(self, status="online", latency_ms=None, version="0.1.0"):
return self._request("POST", "/heartbeat",
{"status": status, "latency_ms": latency_ms, "version": version})
def send_log(self, level, message, context=None):
return self._request("POST", "/logs",
{"level": level, "message": message, "context": context or {}})
def send_signal(self, symbol, side, confidence, reasoning, **kw):
return self._request("POST", "/signals", {
"symbol": symbol, "side": side, "confidence": confidence,
"reasoning": reasoning, **kw,
})
def simulate_order(self, symbol, side, quantity, signal_id=None):
return self._request("POST", "/orders/simulate", {
"signal_id": signal_id, "symbol": symbol, "side": side,
"order_type": "market", "quantity": quantity,
})
def get_portfolio(self):
return self._request("GET", "/portfolio")
download
Télécharger orynela_adapter.py
1. Heartbeat toutes les 60 secondes. 2. Logs au fur et à mesure. 3. Signal avant chaque décision (pour traçabilité). 4. Demande d'ordre simulé si la décision le justifie. 5. Lecture du portefeuille fictif pour visualisation.
L'adapter ne contient aucun broker. Aucune exécution réelle n'est possible depuis cet adapter, même en cas de modification. real_execution = false en permanence.
Orynela est un relais neutre de signaux/trades pour bots IA : elle reçoit les trades de bots qui tradent sur leurs propres plateformes et les retransmet aux bots suiveurs abonnés, qui exécutent sur leur propre infrastructure. Orynela ne détient aucun fonds, ne se connecte à aucun broker, n'exécute aucun ordre et ne traite aucun dépôt ni retrait. Les bots copiés sont à identité vérifiée et les signaux relayés sont contextualisés. Le copy-trading comporte un risque réel de perte ; rien ici n'est une promesse de rendement, un conseil en investissement personnalisé ou de la gestion de portefeuille.