2021-02-09 17:05:00 +01:00
|
|
|
FROM alpine:latest as dist
|
2021-06-13 02:09:57 +02:00
|
|
|
LABEL maintainer aynic.os <support+docker@asycn.io>
|
2022-02-07 15:09:51 +01:00
|
|
|
ARG DOCKER_BUILD_DIR
|
2021-06-13 02:09:57 +02:00
|
|
|
|
2022-10-12 02:50:02 +02:00
|
|
|
ARG MACHINE="$(uname -m)"
|
|
|
|
ARG SYSTEM="$(uname -s)"
|
|
|
|
ARG ARCH="$(echo ${MACHINE} |awk '/x86_64/ {print "amd64"}; /aarch64/ {print "arm64"}')"
|
|
|
|
ARG OS="$(echo ${SYSTEM} |awk '{print tolower($0)}')"
|
|
|
|
|
|
|
|
ARG PACKER_VERSION=1.8.3
|
2021-02-09 17:05:00 +01:00
|
|
|
|
|
|
|
RUN apk --no-cache add \
|
|
|
|
ansible \
|
|
|
|
bash \
|
|
|
|
git \
|
|
|
|
qemu \
|
|
|
|
qemu-system-x86_64 \
|
|
|
|
qemu-img \
|
|
|
|
openssl \
|
|
|
|
socat \
|
|
|
|
wget
|
|
|
|
|
2022-10-12 02:50:02 +02:00
|
|
|
ADD https://releases.hashicorp.com/packer/${PACKER_VERSION}/packer_${PACKER_VERSION}_${OS}_${ARCH}.zip ./
|
2021-02-09 17:05:00 +01:00
|
|
|
ADD https://releases.hashicorp.com/packer/${PACKER_VERSION}/packer_${PACKER_VERSION}_SHA256SUMS ./
|
|
|
|
|
2022-10-12 02:50:02 +02:00
|
|
|
RUN sed -i '/.*'"${OS}"'_'"${ARCH}"'.zip/!d' packer_${PACKER_VERSION}_SHA256SUMS \
|
|
|
|
&& sha256sum -cs packer_${PACKER_VERSION}_SHA256SUMS \
|
|
|
|
&& unzip "packer_${PACKER_VERSION}_${OS}_${ARCH}.zip" -d /bin \
|
|
|
|
&& rm -f "packer_${PACKER_VERSION}_${OS}_${ARCH}.zip"
|
2021-02-09 17:05:00 +01:00
|
|
|
|
|
|
|
ENTRYPOINT ["/bin/packer"]
|
|
|
|
|
2021-06-13 02:09:57 +02:00
|
|
|
FROM dist as master
|
2021-02-09 17:05:00 +01:00
|
|
|
ARG DOCKER_BUILD_DIR
|
|
|
|
ARG UID
|
|
|
|
ARG USER
|
|
|
|
ENV UID=${UID}
|
|
|
|
ENV GID=${UID}
|
|
|
|
ENV USER=${USER}
|
|
|
|
|
|
|
|
# If we provide a specific UID
|
|
|
|
RUN let $UID >/dev/null 2>&1 \
|
|
|
|
# Remove user with $UID if it is not our $USER
|
|
|
|
&& if [ "$(getent passwd $UID |awk 'BEGIN {FS=":"} {print $1}')" != "$USER" ]; then \
|
|
|
|
sed -i '/^'$(getent passwd $UID |awk 'BEGIN {FS=":"} {print $1}')':x:'$UID':/d' /etc/passwd; \
|
|
|
|
sed -i '/^'$(getent group $GID |awk 'BEGIN {FS=":"} {print $1}')':x:'$GID':/d' /etc/group; \
|
|
|
|
fi \
|
|
|
|
# Force $UID if our $USER already exists
|
|
|
|
&& sed -i 's/^'$USER':x:[0-9]\+:[0-9]\+:/'$USER':x:'$UID':'$GID':/' /etc/passwd \
|
|
|
|
&& sed -i 's/^'$USER':x:[0-9]\+:/'$USER':x:'$GID':/' /etc/group \
|
|
|
|
# Create $USER if it does not exist
|
|
|
|
&& if [ "$(getent passwd $UID)" = "" ]; then \
|
|
|
|
echo "$USER:x:$UID:$GID::/home/$USER:/bin/false" >> /etc/passwd; \
|
|
|
|
echo "$USER:!:$(($(date +%s) / 60 / 60 / 24)):0:99999:7:::" >> /etc/shadow; \
|
|
|
|
echo "$USER:x:$GID:" >> /etc/group; \
|
|
|
|
fi \
|
|
|
|
&& mkdir -p /home/$USER \
|
|
|
|
&& chown $UID:$GID /home/$USER \
|
|
|
|
|| true
|
|
|
|
|
|
|
|
USER $USER
|