Le sandbox est l'endroit où l'agent effectue ses tâches. Au lieu d'exécuter des commandes directement sur votre ordinateur (ce qui pourrait être risqué), l'agent les exécute à l'intérieur d'un conteneur Docker.
Le sandbox OpenHands par défaut (python-nodejs:python3.12-nodejs22 de nikolaik/python-nodejs) est livré avec certains paquets installés tels que Python et Node.js, mais peut nécessiter l'installation d'autres logiciels par défaut.
Vous avez deux options pour la personnalisation :
Si vous choisissez la première option, vous pouvez passer la section Créer Votre Image Docker.
Pour créer une image Docker personnalisée, elle doit être basée sur Debian.
Par exemple, si vous voulez qu'OpenHands ait ruby installé, créez un Dockerfile avec le contenu suivant :
FROM debian:latest
# Installer les paquets requis
RUN apt-get update && apt-get install -y ruby
Enregistrez ce fichier dans un dossier. Ensuite, construisez votre image Docker (par exemple, nommée custom-image) en naviguant vers le dossier dans le terminal et en exécutant :
docker build -t custom-image .
Cela produira une nouvelle image appelée custom-image, qui sera disponible dans Docker.
Notez que dans la configuration décrite dans ce document, OpenHands s'exécutera en tant qu'utilisateur "openhands" à l'intérieur du sandbox et donc tous les paquets installés via le docker file devraient être disponibles pour tous les utilisateurs du système, pas seulement root.
Tout d'abord, assurez-vous de pouvoir exécuter OpenHands en suivant les instructions dans Development.md.
Dans le fichier config.toml dans le répertoire OpenHands, définissez sandbox_base_container_image sur l'image que vous souhaitez utiliser. Cela peut être une image que vous avez déjà extraite ou une que vous avez construite :
[core]
...
sandbox_base_container_image="custom-image"
Exécutez OpenHands en exécutant make run dans le répertoire de niveau supérieur.
Veuillez vous référer à la section image docker personnalisée de la documentation d'exécution pour plus de détails.
useradd: UID 1000 is not uniqueSi vous voyez cette erreur dans la sortie de la console, c'est parce qu'OpenHands essaie de créer l'utilisateur openhands dans le sandbox avec un UID de 1000, mais cet UID est déjà utilisé dans l'image (pour une raison quelconque). Pour corriger cela, changez le champ sandbox_user_id dans le fichier config.toml à une valeur différente :
[core]
workspace_base="./workspace"
run_as_openhands=true
sandbox_base_container_image="custom_image"
sandbox_user_id="1001"
Si vous voyez une erreur concernant un port déjà utilisé ou indisponible, essayez de supprimer tous les conteneurs Docker en cours d'exécution (exécutez docker ps et docker rm sur les conteneurs pertinents) puis réexécutez make run.
Pour d'autres problèmes ou questions, rejoignez le Slack ou le Discord et demandez !