Block a user
mort-workspace (sha-115f5e1)
Published 2026-05-03 04:26:02 +00:00 by steve
Installation
docker pull gitea.stevedudenhoeffer.com/steve/mort-workspace:sha-115f5e1sha256:a43dceaf033ee8d491d7182ecb6312b2c8fd899cfa93d9a042478c4c392ecc26
Images
| Digest | OS / Arch | Size |
|---|---|---|
| 81adb5a307 | linux/amd64 | 1.4 GiB |
Image Layers ( linux/amd64)
| # debian.sh --arch 'amd64' out/ 'bookworm' '@1776729600' |
| RUN /bin/sh -c groupadd --gid 1000 node && useradd --uid 1000 --gid node --shell /bin/bash --create-home node # buildkit |
| ENV NODE_VERSION=22.22.2 |
| RUN /bin/sh -c ARCH= OPENSSL_ARCH= && dpkgArch="$(dpkg --print-architecture)" && case "${dpkgArch##*-}" in amd64) ARCH='x64' OPENSSL_ARCH='linux-x86_64';; ppc64el) ARCH='ppc64le' OPENSSL_ARCH='linux-ppc64le';; s390x) ARCH='s390x' OPENSSL_ARCH='linux*-s390x';; arm64) ARCH='arm64' OPENSSL_ARCH='linux-aarch64';; armhf) ARCH='armv7l' OPENSSL_ARCH='linux-armv4';; i386) ARCH='x86' OPENSSL_ARCH='linux-elf';; *) echo "unsupported architecture"; exit 1 ;; esac && set -ex && apt-get update && apt-get install -y ca-certificates curl wget gnupg dirmngr xz-utils libatomic1 --no-install-recommends && rm -rf /var/lib/apt/lists/* && export GNUPGHOME="$(mktemp -d)" && for key in 5BE8A3F6C8A5C01D106C0AD820B1A390B168D356 DD792F5973C6DE52C432CBDAC77ABFA00DDBF2B7 CC68F5A3106FF448322E48ED27F5E38D5B0A215F 8FCCA13FEF1D0C2E91008E09770F7A9A5AE15600 890C08DB8579162FEE0DF9DB8BEAB4DFCF555EF4 C82FA3AE1CBEDC6BE46B9360C43CEC45C17AB93C 108F52B48DB57BB0CC439B2997B01419BD92F80A A363A499291CBBC940DD62E41F10027AF002F8B0 ; do { gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" && gpg --batch --fingerprint "$key"; } || { gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" && gpg --batch --fingerprint "$key"; } ; done && curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-$ARCH.tar.xz" && curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc" && gpg --batch --decrypt --output SHASUMS256.txt SHASUMS256.txt.asc && gpgconf --kill all && rm -rf "$GNUPGHOME" && grep " node-v$NODE_VERSION-linux-$ARCH.tar.xz\$" SHASUMS256.txt | sha256sum -c - && tar -xJf "node-v$NODE_VERSION-linux-$ARCH.tar.xz" -C /usr/local --strip-components=1 --no-same-owner && rm "node-v$NODE_VERSION-linux-$ARCH.tar.xz" SHASUMS256.txt.asc SHASUMS256.txt && find /usr/local/include/node/openssl/archs -mindepth 1 -maxdepth 1 ! -name "$OPENSSL_ARCH" -exec rm -rf {} \; && apt-mark auto '.*' > /dev/null && find /usr/local -type f -executable -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); print so }' | sort -u | xargs -r dpkg-query --search | cut -d: -f1 | sort -u | xargs -r apt-mark manual && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false && ln -s /usr/local/bin/node /usr/local/bin/nodejs && node --version && npm --version && rm -rf /tmp/* # buildkit |
| ENV YARN_VERSION=1.22.22 |
| RUN /bin/sh -c set -ex && savedAptMark="$(apt-mark showmanual)" && apt-get update && apt-get install -y ca-certificates curl wget gnupg dirmngr --no-install-recommends && rm -rf /var/lib/apt/lists/* && export GNUPGHOME="$(mktemp -d)" && for key in 6A010C5166006599AA17F08146C2130DFD2497F5 ; do { gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" && gpg --batch --fingerprint "$key"; } || { gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" && gpg --batch --fingerprint "$key"; } ; done && curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz" && curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz.asc" && gpg --batch --verify yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz && gpgconf --kill all && rm -rf "$GNUPGHOME" && mkdir -p /opt && tar -xzf yarn-v$YARN_VERSION.tar.gz -C /opt/ && ln -s /opt/yarn-v$YARN_VERSION/bin/yarn /usr/local/bin/yarn && ln -s /opt/yarn-v$YARN_VERSION/bin/yarnpkg /usr/local/bin/yarnpkg && rm yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz && apt-mark auto '.*' > /dev/null && { [ -z "$savedAptMark" ] || apt-mark manual $savedAptMark > /dev/null; } && find /usr/local -type f -executable -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); print so }' | sort -u | xargs -r dpkg-query --search | cut -d: -f1 | sort -u | xargs -r apt-mark manual && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false && yarn --version && rm -rf /tmp/* # buildkit |
| COPY docker-entrypoint.sh /usr/local/bin/ # buildkit |
| ENTRYPOINT ["docker-entrypoint.sh"] |
| CMD ["node"] |
| RUN /bin/sh -c apt-get update && apt-get install -y --no-install-recommends git curl ca-certificates jq ripgrep sudo python3 python3-pip python3-venv ffmpeg imagemagick ghostscript tesseract-ocr libmagic1 poppler-utils libreoffice-calc-nogui libreoffice-writer-nogui libreoffice-impress-nogui fonts-liberation fonts-dejavu-core libglib2.0-0 libnss3 libatk1.0-0 libatk-bridge2.0-0 libcups2 libdrm2 libgbm1 libxcomposite1 libxdamage1 libxfixes3 libxrandr2 libpango-1.0-0 libcairo2 libasound2 libxshmfence1 libx11-xcb1 && rm -rf /var/lib/apt/lists/* # buildkit |
| RUN /bin/sh -c sed -i 's/rights="none" pattern="PDF"/rights="read|write" pattern="PDF"/' /etc/ImageMagick-6/policy.xml 2>/dev/null || true # buildkit |
| RUN /bin/sh -c npm install -g @anthropic-ai/claude-code @playwright/mcp # buildkit |
| ENV PLAYWRIGHT_BROWSERS_PATH=/opt/playwright-browsers |
| RUN /bin/sh -c npx -p @playwright/mcp playwright install --with-deps chromium && chmod -R o+rwx /opt/playwright-browsers # buildkit |
| RUN /bin/sh -c pip3 install --no-cache-dir --break-system-packages playwright python-docx openpyxl python-pptx pypdf pdfplumber pdf2image mammoth Pillow imageio imageio-ffmpeg pytesseract pandas numpy matplotlib beautifulsoup4 lxml markdown pyyaml requests python-magic chardet xlrd csvkit mcp-server-fetch # buildkit |
| RUN /bin/sh -c python3 -m playwright install --with-deps chromium # buildkit |
| COPY scripts/ask-user-mcp.py /usr/local/bin/ask-user-mcp # buildkit |
| RUN /bin/sh -c chmod +x /usr/local/bin/ask-user-mcp # buildkit |
| RUN /bin/sh -c mkdir -p /etc/claude && cat > /etc/claude/mcp.json <<'MCPJSON' {"mcpServers":{"fetch":{"command":"mcp-server-fetch"},"playwright":{"command":"npx","args":["@playwright/mcp","--headless","--browser","chromium"]},"ask-user":{"command":"/usr/local/bin/ask-user-mcp"}}} MCPJSON # buildkit |
| COPY skills/ /skills/ # buildkit |
| RUN /bin/sh -c chmod -R +x /skills/*/claude/skills/*/scripts/*.sh 2>/dev/null || true # buildkit |
| RUN /bin/sh -c for manifest in /skills/*/skill.toml; do if [ -f "$manifest" ]; then apt_deps=$(grep -A 100 '^\[deps\]' "$manifest" | grep '^apt' | sed 's/apt *= *\[//;s/\]//;s/"//g;s/,/ /g' || true); if [ -n "$apt_deps" ]; then apt-get update && apt-get install -y --no-install-recommends $apt_deps && rm -rf /var/lib/apt/lists/*; fi; fi; done # buildkit |
| COPY scripts/entrypoint.sh /entrypoint.sh # buildkit |
| RUN /bin/sh -c chmod +x /entrypoint.sh # buildkit |
| RUN /bin/sh -c useradd -m -s /bin/bash claude && echo 'claude ALL=(ALL) NOPASSWD: ALL' > /etc/sudoers.d/claude && chmod 0440 /etc/sudoers.d/claude && mkdir -p /workspace /output && chown claude:claude /workspace /output # buildkit |
| USER claude |
| RUN /bin/sh -c mkdir -p /home/claude/.claude && cat > /home/claude/.claude/settings.json <<'SETTINGS' {"permissions":{"allow":["Bash(*)","Read","Write","Edit","MultiEdit","Glob","Grep","WebFetch(*)","WebSearch(*)","NotebookEdit","Agent","TodoWrite","TodoRead","TaskCreate","TaskUpdate"]}} SETTINGS # buildkit |
| WORKDIR /workspace |
| ENTRYPOINT ["/entrypoint.sh"] |
Details
2026-05-03 04:26:02 +00:00
Versions (120)
View all
Container
0
OCI / Docker
latest
2026-05-16
sha-6833138
2026-05-16
sha-86bed1a
2026-05-16
sha-2875b8b
2026-05-16
sha-7452fd3
2026-05-16