81 lines
2.3 KiB
Docker
81 lines
2.3 KiB
Docker
FROM oven/bun:canary-slim AS bun-bin
|
|
|
|
FROM smanx/opencode:latest AS base
|
|
USER root
|
|
ARG UBUNTU_APT_MIRROR=mirrors.aliyun.com
|
|
ARG PYPI_INDEX_URL=https://pypi.tuna.tsinghua.edu.cn/simple
|
|
ARG PYPI_TRUSTED_HOST=pypi.tuna.tsinghua.edu.cn
|
|
ENV VIRTUAL_ENV=/opt/venv
|
|
ENV PATH="$VIRTUAL_ENV/bin:/root/.local/bin:$PATH"
|
|
ENV PIP_INDEX_URL=${PYPI_INDEX_URL}
|
|
ENV PIP_TRUSTED_HOST=${PYPI_TRUSTED_HOST}
|
|
ENV UV_INDEX_URL=${PYPI_INDEX_URL}
|
|
|
|
RUN sed -i "s|http://archive.ubuntu.com|https://${UBUNTU_APT_MIRROR}|g; s|http://security.ubuntu.com|https://${UBUNTU_APT_MIRROR}|g" /etc/apt/sources.list 2>/dev/null || true && \
|
|
sed -i "s|http://archive.ubuntu.com|https://${UBUNTU_APT_MIRROR}|g; s|http://security.ubuntu.com|https://${UBUNTU_APT_MIRROR}|g" /etc/apt/sources.list.d/*.sources 2>/dev/null || true && \
|
|
apt-get update && apt-get install -y --no-install-recommends \
|
|
curl \
|
|
unzip \
|
|
python3 \
|
|
python3-venv && \
|
|
curl -LsSf https://astral.sh/uv/install.sh | sh && \
|
|
ln -s /root/.local/bin/uv /usr/local/bin/uv && \
|
|
ln -sf /usr/bin/python3 /usr/local/bin/python && \
|
|
mkdir -p /root/.config/pip && \
|
|
printf "[global]\nindex-url = %s\ntrusted-host = %s\n" "$PIP_INDEX_URL" "$PIP_TRUSTED_HOST" > /root/.config/pip/pip.conf && \
|
|
uv venv "$VIRTUAL_ENV" && \
|
|
uv pip install --python "$VIRTUAL_ENV/bin/python" \
|
|
--index-url "$UV_INDEX_URL" \
|
|
pip \
|
|
setuptools \
|
|
wheel \
|
|
requests \
|
|
httpx \
|
|
pydantic \
|
|
python-dotenv \
|
|
rich \
|
|
ipython \
|
|
pytest && \
|
|
rm -rf /var/lib/apt/lists/*
|
|
|
|
COPY --from=bun-bin /usr/local/bin/bun /usr/local/bin/bun
|
|
|
|
FROM base AS deps
|
|
|
|
WORKDIR /app
|
|
|
|
COPY package.json bun.lock ./
|
|
COPY .opencode/package.json .opencode/bun.lock ./.opencode/
|
|
RUN bun install --frozen-lockfile
|
|
|
|
FROM base AS build
|
|
WORKDIR /app
|
|
|
|
COPY tsconfig.json opencode.json README.md ./
|
|
COPY src ./src
|
|
COPY .opencode ./.opencode
|
|
RUN bun run check
|
|
|
|
FROM base AS runner
|
|
WORKDIR /app
|
|
|
|
ENV NODE_ENV=production
|
|
ENV HOST=0.0.0.0
|
|
ENV PORT=8787
|
|
|
|
COPY --from=deps /app/node_modules ./node_modules
|
|
COPY --from=deps /app/.opencode/node_modules ./.opencode/node_modules
|
|
COPY package.json bun.lock ./
|
|
COPY tsconfig.json opencode.json ./
|
|
COPY src ./src
|
|
COPY .opencode ./.opencode
|
|
|
|
COPY entrypoint.sh /entrypoint.sh
|
|
RUN chmod +x /entrypoint.sh
|
|
|
|
ENTRYPOINT ["/entrypoint.sh"]
|
|
COPY .opencode ./.opencode
|
|
|
|
EXPOSE 8787
|
|
CMD ["bun", "src/server.ts"]
|