# Dockerfile.stage — Stage build: landing server only. # # neuron-web runs on port 8080 (landing page server). # soul-demo is now a separate Cloud Run service (soul-demo-stage). # # neuron-web binary is pre-built by CI on the host runner before this # Dockerfile runs. This keeps the Docker build single-stage with no # compilation and no network downloads. # # CI pre-build steps (in stage.yaml): # - neuron-web: built by `elb build` → dist/neuron-landing # Last rebuilt: 2026-05-11 FROM ubuntu:24.04 ENV DEBIAN_FRONTEND=noninteractive RUN apt-get update \ && apt-get install -y --no-install-recommends \ libcurl4t64 \ libssl3t64 \ ca-certificates \ && rm -rf /var/lib/apt/lists/* \ && groupadd -r landing && useradd -r -g landing landing \ && mkdir -p /srv/landing/assets /srv/landing/js /srv/landing/shares \ && chown -R landing:landing /srv/landing # neuron-web binary — produced by `elb build` in CI (linux/amd64) COPY dist/neuron-landing /usr/local/bin/neuron-web RUN chmod +x /usr/local/bin/neuron-web COPY src/assets /srv/landing/assets COPY dist/js /srv/landing/js COPY src/llms.txt /srv/landing/llms.txt # Pre-rendered HTML shells (about, terms, enterprise-terms, index) used as # fallback when the El page-builder hasn't been seeded yet at startup. # chown to the landing user so the El runtime's fs_write at startup can # rewrite them with the freshly-rendered page (extracted JS asset paths, # updated chat widget, etc.). Without this they stay as their COPY'd root- # owned shells and the served HTML never reflects post-COPY source edits. COPY src/about.html src/terms.html src/enterprise-terms.html src/index.html /srv/landing/ RUN chown landing:landing /srv/landing/about.html /srv/landing/terms.html /srv/landing/enterprise-terms.html /srv/landing/index.html /srv/landing/llms.txt COPY dist/entrypoint.sh /usr/local/bin/entrypoint.sh RUN chmod +x /usr/local/bin/entrypoint.sh ENV LANDING_ROOT=/srv/landing ENV PORT=8080 EXPOSE 8080 CMD ["/usr/local/bin/entrypoint.sh"]