-
Notifications
You must be signed in to change notification settings - Fork 110
/
Copy pathDockerfile
98 lines (86 loc) · 3.03 KB
/
Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
# ==============================================================================
# This Docker file is designed support multi-architecture[1] images.
#
# How you build depends on your use case. If you only want to build
# for the architecture you're invoking docker from (host arch):
#
# docker build .
#
# However, if you want to build for another architecture or multiple
# architectures, use buildx[2]:
#
# docker buildx build --platform linux/arm64,linux/amd64 .
#
# Adding support for additional architectures requires editing the
# `case "$TARGETPLATFORM" in` in the build stage (and likely quite a
# bit of googling).
#
# 1: https://www.docker.com/blog/how-to-rapidly-build-multi-architecture-images-with-buildx
# 2: https://docs.docker.com/build/install-buildx
# ==============================================================================
# ------------------------------------------------------------------------------
# Cargo Build Stage
#
# Runs on native host architecture
# Cross compiles for target architecture
# ------------------------------------------------------------------------------
FROM --platform=$BUILDPLATFORM rust:alpine3.17 AS cargo-build
RUN apk add --no-cache --update \
clang15-libclang \
cmake \
g++ \
gcc \
libc-dev \
musl-dev \
protobuf \
tpm2-tss-dev
WORKDIR /tmp/helium_gateway
COPY . .
ARG BUILDPLATFORM
ARG TARGETPLATFORM
RUN \
case "$BUILDPLATFORM $TARGETPLATFORM" in \
"linux/amd64 linux/arm64") \
rustup target add aarch64-unknown-linux-musl ; \
echo "aarch64-unknown-linux-musl" > rust_target.txt ; \
echo "--target=aarch64-unknown-linux-musl" > cargo_flags.txt ; \
;; \
"linux/amd64 linux/amd64") \
echo > rust_target.txt ; \
echo "--features=tpm" > cargo_flags.txt ; \
;; \
*) \
exit 1 \
;; \
esac
ENV CC_aarch64_unknown_linux_musl=clang
ENV AR_aarch64_unknown_linux_musl=llvm-ar
ENV CARGO_TARGET_AARCH64_UNKNOWN_LINUX_MUSL_RUSTFLAGS="-Clink-self-contained=yes -Clinker=rust-lld"
ENV CARGO_TARGET_X86_64_UNKNOWN_LINUX_MUSL_RUSTFLAGS="-Ctarget-feature=-crt-static"
RUN cargo build --release $(cat cargo_flags.txt)
RUN mv target/$(cat rust_target.txt)/release/helium_gateway .
# ------------------------------------------------------------------------------
# Final Stage
#
# Run steps run in a VM based on the target architecture
# Produces image for target architecture
# ------------------------------------------------------------------------------
FROM alpine:3.17.3
ENV RUST_BACKTRACE=1
ENV GW_LISTEN="0.0.0.0:1680"
ARG TARGETPLATFORM
# We will never enable TPM on anything other than x86
RUN \
if [ "$TARGETPLATFORM" = "linux/amd64" ]; \
then apk add --no-cache --update \
libstdc++ \
tpm2-tss-esys \
tpm2-tss-fapi \
tpm2-tss-mu \
tpm2-tss-rc \
tpm2-tss-tcti-device ; \
fi
COPY --from=cargo-build /tmp/helium_gateway/helium_gateway /usr/local/bin/helium_gateway
RUN mkdir /etc/helium_gateway
COPY config/settings.toml /etc/helium_gateway/settings.toml
CMD ["helium_gateway", "server"]