diff --git a/changemaker-control-panel/agent/Dockerfile b/changemaker-control-panel/agent/Dockerfile index cf3aca7..7833ee0 100644 --- a/changemaker-control-panel/agent/Dockerfile +++ b/changemaker-control-panel/agent/Dockerfile @@ -12,6 +12,12 @@ FROM node:20-alpine # shells out to (upgrade-check.sh, upgrade.sh, backup.sh). Without them, every # /upgrade/* and /backup/* call returns "command not found" failures. RUN apk add --no-cache docker-cli docker-cli-compose git rsync bash curl jq python3 +# Agent runs as root, but the bind-mounted /app/instance is owned by the host +# user (UID 1000 = `node` inside the container). Modern git refuses to operate +# on repos with mismatched ownership without an explicit safe.directory entry. +# Wildcard whitelist all paths — the agent only mounts a single host directory +# anyway (the instance's project root). +RUN git config --system --add safe.directory '*' WORKDIR /app COPY package*.json ./ RUN npm ci --production