2025-04-20 08:22:17 -07:00
|
|
|
#!/bin/bash
|
2025-04-20 14:50:12 -07:00
|
|
|
set -euo pipefail
|
2025-04-20 08:22:17 -07:00
|
|
|
|
|
|
|
|
IMAGE=gemini-code-sandbox
|
2025-04-20 14:49:02 -07:00
|
|
|
WORKDIR=/sandbox/$(basename "$PWD")
|
2025-04-21 09:17:17 -07:00
|
|
|
CLI_DIST=/usr/local/share/npm-global/lib/node_modules/\@gemini-code/cli
|
2025-04-20 08:22:17 -07:00
|
|
|
|
|
|
|
|
# use docker if installed, otherwise try to use podman instead
|
|
|
|
|
if command -v docker &> /dev/null; then
|
|
|
|
|
CMD=docker
|
|
|
|
|
elif command -v podman &> /dev/null; then
|
|
|
|
|
CMD=podman
|
|
|
|
|
else
|
2025-04-21 07:50:18 -07:00
|
|
|
echo "ERROR: missing docker or podman for sandboxing"
|
2025-04-20 08:22:17 -07:00
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
|
2025-04-21 09:17:17 -07:00
|
|
|
# use interactive tty mode and auto-remove container on exit
|
|
|
|
|
run_args=(-it --rm)
|
|
|
|
|
|
|
|
|
|
# mount current directory as $WORKDIR inside container
|
|
|
|
|
run_args+=(-v "$PWD:$WORKDIR")
|
|
|
|
|
|
|
|
|
|
# name container after image, plus numeric suffix to avoid conflicts
|
|
|
|
|
INDEX=0
|
|
|
|
|
while $CMD ps -a --format "{{.Names}}" | grep -q "$IMAGE-$INDEX"; do
|
|
|
|
|
INDEX=$((INDEX + 1))
|
|
|
|
|
done
|
|
|
|
|
run_args+=(--name "$IMAGE-$INDEX")
|
|
|
|
|
|
2025-04-21 07:50:18 -07:00
|
|
|
# run gemini-code in sandbox container
|
|
|
|
|
# use empty --authfile to skip unnecessary auth refresh overhead
|
2025-04-21 09:17:17 -07:00
|
|
|
$CMD run "${run_args[@]}" --authfile <(echo '{}') --workdir "$WORKDIR" "$IMAGE" node "$CLI_DIST"
|