nginx.conf 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. server {
  2. listen 80;
  3. listen [::]:80;
  4. server_name YOUR_DOMAIN;
  5. return 301 https://$server_name$request_uri;
  6. }
  7. server {
  8. listen 443 ssl http2;
  9. listen [::]:443 ssl http2;
  10. server_name YOUR_DOMAIN;
  11. ssl_protocols TLSv1.2;
  12. ssl_ciphers 'ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA256';
  13. ssl_prefer_server_ciphers on;
  14. ssl_session_cache shared:SSL:10m;
  15. ssl_stapling on;
  16. ssl_stapling_verify on;
  17. add_header Strict-Transport-Security "max-age=31536000";
  18. add_header X-XSS-Protection "1; mode=block";
  19. ssl_certificate /etc/CHANGE_THIS/fullchain.pem;
  20. ssl_certificate_key /etc/CHANGE_THIS/privkey.pem;
  21. ssl_dhparam /etc/CHANGE_THIS/dhparam.pem;
  22. keepalive_timeout 70;
  23. sendfile on;
  24. client_max_body_size 20m;
  25. root /var/www/example.com;
  26. location ~* (?:DESIGN|(?:gpl|README|LICENSE)[^.]*|LEGALNOTICE)(?:\.txt)*$ {
  27. return 302 /;
  28. }
  29. location ~* \.(?:bat|git|ini|sh|svn[^.]*|txt|tpl|xml)$ {
  30. return 404;
  31. }
  32. # Main
  33. rewrite ^/home/?$ / permanent;
  34. rewrite ^/login/?$ /login/login.php break;
  35. rewrite ^/auth/?$ /login/auth.php break;
  36. rewrite ^/logout/?$ /login/logout.php break;
  37. rewrite ^/terms/?$ /login/terms.php break;
  38. rewrite ^/privacy/?$ /login/privacy.php break;
  39. rewrite ^/imprint/?$ /login/imprint.php break;
  40. # LTL
  41. rewrite ^/local/?$ /local.php break;
  42. # FTL
  43. rewrite ^/federated/?$ /federated.php break;
  44. # Notice
  45. rewrite ^/notifications/?$ /notifications.php break;
  46. # Who to follow
  47. rewrite ^/whotofollow/?$ /who_to_follow.php break;
  48. # Search
  49. rewrite ^/search/?$ /search_hash_tag.php break;
  50. rewrite ^/search/users/?$ /search_user.php break;
  51. # Settings
  52. rewrite ^/settings/?$ /settings_general.php break;
  53. rewrite ^/settings/profile/?$ /settings_profile.php break;
  54. rewrite ^/settings/appearance/?$ /settings_appearance.php break;
  55. # User
  56. rewrite ^/@(.+)@(.+)\.([a-z]+)/?$ /user.php?user=@$1@$2\.$3 break;
  57. rewrite ^/@(.+)@(.+)\.([a-z]+)/status/(.+?)?$ /user.php?user=@$1@$2\.$3&status=$4 break;
  58. rewrite ^/@(.+)@(.+)\.([a-z]+)/media/?$ /user_only_media.php?user=@$1@$2\.$3 break;
  59. rewrite ^/@(.+)@(.+)\.([a-z]+)/with_replies/?$ /user_include_replies.php?user=@$1@$2\.$3 break;
  60. rewrite ^/@(.+)@(.+)\.([a-z]+)/followers/?$ /user_followers.php?user=@$1@$2\.$3 break;
  61. rewrite ^/@(.+)@(.+)\.([a-z]+)/following/?$ /user_following.php?user=@$1@$2\.$3 break;
  62. rewrite ^/@(.+)@(.+)\.([a-z]+)/favourites/?$ /user_favorite.php?user=@$1@$2\.$3 break;
  63. # Image
  64. rewrite ^/avatars/original/missing.png$ /assets/images/missing.png break;
  65. rewrite ^/headers/original/missing.png$ /assets/images/missing_header.png break;
  66. # 404
  67. rewrite ^/404/?$ /404.php break;
  68. location ~ [^/]\.php(/|$) {
  69. fastcgi_split_path_info ^(.+?\.php)(/.*)$;
  70. include fastcgi_params;
  71. fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  72. if (!-f $document_root$fastcgi_script_name) {
  73. return 404;
  74. }
  75. fastcgi_param PATH_INFO $fastcgi_path_info;
  76. fastcgi_param HTTPS on;
  77. fastcgi_buffers 8 256k;
  78. fastcgi_buffer_size 128k;
  79. fastcgi_intercept_errors on;
  80. fastcgi_pass unix:/var/run/php/php7.1-fpm.sock;
  81. }
  82. }