-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDockerfile
More file actions
73 lines (62 loc) · 2.74 KB
/
Dockerfile
File metadata and controls
73 lines (62 loc) · 2.74 KB
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
FROM debian:sid AS bootstrap
# Avoid warnings by switching to noninteractive
ENV DEBIAN_FRONTEND=noninteractive
ARG TARGETARCH
ARG PACKAGE_GROUP=base
# Create Arch Linux rootfs directory
RUN mkdir -p /rootfs
# Copy customized pacstrap script to root directory
COPY pacstrap-docker /
# Copy customized rootfs files to rootfs directory
COPY rootfs/any /rootfs
COPY rootfs/${TARGETARCH} /rootfs
# Set build environment and generate Arch Linux rootfs image
RUN \
apt update && \
apt install -y --no-install-recommends arch-install-scripts pacman-package-manager makepkg curl ca-certificates xz-utils zstd && \
cp -rf /rootfs/etc/pacman.conf /etc/pacman.conf && \
sed -i "s/^CheckSpace/#CheckSpace/" /etc/pacman.conf && \
mkdir -p /etc/pacman.d && \
cp -rf /rootfs/etc/pacman.d/mirrorlist /etc/pacman.d/mirrorlist && \
BOOTSTRAP_EXTRA_PACKAGES="" && \
if case "$TARGETARCH" in arm64) true;; *) false;; esac; then \
EXTRA_KEYRING_FILES=" \
archlinuxarm-revoked \
archlinuxarm-trusted \
archlinuxarm.gpg \
" && \
EXTRA_KEYRING_URL="https://raw.githubusercontent.com/archlinuxarm/PKGBUILDs/master/core/archlinuxarm-keyring/" && \
for EXTRA_KEYRING_FILE in $EXTRA_KEYRING_FILES; do \
curl "$EXTRA_KEYRING_URL$EXTRA_KEYRING_FILE" -o /usr/share/keyrings/$EXTRA_KEYRING_FILE -L; \
done && \
BOOTSTRAP_EXTRA_PACKAGES="archlinuxarm-keyring"; \
elif case "$TARGETARCH" in ppc64le) true;; *) false;; esac; then \
EXTRA_KEYRING_FILES=" \
archpower-revoked \
archpower-trusted \
archpower.gpg \
" && \
EXTRA_KEYRING_URL="https://raw.githubusercontent.com/kth5/archpower/master/archpower-keyring/" && \
for EXTRA_KEYRING_FILE in $EXTRA_KEYRING_FILES; do \
curl "$EXTRA_KEYRING_URL$EXTRA_KEYRING_FILE" -o /usr/share/keyrings/$EXTRA_KEYRING_FILE -L; \
done && \
BOOTSTRAP_EXTRA_PACKAGES="archpower-keyring"; \
else \
mkdir /tmp/archlinux-keyring && \
curl -L https://archlinux.org/packages/core/any/archlinux-keyring/download/ | unzstd | tar -C /tmp/archlinux-keyring -xv && \
mv /tmp/archlinux-keyring/usr/share/pacman/keyrings/* /usr/share/keyrings/; \
fi && \
pacman-key --init && \
pacman-key --populate && \
./pacstrap-docker /rootfs $PACKAGE_GROUP $BOOTSTRAP_EXTRA_PACKAGES && \
rm /rootfs/var/lib/pacman/sync/*
FROM scratch
COPY --from=bootstrap /rootfs /
ENV LANG=en_US.UTF-8
RUN locale-gen
RUN \
ln -sf /usr/lib/os-release /etc/os-release && \
pacman-key --init && \
pacman-key --populate && \
bash -c "rm -rf etc/pacman.d/gnupg/{openpgp-revocs.d/,private-keys-v1.d/,pubring.gpg~,gnupg.S.}*"
CMD ["/usr/bin/bash"]