forked from TrueCloudLab/certificates
Merge pull request #910 from jschlyter/docker_hsm
Dockerfile for HSM-enabled Step CA
This commit is contained in:
commit
c82296b7cd
3 changed files with 43 additions and 5 deletions
|
@ -3,15 +3,15 @@ FROM golang:alpine AS builder
|
||||||
WORKDIR /src
|
WORKDIR /src
|
||||||
COPY . .
|
COPY . .
|
||||||
|
|
||||||
RUN apk add --no-cache \
|
RUN apk add --no-cache curl git make
|
||||||
curl \
|
RUN make V=1 bin/step-ca bin/step-awskms-init bin/step-cloudkms-init
|
||||||
git \
|
|
||||||
make && \
|
|
||||||
make V=1 bin/step-ca
|
|
||||||
|
|
||||||
FROM smallstep/step-cli:latest
|
FROM smallstep/step-cli:latest
|
||||||
|
|
||||||
COPY --from=builder /src/bin/step-ca /usr/local/bin/step-ca
|
COPY --from=builder /src/bin/step-ca /usr/local/bin/step-ca
|
||||||
|
COPY --from=builder /src/bin/step-awskms-init /usr/local/bin/step-awskms-init
|
||||||
|
COPY --from=builder /src/bin/step-cloudkms-init /usr/local/bin/step-cloudkms-init
|
||||||
|
|
||||||
USER root
|
USER root
|
||||||
RUN apk add --no-cache libcap && setcap CAP_NET_BIND_SERVICE=+eip /usr/local/bin/step-ca
|
RUN apk add --no-cache libcap && setcap CAP_NET_BIND_SERVICE=+eip /usr/local/bin/step-ca
|
||||||
|
|
34
docker/Dockerfile.step-ca.hsm
Normal file
34
docker/Dockerfile.step-ca.hsm
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
FROM golang:alpine AS builder
|
||||||
|
|
||||||
|
WORKDIR /src
|
||||||
|
COPY . .
|
||||||
|
|
||||||
|
RUN apk add --no-cache curl git make
|
||||||
|
RUN apk add --no-cache gcc musl-dev pkgconf pcsc-lite-dev
|
||||||
|
RUN make V=1 GOFLAGS="" build
|
||||||
|
|
||||||
|
|
||||||
|
FROM smallstep/step-cli:latest
|
||||||
|
|
||||||
|
COPY --from=builder /src/bin/step-ca /usr/local/bin/step-ca
|
||||||
|
COPY --from=builder /src/bin/step-awskms-init /usr/local/bin/step-awskms-init
|
||||||
|
COPY --from=builder /src/bin/step-cloudkms-init /usr/local/bin/step-cloudkms-init
|
||||||
|
COPY --from=builder /src/bin/step-pkcs11-init /usr/local/bin/step-pkcs11-init
|
||||||
|
COPY --from=builder /src/bin/step-yubikey-init /usr/local/bin/step-yubikey-init
|
||||||
|
|
||||||
|
USER root
|
||||||
|
RUN apk add --no-cache libcap && setcap CAP_NET_BIND_SERVICE=+eip /usr/local/bin/step-ca
|
||||||
|
RUN apk add --no-cache pcsc-lite pcsc-lite-libs
|
||||||
|
USER step
|
||||||
|
|
||||||
|
ENV CONFIGPATH="/home/step/config/ca.json"
|
||||||
|
ENV PWDPATH="/home/step/secrets/password"
|
||||||
|
|
||||||
|
VOLUME ["/home/step"]
|
||||||
|
STOPSIGNAL SIGTERM
|
||||||
|
HEALTHCHECK CMD step ca health 2>/dev/null | grep "^ok" >/dev/null
|
||||||
|
|
||||||
|
COPY docker/entrypoint.sh /entrypoint.sh
|
||||||
|
|
||||||
|
ENTRYPOINT ["/bin/bash", "/entrypoint.sh"]
|
||||||
|
CMD exec /usr/local/bin/step-ca --password-file $PWDPATH $CONFIGPATH
|
|
@ -53,6 +53,10 @@ function step_ca_init () {
|
||||||
mv $STEPPATH/password $PWDPATH
|
mv $STEPPATH/password $PWDPATH
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if [ -f /usr/sbin/pcscd ]; then
|
||||||
|
/usr/sbin/pcscd
|
||||||
|
fi
|
||||||
|
|
||||||
if [ ! -f "${STEPPATH}/config/ca.json" ]; then
|
if [ ! -f "${STEPPATH}/config/ca.json" ]; then
|
||||||
init_if_possible
|
init_if_possible
|
||||||
fi
|
fi
|
||||||
|
|
Loading…
Reference in a new issue