forked from uvdesk/community-skeleton
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Dockerfile
88 lines (80 loc) · 3.31 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
FROM ubuntu:18.04
LABEL maintainer="[email protected]"
ENV GOSU_VERSION 1.11
RUN adduser uvdesk -q --disabled-password --gecos ""
# Install base supplimentary packages
RUN apt-get update && apt-get -y upgrade \
&& apt-get update && apt-get install -y software-properties-common \
&& apt-get update && DEBIAN_FRONTEND=noninteractive apt-get -y install \
curl \
wget \
git \
unzip \
apache2 \
mysql-server \
php7.2 \
libapache2-mod-php7.2 \
php-xml \
php7.2-imap \
php7.2-mysql \
php-mailparse \
ca-certificates; \
if ! command -v gpg; then \
apt-get install -y --no-install-recommends gnupg2 dirmngr; \
elif gpg --version | grep -q '^gpg (GnuPG) 1\.'; then \
apt-get install -y --no-install-recommends gnupg-curl; \
fi;
COPY ./.docker/config/apache2/env /etc/apache2/envvars
COPY ./.docker/config/apache2/httpd.conf /etc/apache2/apache2.conf
COPY ./.docker/config/apache2/vhost.conf /etc/apache2/sites-available/000-default.conf
COPY ./.docker/config/php/php.ini /etc/php/7.2/apache2/php.ini
COPY ./.docker/bash/uvdesk-entrypoint.sh /usr/local/bin/
COPY . /var/www/uvdesk/
RUN \
# Update apache configurations
a2enmod php7.2 rewrite; \
chmod +x /usr/local/bin/uvdesk-entrypoint.sh; \
# Install gosu for stepping-down from root to a non-privileged user during container startup
dpkgArch="$(dpkg --print-architecture | awk -F- '{ print $NF }')"; \
wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$dpkgArch" \
&& wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$dpkgArch.asc"; \
# Verify gosu installation
export GNUPGHOME="$(mktemp -d)" \
&& gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4 \
&& gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosu \
&& gpgconf --kill all \
&& chmod +x /usr/local/bin/gosu \
&& gosu nobody true; \
\
# Download and verify composer installer signature
wget -O /usr/local/bin/composer.php "https://getcomposer.org/installer"; \
actualSig="$(wget -q -O - https://composer.github.io/installer.sig)"; \
currentSig="$(shasum -a 384 /usr/local/bin/composer.php | awk '{print $1}')"; \
if [ "$currentSig" != "$actualSig" ]; then \
echo "Warning: Failed to verify composer signature."; \
exit 1; \
fi; \
# Install composer
php /usr/local/bin/composer.php --quiet --filename=/usr/local/bin/composer \
&& chmod +x /usr/local/bin/composer; \
# Assign user uvdesk the ownership of source directory
chown -R uvdesk:uvdesk /var/www; \
# Clean up files
rm -rf \
"$GNUPGHOME" \
/var/lib/apt/lists/* \
/usr/local/bin/gosu.asc \
/usr/local/bin/composer.php \
/var/www/bin \
/var/www/html \
/var/www/uvdesk/.docker;
WORKDIR /var/www/uvdesk
RUN composer update
RUN composer install && \
chmod 777 /var/www/uvdesk/config/packages/uvdesk.yaml && \
chmod 777 /var/www/uvdesk/config/packages/swiftmailer.yaml && \
chmod 777 /var/www/uvdesk/config/packages/uvdesk_mailbox.yaml
# Change working directory to uvdesk source
WORKDIR /var/www
ENTRYPOINT ["uvdesk-entrypoint.sh"]
CMD ["/bin/bash"]