Mauro Torrez 0bcb81bb23
All checks were successful
continuous-integration/drone/push Build is passing
fix dockerfile sybtax
2019-10-12 17:33:20 -03:00

225 lines
6.8 KiB
Docker

# DO NOT EDIT: created by update.sh from Dockerfile-unit.template
FROM eumau/nginx-unit:1.12.0-php7.3
# entrypoint.sh and cron.sh dependencies
RUN set -ex; \
\
apt-get update; \
apt-get install -y --no-install-recommends \
rsync \
bzip2 \
busybox-static \
; \
rm -rf /var/lib/apt/lists/*; \
\
mkdir -p /var/spool/cron/crontabs; \
echo '*/15 * * * * php -f /var/www/html/cron.php' > /var/spool/cron/crontabs/www-data
# install the PHP extensions we need
# see https://docs.nextcloud.com/server/stable/admin_manual/installation/source_installation.html
RUN set -ex; \
\
apt-get update; \
apt-get install -y --no-install-recommends \
php-exif \
php-gd \
php-intl \
php-ldap \
php-opcache \
php-mysql \
php-pgsql \
php-sqlite3 \
php-zip \
php-apcu \
php-memcached \
php-redis \
php-imagick \
php-xml \
php-mbstring \
php-curl \
ssl-cert \
sudo \
; \
\
rm -rf /var/lib/apt/lists/*
# set recommended PHP.ini settings
# see https://docs.nextcloud.com/server/12/admin_manual/configuration_server/server_tuning.html#enable-php-opcache
RUN { \
echo 'opcache.enable=1'; \
echo 'opcache.interned_strings_buffer=8'; \
echo 'opcache.max_accelerated_files=10000'; \
echo 'opcache.memory_consumption=128'; \
echo 'opcache.save_comments=1'; \
echo 'opcache.revalidate_freq=1'; \
} > /etc/php/7.3/embed/conf.d/opcache-recommended.ini; \
\
echo 'apc.enable_cli=1' >> /etc/php/7.3/embed/conf.d/docker-php-ext-apcu.ini; \
\
echo 'memory_limit=512M' > /etc/php/7.3/embed/conf.d/memory-limit.ini; \
\
mkdir -p /var/www/data; \
chown -R www-data:root /var/www; \
chmod -R g=u /var/www
VOLUME /var/www/html
ENV NEXTCLOUD_VERSION 16.0.5
RUN set -ex; \
fetchDeps=" \
gnupg \
dirmngr \
"; \
apt-get update; \
apt-get install -y --no-install-recommends $fetchDeps; \
\
curl -fsSL -o nextcloud.tar.bz2 \
"https://download.nextcloud.com/server/releases/nextcloud-${NEXTCLOUD_VERSION}.tar.bz2"; \
curl -fsSL -o nextcloud.tar.bz2.asc \
"https://download.nextcloud.com/server/releases/nextcloud-${NEXTCLOUD_VERSION}.tar.bz2.asc"; \
export GNUPGHOME="$(mktemp -d)"; \
# gpg key from https://nextcloud.com/nextcloud.asc
gpg --batch --keyserver ha.pool.sks-keyservers.net --recv-keys 28806A878AE423A28372792ED75899B9A724937A; \
gpg --batch --verify nextcloud.tar.bz2.asc nextcloud.tar.bz2; \
tar -xjf nextcloud.tar.bz2 -C /usr/src/; \
gpgconf --kill all; \
rm -r "$GNUPGHOME" nextcloud.tar.bz2.asc nextcloud.tar.bz2; \
rm -rf /usr/src/nextcloud/updater; \
mkdir -p /usr/src/nextcloud/data; \
mkdir -p /usr/src/nextcloud/custom_apps; \
chmod +x /usr/src/nextcloud/occ; \
\
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps; \
rm -rf /var/lib/apt/lists/*
COPY *.sh upgrade.exclude /
COPY config/* /usr/src/nextcloud/config/
# launch and configure Unit
RUN \
[ -f /var/www/html/index.php ] || { \
touch /var/www/html/index.php /var/www/html/index.php.remove; \
} \
&& unitd --control unix:/var/run/control.unit.sock \
&& cat /etc/ssl/certs/ssl-cert-snakeoil.pem /etc/ssl/private/ssl-cert-snakeoil.key | \
curl -X PUT --data-binary @- --unix-socket /var/run/control.unit.sock \
http://localhost/certificates/default \
&& curl -X PUT --data-binary \
'{ \
"listeners": { \
"*:9000": { "pass": "routes/main" }, \
"*:9001": { "pass": "routes/dynamic" }, \
"*:9002": { "pass": "routes/static" }, \
"*:9003": { "pass": "routes/direct" }, \
"*:9010": { "pass": "routes/main", "tls": { "certificate": "default" } }, \
"*:9011": { "pass": "routes/dynamic", "tls": { "certificate": "default" } }, \
"*:9012": { "pass": "routes/static", "tls": { "certificate": "default" } }, \
"*:9013": { "pass": "routes/direct", "tls": { "certificate": "default" } } \
}, \
"routes": { \
"main": [ \
{ \
"match": { \
"uri": [ \
"/index.php*", \
"/remote.php*", \
"/public.php*", \
"/cron.php*", \
"/core/ajax/update.php*", \
"/status.php*", \
"/ocs/v1.php*", \
"/ocs/v2.php*", \
"/updater/*.php", \
"/ocs-provider/*.php", \
"/ocm-provider/*.php" \
] \
}, \
"action": { "pass": "applications/direct_php" } \
}, \
{ \
"match": { \
"uri": [ \
"*.css", \
"*.js", \
"*.woff", \
"*.woff2", \
"*.svg", \
"*.gif", \
"*.map", \
"*.png", \
"*.html", \
"*.ttf", \
"*.ico", \
"*.jpg", \
"*.jpeg", \
"*.bcmap" \
] \
}, \
"action": { "share": "/var/www/html" } \
}, \
{ "action": { "pass": "applications/index_php" } } \
], \
"static": [ \
{ "action": { "share": "/var/www/html" } } \
], \
"dynamic": [ \
{ "action": { "pass": "applications/index_php" } } \
], \
"direct": [ \
{ "action": { "pass": "applications/direct_php" } } \
], \
}, \
"applications": { \
"index_php": { \
"type": "php", \
"processes": { "max": 20, "spare": 5 }, \
"user": "www-data", \
"group": "www-data", \
"root": "/var/www/html", \
"script": "index.php" \
}, \
"direct_php": { \
"type": "php", \
"processes": { "max": 5, "spare": 0 }, \
"user": "www-data", \
"group": "www-data", \
"root": "/var/www/html", \
"index": "index.php" \
} \
} \
}' \
--unix-socket /var/run/control.unit.sock http://localhost/config/ \
&& [ -f /var/www/html/index.php.remove ] && { \
rm /var/www/html/index.php /var/www/html/index.php.remove; \
}
ENV LDAP_ENABLE=false
ENV LDAP_HOST=
ENV LDAP_PORT=389
ENV LDAP_BACKUP_HOST=
ENV LDAP_BACKUP_PORT=389
ENV LDAP_DN=
ENV LDAP_AGENT_PASSWORD=
ENV LDAP_BASE=
ENV LDAP_BASE_USERS=
ENV LDAP_BASE_GROUPS=
# space-separated objectclass values
ENV LDAP_USERFILTER_OBJECTCLASS=inetOrgPerson
ENV LDAP_USERLIST_FILTER=
ENV LDAP_LOGIN_FILTER=
ENV LDAP_GROUPFILTER_OBJECTCLASS=organizationalRole
ENV LDAP_GROUP_FILTER=
ENV LDAP_GID_NUMBER=gidNumber
ENV LDAP_DISPLAY_NAME=cn
ENV LDAP_USER_DISPLAY_NAME_2=
ENV LDAP_GROUP_DISPLAY_NAME=cn
ENV LDAP_EMAIL_ATTR=mail
ENV LDAP_GROUP_MEMBER_ASSOC_ATTRIBUTE=memberUid
EXPOSE 9000 9001 9002 9003 9010 9011 9012 9013
ENTRYPOINT ["/entrypoint.sh"]
STOPSIGNAL SIGTERM
CMD ["unitd", "--no-daemon", "--control", "unix:/var/run/control.unit.sock"]