Last active
November 16, 2024 09:59
NextCloud directive on ISPConfig with nGinx
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
Custom php.ini settings | |
memory_limit = 8G | |
upload_max_filesize=15G | |
post_max_size=15G | |
max_execution_time = 3600 | |
max_input_time = 3600 | |
opcache.enable_cli=1 | |
opcache.save_comments=1 | |
opcache.revalidate_freq=60 | |
opcache.validate_timestamps = 0 | |
opcache.interned_strings_buffer=256 | |
opcache.memory_consumption=256 | |
opcache.jit = 1255 | |
opcache.jit_buffer_size = 128 | |
output_buffering=0 | |
##################################################### | |
nginx Directives | |
# set max upload size and increase upload timeout: | |
client_max_body_size 2G; | |
client_body_timeout 1800s; | |
fastcgi_buffers 64 4K; | |
location ~ \.php$ { ##delete## | |
} | |
location @php { ##delete## | |
} | |
location ~ /\. { ##delete## | |
} | |
# Enable gzip but do not remove ETag headers | |
gzip on; | |
gzip_vary on; | |
gzip_comp_level 4; | |
gzip_min_length 256; | |
gzip_proxied expired no-cache no-store private no_last_modified no_etag auth; | |
gzip_types application/atom+xml application/javascript application/json application/ld+json application/manifest+json application/rss+xml application/vnd.geo+json application/vnd.ms-fontobject application/wasm application/x-font-ttf application/x-web-app-manifest+json application/xhtml+xml application/xml font/opentype image/bmp image/svg+xml image/x-icon text/cache-manifest text/css text/plain text/vcard text/vnd.rim.location.xloc text/vtt text/x-component text/x-cross-domain-policy; | |
# HTTP response headers borrowed from Nextcloud .htaccess | |
add_header Referrer-Policy "no-referrer" always; | |
add_header X-Content-Type-Options "nosniff" always; | |
add_header X-Download-Options "noopen" always; | |
add_header X-Frame-Options "SAMEORIGIN" always; | |
add_header X-Permitted-Cross-Domain-Policies "none" always; | |
add_header X-Robots-Tag "noindex, nofollow" always; | |
add_header X-XSS-Protection "1; mode=block" always; | |
add_header Strict-Transport-Security "max-age=15552000; includeSubDomains"; | |
# Remove X-Powered-By, which is an information leak | |
fastcgi_hide_header X-Powered-By; | |
index index.php index.html /index.php$request_uri; | |
#location / { | |
# rewrite ^ /index.php; | |
#} | |
include mime.types; | |
types { | |
text/javascript js mjs; | |
application/wasm wasm; | |
} | |
# Rule borrowed from `.htaccess` to handle Microsoft DAV clients | |
location = / { | |
if ( $http_user_agent ~ ^DavClnt ) { | |
return 302 /remote.php/webdav/$is_args$args; | |
} | |
} | |
location = /robots.txt { | |
allow all; | |
log_not_found off; | |
access_log off; | |
} | |
# Make a regex exception for `/.well-known` so that clients can still | |
# access it despite the existence of the regex rule | |
# `location ~ /(\.|autotest|...)` which would otherwise handle requests | |
# for `/.well-known`. | |
location ^~ /.well-known { | |
# The rules in this block are an adaptation of the rules | |
# in `.htaccess` that concern `/.well-known`. | |
location = /.well-known/carddav { return 301 /remote.php/dav/; } | |
location = /.well-known/caldav { return 301 /remote.php/dav/; } | |
location = /.well-known/webfinger { return 301 /index.php$uri; } | |
location = /.well-known/nodeinfo { return 301 /index.php$uri; } | |
location /.well-known/acme-challenge { try_files $uri $uri/ =404; } | |
location /.well-known/pki-validation { try_files $uri $uri/ =404; } | |
# Let Nextcloud's API for `/.well-known` URIs handle all other | |
# requests by passing them to the front-end controller. | |
return 301 /index.php$request_uri; | |
} | |
# Rules borrowed from .htaccess to hide certain paths from clients | |
location ~ ^/(?:build|tests|config|lib|3rdparty|templates|data)(?:$|/) { return 404; } | |
location ~ ^/(?:\.|autotest|occ|issue|indie|db_|console) { return 404; } | |
location ~ /\.(?!well-known)(?!file) { | |
deny all; | |
} | |
# Ensure this block, which passes PHP files to the PHP process, is above the blocks | |
# which handle static assets (as seen below). If this block is not declared first, | |
# then Nginx will encounter an infinite rewriting loop when it prepends `/index.php` | |
# to the URI, resulting in a HTTP 500 error response. | |
location ~ \.php(?:$|/) { | |
# Required for legacy support | |
rewrite ^/(?!index|remote|public|cron|core\/ajax\/update|status|ocs\/v[12]|updater\/.+|oc[ms]-provider\/.+|.+\/richdocumentscode\/proxy) /index.php$request_uri; | |
fastcgi_split_path_info ^(.+?\.php)(/.*)$; | |
set $path_info $fastcgi_path_info; | |
try_files $fastcgi_script_name =404; | |
include fastcgi_params; | |
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; | |
fastcgi_param PATH_INFO $path_info; | |
fastcgi_param HTTPS on; | |
fastcgi_param modHeadersAvailable true; # Avoid sending the security headers twice | |
fastcgi_param front_controller_active true; # Enable pretty urls | |
{FASTCGIPASS} | |
#fastcgi_pass php-handler; | |
fastcgi_intercept_errors on; | |
fastcgi_request_buffering off; | |
fastcgi_read_timeout 1800s; | |
fastcgi_connect_timeout 1800s; | |
fastcgi_max_temp_file_size 0; | |
} | |
location ~ \.(?:css|js|svg|gif|png|jpg|ico|wasm|tflite|map)$ { | |
try_files $uri /index.php$request_uri; | |
add_header Cache-Control "public, max-age=15778463, immutable"; | |
access_log off; # Optional: Don't log access to assets | |
location ~ \.wasm$ { | |
default_type application/wasm; | |
} | |
} | |
location ~ \.woff2?$ { | |
try_files $uri /index.php$request_uri; | |
expires 7d; # Cache-Control policy borrowed from `.htaccess` | |
access_log off; # Optional: Don't log access to assets | |
} | |
# Rule borrowed from .htaccess | |
location /remote { | |
return 301 /remote.php$request_uri; | |
} | |
location / { | |
try_files $uri $uri/ /index.php$request_uri; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Thank You Developer... I solve my problem ...............