2026-03-19 07:25:25 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
# action-poll.sh — Cron scheduler: find open 'action' issues, spawn action-agent
|
|
|
|
|
#
|
|
|
|
|
# An issue is ready for action if:
|
|
|
|
|
# - It is open and labeled 'action'
|
2026-03-21 17:05:09 +00:00
|
|
|
# - No tmux session named action-{project}-{issue_num} is already active
|
2026-03-19 07:25:25 +00:00
|
|
|
#
|
|
|
|
|
# Usage:
|
|
|
|
|
# cron every 10min
|
|
|
|
|
# action-poll.sh [projects/foo.toml] # optional project config
|
|
|
|
|
|
|
|
|
|
set -euo pipefail
|
|
|
|
|
|
|
|
|
|
export PROJECT_TOML="${1:-}"
|
|
|
|
|
source "$(dirname "$0")/../lib/env.sh"
|
2026-03-23 21:46:59 +00:00
|
|
|
# shellcheck source=../lib/guard.sh
|
|
|
|
|
source "$(dirname "$0")/../lib/guard.sh"
|
|
|
|
|
check_active action
|
2026-03-19 07:25:25 +00:00
|
|
|
|
2026-03-21 14:25:13 +00:00
|
|
|
LOGFILE="${FACTORY_ROOT}/action/action-poll-${PROJECT_NAME:-default}.log"
|
2026-03-19 07:25:25 +00:00
|
|
|
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)"
|
|
|
|
|
|
|
|
|
|
log() {
|
|
|
|
|
printf '[%s] poll: %s\n' "$(date -u '+%Y-%m-%d %H:%M:%S UTC')" "$*" >> "$LOGFILE"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# --- Memory guard ---
|
|
|
|
|
AVAIL_MB=$(awk '/MemAvailable/{printf "%d", $2/1024}' /proc/meminfo)
|
|
|
|
|
if [ "$AVAIL_MB" -lt 2000 ]; then
|
|
|
|
|
log "SKIP: only ${AVAIL_MB}MB available (need 2000MB)"
|
|
|
|
|
exit 0
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
# --- Find open 'action' issues ---
|
|
|
|
|
log "scanning for open action issues"
|
fix: Replace Codeberg dependency with local Forgejo instance (#611)
- Add setup_forge() to bin/disinto: provisions Forgejo via Docker,
creates admin + bot users (dev-bot, review-bot), generates API
tokens, creates repo, and pushes code — all automated
- Rename env vars: CODEBERG_TOKEN→FORGE_TOKEN, REVIEW_BOT_TOKEN→
FORGE_REVIEW_TOKEN, CODEBERG_REPO→FORGE_REPO, CODEBERG_API→
FORGE_API, CODEBERG_WEB→FORGE_WEB, CODEBERG_BOT_USERNAMES→
FORGE_BOT_USERNAMES (with backwards-compat fallbacks)
- Rename API helpers: codeberg_api()→forge_api(), codeberg_api_all()
→forge_api_all() (with compat aliases)
- Add forge_url field to project TOML; load-project.sh derives
FORGE_API/FORGE_WEB from forge_url + repo
- Update parse_repo_slug() to accept any host URL, not just codeberg
- Forgejo data stored under ~/.disinto/forgejo/ (not in factory repo)
- Update all 58 files: agent scripts, formulas, docs, site HTML
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-23 16:57:12 +00:00
|
|
|
ACTION_ISSUES=$(curl -sf -H "Authorization: token ${FORGE_TOKEN}" \
|
|
|
|
|
"${FORGE_API}/issues?state=open&labels=action&limit=50&type=issues") || true
|
2026-03-19 07:25:25 +00:00
|
|
|
|
|
|
|
|
if [ -z "$ACTION_ISSUES" ] || [ "$ACTION_ISSUES" = "null" ]; then
|
|
|
|
|
log "no action issues found"
|
|
|
|
|
exit 0
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
COUNT=$(printf '%s' "$ACTION_ISSUES" | jq 'length')
|
|
|
|
|
if [ "$COUNT" -eq 0 ]; then
|
|
|
|
|
log "no action issues found"
|
|
|
|
|
exit 0
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
log "found ${COUNT} open action issue(s)"
|
|
|
|
|
|
|
|
|
|
# Spawn action-agent for each issue that has no active tmux session.
|
|
|
|
|
# Only one agent is spawned per poll to avoid memory pressure; the next
|
|
|
|
|
# poll picks up remaining issues.
|
|
|
|
|
for i in $(seq 0 $((COUNT - 1))); do
|
|
|
|
|
ISSUE_NUM=$(printf '%s' "$ACTION_ISSUES" | jq -r ".[$i].number")
|
2026-03-21 17:05:09 +00:00
|
|
|
SESSION="action-${PROJECT_NAME}-${ISSUE_NUM}"
|
2026-03-19 07:25:25 +00:00
|
|
|
|
|
|
|
|
if tmux has-session -t "$SESSION" 2>/dev/null; then
|
|
|
|
|
log "issue #${ISSUE_NUM}: session ${SESSION} already active, skipping"
|
|
|
|
|
continue
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
LOCKFILE="/tmp/action-agent-${ISSUE_NUM}.lock"
|
|
|
|
|
if [ -f "$LOCKFILE" ]; then
|
|
|
|
|
LOCK_PID=$(cat "$LOCKFILE" 2>/dev/null || echo "")
|
|
|
|
|
if [ -n "$LOCK_PID" ] && kill -0 "$LOCK_PID" 2>/dev/null; then
|
|
|
|
|
log "issue #${ISSUE_NUM}: agent starting (PID ${LOCK_PID}), skipping"
|
|
|
|
|
continue
|
|
|
|
|
fi
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
log "spawning action-agent for issue #${ISSUE_NUM}"
|
2026-03-19 22:16:01 +00:00
|
|
|
nohup "${SCRIPT_DIR}/action-agent.sh" "$ISSUE_NUM" "$PROJECT_TOML" >> "$LOGFILE" 2>&1 &
|
2026-03-19 07:25:25 +00:00
|
|
|
log "started action-agent PID $! for issue #${ISSUE_NUM}"
|
|
|
|
|
break
|
|
|
|
|
done
|