From 6b0e9b5f4d7935af3331cfce736b1906cfe79cf5 Mon Sep 17 00:00:00 2001 From: johba Date: Sat, 28 Mar 2026 17:33:09 +0000 Subject: [PATCH] feat: add entrypoint for llama dev-agent container (#29) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Simple while-true loop that runs dev-poll with llama backend env vars. No cron, no guard files, no activation state — just polls and spawns. Repo auto-cloned on first start. To be used with a separate agents-llama compose service that sets ANTHROPIC_BASE_URL to the llama-server address. Co-Authored-By: Claude Opus 4.6 (1M context) --- docker/agents/entrypoint-llama.sh | 33 +++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100755 docker/agents/entrypoint-llama.sh diff --git a/docker/agents/entrypoint-llama.sh b/docker/agents/entrypoint-llama.sh new file mode 100755 index 0000000..0363102 --- /dev/null +++ b/docker/agents/entrypoint-llama.sh @@ -0,0 +1,33 @@ +#!/usr/bin/env bash +set -euo pipefail + +LOG_DIR="/home/agent/data/logs/dev" +mkdir -p "$LOG_DIR" /home/agent/data + +log() { + printf "[%s] llama-loop: %s\n" "$(date -u +%Y-%m-%d\ %H:%M:%S\ UTC)" "$*" | tee -a "$LOG_DIR/llama-loop.log" +} + +log "Starting llama dev-agent loop" +log "Backend: ${ANTHROPIC_BASE_URL:-not set}" +log "Claude CLI: $(claude --version 2>&1 || echo not found)" + +# Clone repo if not present +if [ ! -d "${PROJECT_REPO_ROOT}/.git" ]; then + log "Cloning repo..." + mkdir -p "$(dirname "$PROJECT_REPO_ROOT")" + chown -R agent:agent /home/agent/repos 2>/dev/null || true + su -s /bin/bash agent -c "git clone http://dev-bot:${FORGE_TOKEN}@forgejo:3000/${FORGE_REPO:-johba/disinto}.git ${PROJECT_REPO_ROOT}" + log "Repo cloned" +fi + +log "Entering poll loop (interval: ${POLL_INTERVAL:-300}s)" + +# Run dev-poll in a loop as agent user +while true; do + su -s /bin/bash agent -c " + cd /home/agent/disinto && \ + bash dev/dev-poll.sh ${PROJECT_TOML:-projects/disinto.toml} + " >> "$LOG_DIR/llama-loop.log" 2>&1 || true + sleep "${POLL_INTERVAL:-300}" +done