-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile
90 lines (78 loc) · 2.74 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
FROM quay.io/fedora/httpd-24:20250108 AS upstream
FROM ghcr.io/radiorabe/ubi9-minimal:0.8.0 AS build
ENV APP_ROOT=/opt/app-root
ENV HTTPD_VERSION=2.4
RUN mkdir -p /mnt/rootfs \
&& microdnf install -y \
--releasever 9 \
--installroot /mnt/rootfs \
--nodocs \
--noplugins \
--config /etc/dnf/dnf.conf \
--setopt install_weak_deps=0 \
--setopt cachedir=/var/cache/dnf \
--setopt reposdir=/etc/yum.repos.d \
--setopt varsdir=/etc/yum.repos.d \
coreutils-single \
findutils \
glibc-minimal-langpack \
hostname \
httpd-core \
mod_auth_openidc \
mod_ldap \
mod_md \
mod_security \
mod_security_crs \
mod_session \
mod_ssl \
sscg \
nss_wrapper-libs \
&& cp \
/etc/pki/ca-trust/source/anchors/rabe-ca.crt \
/mnt/rootfs/etc/pki/ca-trust/source/anchors/ \
&& chmod a-s \
/mnt/rootfs/usr/bin/* \
/mnt/rootfs/usr/sbin/* \
/mnt/rootfs/usr/libexec/*/* \
&& rm -rf \
/mnt/rootfs/var/cache/* \
/mnt/rootfs/var/log/dnf* \
/mnt/rootfs/var/log/yum.*
FROM scratch as app
ENV PLATFORM=el9 \
SUMMARY="Apache HTTPD Image for RaBe" \
APP_ROOT=/opt/app-root \
HOME=/opt/app-root/src \
STI_SCRIPTS_PATH=/usr/libexec/s2i \
STI_SCRIPTS_URL=image:///usr/libexec/s2i \
HTTPD_VERSION=2.4 \
HTTPD_CONTAINER_SCRIPTS_PATH=/usr/share/container-scripts/httpd/ \
HTTPD_APP_ROOT=/opt/app-root \
HTTPD_CONFIGURATION_PATH=/opt/app-root/etc/httpd.d \
HTTPD_MAIN_CONF_PATH=/etc/httpd/conf \
HTTPD_MAIN_CONF_MODULES_D_PATH=/etc/httpd/conf.modules.d \
HTTPD_MAIN_CONF_D_PATH=/etc/httpd/conf.d \
HTTPD_TLS_CERT_PATH=/etc/httpd/tls \
HTTPD_VAR_RUN=/var/run/httpd \
HTTPD_DATA_PATH=/var/www \
HTTPD_DATA_ORIG_PATH=/var/www \
HTTPD_LOG_PATH=/var/log/httpd
COPY --from=build /mnt/rootfs/ /
COPY --from=upstream ${STI_SCRIPTS_PATH} ${STI_SCRIPTS_PATH}
COPY --from=upstream ${HTTPD_CONTAINER_SCRIPTS_PATH} ${HTTPD_CONTAINER_SCRIPTS_PATH}
COPY --from=upstream ${APP_ROOT} ${APP_ROOT}
COPY --from=upstream /usr/bin/run-httpd /usr/bin/run-httpd
COPY --from=upstream /usr/libexec/httpd-prepare /usr/libexec/httpd-prepare
RUN useradd -u 1001 -r -g 0 -d ${HOME} -c "Default Application User" default \
&& chown -R 1001:0 /etc/httpd/conf/ \
&& update-ca-trust \
&& /usr/libexec/httpd-prepare \
&& mkdir /etc/httpd/conf.d/local_configs \
&& chown -R 1001:0 /etc/httpd/conf.d/local_configs \
&& echo "IncludeOptional conf.d/local_configs/*.conf" \
>> ${HTTPD_MAIN_CONF_PATH}/httpd.conf
VOLUME /etc/httpd/state
WORKDIR /opt/app-root/src
USER 1001
STOPSIGNAL SIGQUIT
CMD ["/usr/bin/run-httpd"]