docker-claude/claude/Dockerfile

53 lines
1.9 KiB
Text
Raw Normal View History

FROM node:20-alpine
2026-04-14 20:11:24 +02:00
# Install runtime dependencies
RUN apk add --no-cache \
2026-04-15 19:18:39 +02:00
git \
curl \
ca-certificates \
2026-04-15 21:59:08 +02:00
bash
2026-04-14 20:11:24 +02:00
# Install kubectl — architecture-aware, checksum-verified
RUN KUBECTL_VERSION=$(curl -fsSL https://dl.k8s.io/release/stable.txt) \
2026-04-15 19:18:39 +02:00
&& ARCH=$(uname -m | sed 's/x86_64/amd64/;s/aarch64/arm64/') \
&& curl -fsSL "https://dl.k8s.io/release/${KUBECTL_VERSION}/bin/linux/${ARCH}/kubectl" \
-o /usr/local/bin/kubectl \
&& curl -fsSL "https://dl.k8s.io/release/${KUBECTL_VERSION}/bin/linux/${ARCH}/kubectl.sha256" \
-o /tmp/kubectl.sha256 \
&& echo "$(cat /tmp/kubectl.sha256) /usr/local/bin/kubectl" | sha256sum -c \
&& rm /tmp/kubectl.sha256 \
&& chmod +x /usr/local/bin/kubectl
# System-level Claude Code policy — owned by root, not writable by the node user.
# Restricts available models; cannot be bypassed via CLI flags or env vars.
COPY settings.json /etc/claude-code/managed-settings.json
# Install Claude Code globally
RUN curl -fsSL https://claude.ai/install.sh | ash -s stable
2026-04-15 19:18:39 +02:00
2026-04-14 20:11:24 +02:00
# Install MCP servers globally — entry points land in /usr/local/lib/node_modules/
RUN npm install -g \
2026-04-15 19:18:39 +02:00
@modelcontextprotocol/server-github \
@yoda.digital/gitlab-mcp-server \
@aashari/mcp-server-atlassian-jira \
@aashari/mcp-server-atlassian-confluence
# Workspace and Claude config dir — owned by the built-in node user (uid 1000).
# Pre-creating ~/.claude ensures the named volume is initialised with the
# correct ownership when first mounted (Docker copies image content into
# an empty named volume on first use).
RUN mkdir -p /workspace /home/node/.claude \
2026-04-15 19:18:39 +02:00
&& chown -R node:node /workspace /home/node/.claude
2026-04-14 20:11:24 +02:00
USER node
2026-04-14 20:11:24 +02:00
WORKDIR /workspace
# Proxy traffic through sidecar — override at runtime if needed
ENV HTTP_PROXY=http://proxy:3128
ENV HTTPS_PROXY=http://proxy:3128
ENV ALL_PROXY=http://proxy:3128
ENV NO_PROXY=localhost,127.0.0.1
ENTRYPOINT ["claude"]