| FROM rust:latest AS chef | |
| # We only pay the installation cost once, | |
| # it will be cached from the second build onwards | |
| RUN cargo install cargo-chef --locked | |
| WORKDIR /app | |
| FROM chef AS planner | |
| COPY . . | |
| RUN cargo chef prepare --recipe-path recipe.json | |
| FROM chef AS builder | |
| COPY --from=planner /app/recipe.json recipe.json | |
| # Build dependencies - this is the caching Docker layer! | |
| # Uncomment the line below if you want to use the `hybrid` caching feature. | |
| # RUN cargo chef cook --release --features redis-cache --recipe-path recipe.json | |
| # Comment the line below if you don't want to use the `In-Memory` caching feature. | |
| RUN cargo chef cook --release --recipe-path recipe.json | |
| # Uncomment the line below if you want to use the `no cache` feature. | |
| # RUN cargo chef cook --release --no-default-features --recipe-path recipe.json | |
| # Uncomment the line below if you want to use the `redis` caching feature. | |
| # RUN cargo chef cook --release --no-default-features --features redis-cache --recipe-path recipe.json | |
| # Build application | |
| COPY . . | |
| # Uncomment the line below if you want to use the `hybrid` caching feature. | |
| # RUN cargo install --path . --features redis-cache | |
| # Comment the line below if you don't want to use the `In-Memory` caching feature. | |
| RUN cargo install --path . | |
| # Uncomment the line below if you want to use the `no cache` feature. | |
| # RUN cargo install --path . --no-default-features | |
| # Uncomment the line below if you want to use the `redis` caching feature. | |
| # RUN cargo install --path . --no-default-features --features redis-cache | |
| # We do not need the Rust toolchain to run the binary! | |
| FROM gcr.io/distroless/cc-debian12 | |
| COPY --from=builder /app/public/ /opt/websurfx/public/ | |
| VOLUME ["/etc/xdg/websurfx/"] | |
| COPY --from=builder /usr/local/cargo/bin/* /usr/local/bin/ | |
| CMD ["websurfx"] | |