-
Notifications
You must be signed in to change notification settings - Fork 1.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
GitHub Workflow
committed
Dec 12, 2023
1 parent
d4f8396
commit e6510ac
Showing
42 changed files
with
1,983 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,172 @@ | ||
# DO NOT EDIT: created by update.sh from Dockerfile-debian.template | ||
FROM php:8.2-apache-bookworm | ||
|
||
# entrypoint.sh and cron.sh dependencies | ||
RUN set -ex; \ | ||
\ | ||
apt-get update; \ | ||
apt-get install -y --no-install-recommends \ | ||
busybox-static \ | ||
bzip2 \ | ||
libldap-common \ | ||
libmagickcore-6.q16-6-extra \ | ||
rsync \ | ||
; \ | ||
rm -rf /var/lib/apt/lists/*; \ | ||
\ | ||
mkdir -p /var/spool/cron/crontabs; \ | ||
echo '*/5 * * * * 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 | ||
ENV PHP_MEMORY_LIMIT 512M | ||
ENV PHP_UPLOAD_LIMIT 512M | ||
RUN set -ex; \ | ||
\ | ||
savedAptMark="$(apt-mark showmanual)"; \ | ||
\ | ||
apt-get update; \ | ||
apt-get install -y --no-install-recommends \ | ||
libcurl4-openssl-dev \ | ||
libevent-dev \ | ||
libfreetype6-dev \ | ||
libgmp-dev \ | ||
libicu-dev \ | ||
libjpeg-dev \ | ||
libldap2-dev \ | ||
libmagickwand-dev \ | ||
libmcrypt-dev \ | ||
libmemcached-dev \ | ||
libpng-dev \ | ||
libpq-dev \ | ||
libwebp-dev \ | ||
libxml2-dev \ | ||
libzip-dev \ | ||
; \ | ||
\ | ||
debMultiarch="$(dpkg-architecture --query DEB_BUILD_MULTIARCH)"; \ | ||
docker-php-ext-configure gd --with-freetype --with-jpeg --with-webp; \ | ||
docker-php-ext-configure ldap --with-libdir="lib/$debMultiarch"; \ | ||
docker-php-ext-install -j "$(nproc)" \ | ||
bcmath \ | ||
exif \ | ||
gd \ | ||
gmp \ | ||
intl \ | ||
ldap \ | ||
opcache \ | ||
pcntl \ | ||
pdo_mysql \ | ||
pdo_pgsql \ | ||
sysvsem \ | ||
zip \ | ||
; \ | ||
\ | ||
# pecl will claim success even if one install fails, so we need to perform each install separately | ||
pecl install APCu-5.1.23; \ | ||
pecl install imagick-3.7.0; \ | ||
pecl install memcached-3.2.0; \ | ||
pecl install redis-6.0.2; \ | ||
\ | ||
docker-php-ext-enable \ | ||
apcu \ | ||
imagick \ | ||
memcached \ | ||
redis \ | ||
; \ | ||
rm -r /tmp/pear; \ | ||
\ | ||
# reset apt-mark's "manual" list so that "purge --auto-remove" will remove all build dependencies | ||
apt-mark auto '.*' > /dev/null; \ | ||
apt-mark manual $savedAptMark; \ | ||
ldd "$(php -r 'echo ini_get("extension_dir");')"/*.so \ | ||
| awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); print so }' \ | ||
| sort -u \ | ||
| xargs -r dpkg-query --search \ | ||
| cut -d: -f1 \ | ||
| sort -u \ | ||
| xargs -rt apt-mark manual; \ | ||
\ | ||
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; \ | ||
rm -rf /var/lib/apt/lists/* | ||
|
||
# set recommended PHP.ini settings | ||
# see https://docs.nextcloud.com/server/latest/admin_manual/installation/server_tuning.html#enable-php-opcache | ||
RUN { \ | ||
echo 'opcache.enable=1'; \ | ||
echo 'opcache.interned_strings_buffer=32'; \ | ||
echo 'opcache.max_accelerated_files=10000'; \ | ||
echo 'opcache.memory_consumption=128'; \ | ||
echo 'opcache.save_comments=1'; \ | ||
echo 'opcache.revalidate_freq=60'; \ | ||
echo 'opcache.jit=1255'; \ | ||
echo 'opcache.jit_buffer_size=128M'; \ | ||
} > "${PHP_INI_DIR}/conf.d/opcache-recommended.ini"; \ | ||
\ | ||
echo 'apc.enable_cli=1' >> "${PHP_INI_DIR}/conf.d/docker-php-ext-apcu.ini"; \ | ||
\ | ||
{ \ | ||
echo 'memory_limit=${PHP_MEMORY_LIMIT}'; \ | ||
echo 'upload_max_filesize=${PHP_UPLOAD_LIMIT}'; \ | ||
echo 'post_max_size=${PHP_UPLOAD_LIMIT}'; \ | ||
} > "${PHP_INI_DIR}/conf.d/nextcloud.ini"; \ | ||
\ | ||
mkdir /var/www/data; \ | ||
mkdir -p /docker-entrypoint-hooks.d/pre-installation \ | ||
/docker-entrypoint-hooks.d/post-installation \ | ||
/docker-entrypoint-hooks.d/pre-upgrade \ | ||
/docker-entrypoint-hooks.d/post-upgrade \ | ||
/docker-entrypoint-hooks.d/before-starting; \ | ||
chown -R www-data:root /var/www; \ | ||
chmod -R g=u /var/www | ||
|
||
VOLUME /var/www/html | ||
|
||
RUN a2enmod headers rewrite remoteip ; \ | ||
{ \ | ||
echo 'RemoteIPHeader X-Real-IP'; \ | ||
echo 'RemoteIPInternalProxy 10.0.0.0/8'; \ | ||
echo 'RemoteIPInternalProxy 172.16.0.0/12'; \ | ||
echo 'RemoteIPInternalProxy 192.168.0.0/16'; \ | ||
} > /etc/apache2/conf-available/remoteip.conf; \ | ||
a2enconf remoteip | ||
|
||
# set apache config LimitRequestBody | ||
ENV APACHE_BODY_LIMIT 1073741824 | ||
RUN { \ | ||
echo 'LimitRequestBody ${APACHE_BODY_LIMIT}'; \ | ||
} > /etc/apache2/conf-available/apache-limits.conf; \ | ||
a2enconf apache-limits | ||
|
||
ENV NEXTCLOUD_VERSION 28.0.0 | ||
|
||
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-28.0.0.tar.bz2"; \ | ||
curl -fsSL -o nextcloud.tar.bz2.asc "https://download.nextcloud.com/server/releases/nextcloud-28.0.0.tar.bz2.asc"; \ | ||
export GNUPGHOME="$(mktemp -d)"; \ | ||
# gpg key from https://nextcloud.com/nextcloud.asc | ||
gpg --batch --keyserver keyserver.ubuntu.com --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 nextcloud.tar.bz2.asc nextcloud.tar.bz2; \ | ||
rm -rf "$GNUPGHOME" /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/ | ||
|
||
ENTRYPOINT ["/entrypoint.sh"] | ||
CMD ["apache2-foreground"] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
<?php | ||
$CONFIG = array ( | ||
'htaccess.RewriteBase' => '/', | ||
); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
<?php | ||
$CONFIG = array ( | ||
'memcache.local' => '\OC\Memcache\APCu', | ||
); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
<?php | ||
$CONFIG = array ( | ||
'apps_paths' => array ( | ||
0 => array ( | ||
'path' => OC::$SERVERROOT.'/apps', | ||
'url' => '/apps', | ||
'writable' => false, | ||
), | ||
1 => array ( | ||
'path' => OC::$SERVERROOT.'/custom_apps', | ||
'url' => '/custom_apps', | ||
'writable' => true, | ||
), | ||
), | ||
); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
<?php | ||
|
||
$autoconfig_enabled = false; | ||
|
||
if (getenv('SQLITE_DATABASE')) { | ||
$AUTOCONFIG['dbtype'] = 'sqlite'; | ||
$AUTOCONFIG['dbname'] = getenv('SQLITE_DATABASE'); | ||
$autoconfig_enabled = true; | ||
} elseif (getenv('MYSQL_DATABASE_FILE') && getenv('MYSQL_USER_FILE') && getenv('MYSQL_PASSWORD_FILE') && getenv('MYSQL_HOST')) { | ||
$AUTOCONFIG['dbtype'] = 'mysql'; | ||
$AUTOCONFIG['dbname'] = trim(file_get_contents(getenv('MYSQL_DATABASE_FILE'))); | ||
$AUTOCONFIG['dbuser'] = trim(file_get_contents(getenv('MYSQL_USER_FILE'))); | ||
$AUTOCONFIG['dbpass'] = trim(file_get_contents(getenv('MYSQL_PASSWORD_FILE'))); | ||
$AUTOCONFIG['dbhost'] = getenv('MYSQL_HOST'); | ||
$autoconfig_enabled = true; | ||
} elseif (getenv('MYSQL_DATABASE') && getenv('MYSQL_USER') && getenv('MYSQL_PASSWORD') && getenv('MYSQL_HOST')) { | ||
$AUTOCONFIG['dbtype'] = 'mysql'; | ||
$AUTOCONFIG['dbname'] = getenv('MYSQL_DATABASE'); | ||
$AUTOCONFIG['dbuser'] = getenv('MYSQL_USER'); | ||
$AUTOCONFIG['dbpass'] = getenv('MYSQL_PASSWORD'); | ||
$AUTOCONFIG['dbhost'] = getenv('MYSQL_HOST'); | ||
$autoconfig_enabled = true; | ||
} elseif (getenv('POSTGRES_DB_FILE') && getenv('POSTGRES_USER_FILE') && getenv('POSTGRES_PASSWORD_FILE') && getenv('POSTGRES_HOST')) { | ||
$AUTOCONFIG['dbtype'] = 'pgsql'; | ||
$AUTOCONFIG['dbname'] = trim(file_get_contents(getenv('POSTGRES_DB_FILE'))); | ||
$AUTOCONFIG['dbuser'] = trim(file_get_contents(getenv('POSTGRES_USER_FILE'))); | ||
$AUTOCONFIG['dbpass'] = trim(file_get_contents(getenv('POSTGRES_PASSWORD_FILE'))); | ||
$AUTOCONFIG['dbhost'] = getenv('POSTGRES_HOST'); | ||
$autoconfig_enabled = true; | ||
} elseif (getenv('POSTGRES_DB') && getenv('POSTGRES_USER') && getenv('POSTGRES_PASSWORD') && getenv('POSTGRES_HOST')) { | ||
$AUTOCONFIG['dbtype'] = 'pgsql'; | ||
$AUTOCONFIG['dbname'] = getenv('POSTGRES_DB'); | ||
$AUTOCONFIG['dbuser'] = getenv('POSTGRES_USER'); | ||
$AUTOCONFIG['dbpass'] = getenv('POSTGRES_PASSWORD'); | ||
$AUTOCONFIG['dbhost'] = getenv('POSTGRES_HOST'); | ||
$autoconfig_enabled = true; | ||
} | ||
|
||
if ($autoconfig_enabled) { | ||
$AUTOCONFIG['directory'] = getenv('NEXTCLOUD_DATA_DIR') ?: '/var/www/html/data'; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
<?php | ||
if (getenv('REDIS_HOST')) { | ||
$CONFIG = array( | ||
'memcache.distributed' => '\OC\Memcache\Redis', | ||
'memcache.locking' => '\OC\Memcache\Redis', | ||
'redis' => array( | ||
'host' => getenv('REDIS_HOST'), | ||
'password' => (string) getenv('REDIS_HOST_PASSWORD'), | ||
), | ||
); | ||
|
||
if (getenv('REDIS_HOST_PORT') !== false) { | ||
$CONFIG['redis']['port'] = (int) getenv('REDIS_HOST_PORT'); | ||
} elseif (getenv('REDIS_HOST')[0] != '/') { | ||
$CONFIG['redis']['port'] = 6379; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
<?php | ||
$overwriteHost = getenv('OVERWRITEHOST'); | ||
if ($overwriteHost) { | ||
$CONFIG['overwritehost'] = $overwriteHost; | ||
} | ||
|
||
$overwriteProtocol = getenv('OVERWRITEPROTOCOL'); | ||
if ($overwriteProtocol) { | ||
$CONFIG['overwriteprotocol'] = $overwriteProtocol; | ||
} | ||
|
||
$overwriteCliUrl = getenv('OVERWRITECLIURL'); | ||
if ($overwriteCliUrl) { | ||
$CONFIG['overwrite.cli.url'] = $overwriteCliUrl; | ||
} | ||
|
||
$overwriteWebRoot = getenv('OVERWRITEWEBROOT'); | ||
if ($overwriteWebRoot) { | ||
$CONFIG['overwritewebroot'] = $overwriteWebRoot; | ||
} | ||
|
||
$overwriteCondAddr = getenv('OVERWRITECONDADDR'); | ||
if ($overwriteCondAddr) { | ||
$CONFIG['overwritecondaddr'] = $overwriteCondAddr; | ||
} | ||
|
||
$trustedProxies = getenv('TRUSTED_PROXIES'); | ||
if ($trustedProxies) { | ||
$CONFIG['trusted_proxies'] = array_filter(array_map('trim', explode(' ', $trustedProxies))); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
<?php | ||
if (getenv('OBJECTSTORE_S3_BUCKET')) { | ||
$use_ssl = getenv('OBJECTSTORE_S3_SSL'); | ||
$use_path = getenv('OBJECTSTORE_S3_USEPATH_STYLE'); | ||
$use_legacyauth = getenv('OBJECTSTORE_S3_LEGACYAUTH'); | ||
$autocreate = getenv('OBJECTSTORE_S3_AUTOCREATE'); | ||
$CONFIG = array( | ||
'objectstore' => array( | ||
'class' => '\OC\Files\ObjectStore\S3', | ||
'arguments' => array( | ||
'bucket' => getenv('OBJECTSTORE_S3_BUCKET'), | ||
'region' => getenv('OBJECTSTORE_S3_REGION') ?: '', | ||
'hostname' => getenv('OBJECTSTORE_S3_HOST') ?: '', | ||
'port' => getenv('OBJECTSTORE_S3_PORT') ?: '', | ||
'objectPrefix' => getenv("OBJECTSTORE_S3_OBJECT_PREFIX") ? getenv("OBJECTSTORE_S3_OBJECT_PREFIX") : "urn:oid:", | ||
'autocreate' => (strtolower($autocreate) === 'false' || $autocreate == false) ? false : true, | ||
'use_ssl' => (strtolower($use_ssl) === 'false' || $use_ssl == false) ? false : true, | ||
// required for some non Amazon S3 implementations | ||
'use_path_style' => $use_path == true && strtolower($use_path) !== 'false', | ||
// required for older protocol versions | ||
'legacy_auth' => $use_legacyauth == true && strtolower($use_legacyauth) !== 'false' | ||
) | ||
) | ||
); | ||
|
||
if (getenv('OBJECTSTORE_S3_KEY_FILE') && file_exists(getenv('OBJECTSTORE_S3_KEY_FILE'))) { | ||
$CONFIG['objectstore']['arguments']['key'] = trim(file_get_contents(getenv('OBJECTSTORE_S3_KEY_FILE'))); | ||
} elseif (getenv('OBJECTSTORE_S3_KEY')) { | ||
$CONFIG['objectstore']['arguments']['key'] = getenv('OBJECTSTORE_S3_KEY'); | ||
} else { | ||
$CONFIG['objectstore']['arguments']['key'] = ''; | ||
} | ||
|
||
if (getenv('OBJECTSTORE_S3_SECRET_FILE') && file_exists(getenv('OBJECTSTORE_S3_SECRET_FILE'))) { | ||
$CONFIG['objectstore']['arguments']['secret'] = trim(file_get_contents(getenv('OBJECTSTORE_S3_SECRET_FILE'))); | ||
} elseif (getenv('OBJECTSTORE_S3_SECRET')) { | ||
$CONFIG['objectstore']['arguments']['secret'] = getenv('OBJECTSTORE_S3_SECRET'); | ||
} else { | ||
$CONFIG['objectstore']['arguments']['secret'] = ''; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
<?php | ||
if (getenv('SMTP_HOST') && getenv('MAIL_FROM_ADDRESS') && getenv('MAIL_DOMAIN')) { | ||
$CONFIG = array ( | ||
'mail_smtpmode' => 'smtp', | ||
'mail_smtphost' => getenv('SMTP_HOST'), | ||
'mail_smtpport' => getenv('SMTP_PORT') ?: (getenv('SMTP_SECURE') ? 465 : 25), | ||
'mail_smtpsecure' => getenv('SMTP_SECURE') ?: '', | ||
'mail_smtpauth' => getenv('SMTP_NAME') && (getenv('SMTP_PASSWORD') || (getenv('SMTP_PASSWORD_FILE') && file_exists(getenv('SMTP_PASSWORD_FILE')))), | ||
'mail_smtpauthtype' => getenv('SMTP_AUTHTYPE') ?: 'LOGIN', | ||
'mail_smtpname' => getenv('SMTP_NAME') ?: '', | ||
'mail_from_address' => getenv('MAIL_FROM_ADDRESS'), | ||
'mail_domain' => getenv('MAIL_DOMAIN'), | ||
); | ||
|
||
if (getenv('SMTP_PASSWORD_FILE') && file_exists(getenv('SMTP_PASSWORD_FILE'))) { | ||
$CONFIG['mail_smtppassword'] = trim(file_get_contents(getenv('SMTP_PASSWORD_FILE'))); | ||
} elseif (getenv('SMTP_PASSWORD')) { | ||
$CONFIG['mail_smtppassword'] = getenv('SMTP_PASSWORD'); | ||
} else { | ||
$CONFIG['mail_smtppassword'] = ''; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
<?php | ||
if (getenv('OBJECTSTORE_SWIFT_URL')) { | ||
$autocreate = getenv('OBJECTSTORE_SWIFT_AUTOCREATE'); | ||
$CONFIG = array( | ||
'objectstore' => [ | ||
'class' => 'OC\\Files\\ObjectStore\\Swift', | ||
'arguments' => [ | ||
'autocreate' => $autocreate == true && strtolower($autocreate) !== 'false', | ||
'user' => [ | ||
'name' => getenv('OBJECTSTORE_SWIFT_USER_NAME'), | ||
'password' => getenv('OBJECTSTORE_SWIFT_USER_PASSWORD'), | ||
'domain' => [ | ||
'name' => (getenv('OBJECTSTORE_SWIFT_USER_DOMAIN')) ?: 'Default', | ||
], | ||
], | ||
'scope' => [ | ||
'project' => [ | ||
'name' => getenv('OBJECTSTORE_SWIFT_PROJECT_NAME'), | ||
'domain' => [ | ||
'name' => (getenv('OBJECTSTORE_SWIFT_PROJECT_DOMAIN')) ?: 'Default', | ||
], | ||
], | ||
], | ||
'serviceName' => (getenv('OBJECTSTORE_SWIFT_SERVICE_NAME')) ?: 'swift', | ||
'region' => getenv('OBJECTSTORE_SWIFT_REGION'), | ||
'url' => getenv('OBJECTSTORE_SWIFT_URL'), | ||
'bucket' => getenv('OBJECTSTORE_SWIFT_CONTAINER_NAME'), | ||
] | ||
] | ||
); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
<?php | ||
$CONFIG = array ( | ||
'upgrade.disable-web' => true, | ||
); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
#!/bin/sh | ||
set -eu | ||
|
||
exec busybox crond -f -L /dev/stdout |
Oops, something went wrong.