vaultwarden/Dockerfile

81 lines
2.1 KiB
Docker
Raw Normal View History

2018-02-09 19:00:55 -05:00
# Using multistage build:
# https://docs.docker.com/develop/develop-images/multistage-build/
# https://whitfin.io/speeding-up-rust-docker-builds/
####################### VAULT BUILD IMAGE #######################
FROM node:8-alpine as vault
2018-08-27 21:21:22 -04:00
ENV VAULT_VERSION "v2.2.0"
2018-07-27 05:01:33 -04:00
ENV URL "https://github.com/bitwarden/web.git"
RUN apk add --update-cache --upgrade \
curl \
git \
tar
RUN git clone -b $VAULT_VERSION --depth 1 $URL web-build
WORKDIR /web-build
COPY /docker/set-vault-baseurl.patch /web-build/
RUN git apply set-vault-baseurl.patch
RUN npm run sub:init && npm install
RUN npm run dist \
&& mv build /web-vault
2018-02-09 19:00:55 -05:00
########################## BUILD IMAGE ##########################
# Musl build image for statically compiled binary
2018-08-25 04:29:50 -04:00
FROM clux/muslrust:nightly-2018-08-24 as build
2018-02-09 19:00:55 -05:00
# Creates a dummy project used to grab dependencies
RUN USER=root cargo init --bin
2018-02-09 19:00:55 -05:00
# Copies over *only* your manifests and vendored dependencies
COPY ./Cargo.* ./
COPY ./libs ./libs
2018-06-12 18:48:18 -04:00
COPY ./rust-toolchain ./rust-toolchain
2018-02-09 19:00:55 -05:00
# Builds your dependencies and removes the
# dummy project, except the target folder
# This folder contains the compiled dependencies
2018-02-09 19:00:55 -05:00
RUN cargo build --release
RUN find . -not -path "./target*" -delete
# Copies the complete project
# To avoid copying unneeded files, use .dockerignore
COPY . .
# Builds again, this time it'll just be
# your actual source files being built
RUN cargo build --release
######################## RUNTIME IMAGE ########################
# Create a new stage with a minimal image
# because we already have a binary built
FROM alpine:3.8
2018-02-09 19:00:55 -05:00
ENV ROCKET_ENV "staging"
ENV ROCKET_WORKERS=10
2018-08-17 16:25:08 -04:00
ENV SSL_CERT_DIR=/etc/ssl/certs
2018-02-09 19:00:55 -05:00
# Install needed libraries
RUN apk add \
2018-08-17 16:25:08 -04:00
openssl\
ca-certificates \
&& rm /var/cache/apk/*
2018-02-09 19:00:55 -05:00
RUN mkdir /data
VOLUME /data
EXPOSE 80
# Copies the files from the context (env file and web-vault)
2018-02-09 19:00:55 -05:00
# and the binary from the "build" stage to the current stage
COPY .env .
COPY Rocket.toml .
COPY --from=vault /web-vault ./web-vault
COPY --from=build /volume/target/x86_64-unknown-linux-musl/release/bitwarden_rs .
2018-02-09 19:00:55 -05:00
# Configures the startup!
CMD ./bitwarden_rs