From 62bb86f11dca5b0ce60ffe926a266726f0b20148 Mon Sep 17 00:00:00 2001 From: Boris Date: Sun, 29 Mar 2026 21:46:18 +0300 Subject: [PATCH] Add nginx vhost configs for reference --- nginx/admin.k-boris.tech.conf | 36 +++++++++++++++++++++++++++++++++++ nginx/ci.k-boris.tech.conf | 34 +++++++++++++++++++++++++++++++++ nginx/git.k-boris.tech.conf | 34 +++++++++++++++++++++++++++++++++ nginx/k-boris.tech.conf | 32 +++++++++++++++++++++++++++++++ 4 files changed, 136 insertions(+) create mode 100644 nginx/admin.k-boris.tech.conf create mode 100644 nginx/ci.k-boris.tech.conf create mode 100644 nginx/git.k-boris.tech.conf create mode 100644 nginx/k-boris.tech.conf diff --git a/nginx/admin.k-boris.tech.conf b/nginx/admin.k-boris.tech.conf new file mode 100644 index 0000000..4028fae --- /dev/null +++ b/nginx/admin.k-boris.tech.conf @@ -0,0 +1,36 @@ +server { + server_name admin.k-boris.tech; + + location = / { + return 301 /admin/; + } + + location / { + proxy_pass http://127.0.0.1:8080; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + listen [::]:443 ssl ipv6only=on; # managed by Certbot + listen 443 ssl; # managed by Certbot + ssl_certificate /etc/letsencrypt/live/admin.k-boris.tech/fullchain.pem; # managed by Certbot + ssl_certificate_key /etc/letsencrypt/live/admin.k-boris.tech/privkey.pem; # managed by Certbot + include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot + ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot + +} +server { + if ($host = admin.k-boris.tech) { + return 301 https://$host$request_uri; + } # managed by Certbot + + + listen 80; + listen [::]:80; + server_name admin.k-boris.tech; + return 404; # managed by Certbot + + +} \ No newline at end of file diff --git a/nginx/ci.k-boris.tech.conf b/nginx/ci.k-boris.tech.conf new file mode 100644 index 0000000..3463027 --- /dev/null +++ b/nginx/ci.k-boris.tech.conf @@ -0,0 +1,34 @@ +server { + server_name ci.k-boris.tech; + + location / { + proxy_pass http://127.0.0.1:8000; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + proxy_set_header Upgrade $http_upgrade; + proxy_set_header Connection "upgrade"; + } + + listen 443 ssl; # managed by Certbot + listen [::]:443 ssl; # managed by Certbot + ssl_certificate /etc/letsencrypt/live/git.k-boris.tech/fullchain.pem; # managed by Certbot + ssl_certificate_key /etc/letsencrypt/live/git.k-boris.tech/privkey.pem; # managed by Certbot + include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot + ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot + +} +server { + if ($host = ci.k-boris.tech) { + return 301 https://$host$request_uri; + } # managed by Certbot + + + listen 80; + listen [::]:80; + server_name ci.k-boris.tech; + return 404; # managed by Certbot + + +} \ No newline at end of file diff --git a/nginx/git.k-boris.tech.conf b/nginx/git.k-boris.tech.conf new file mode 100644 index 0000000..4fcb35c --- /dev/null +++ b/nginx/git.k-boris.tech.conf @@ -0,0 +1,34 @@ +server { + server_name git.k-boris.tech; + + client_max_body_size 100m; + + location / { + proxy_pass http://127.0.0.1:3000; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + listen 443 ssl; # managed by Certbot + listen [::]:443 ssl; # managed by Certbot + ssl_certificate /etc/letsencrypt/live/git.k-boris.tech/fullchain.pem; # managed by Certbot + ssl_certificate_key /etc/letsencrypt/live/git.k-boris.tech/privkey.pem; # managed by Certbot + include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot + ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot + +} +server { + if ($host = git.k-boris.tech) { + return 301 https://$host$request_uri; + } # managed by Certbot + + + listen 80; + listen [::]:80; + server_name git.k-boris.tech; + return 404; # managed by Certbot + + +} \ No newline at end of file diff --git a/nginx/k-boris.tech.conf b/nginx/k-boris.tech.conf new file mode 100644 index 0000000..e268dd0 --- /dev/null +++ b/nginx/k-boris.tech.conf @@ -0,0 +1,32 @@ +server { + listen 80; + listen [::]:80; + server_name k-boris.tech www.k-boris.tech; + return 301 https://$host$request_uri; +} + +server { + listen 443 ssl; + listen [::]:443 ssl; + server_name k-boris.tech www.k-boris.tech; + + ssl_certificate /etc/letsencrypt/live/k-boris.tech/fullchain.pem; + ssl_certificate_key /etc/letsencrypt/live/k-boris.tech/privkey.pem; + include /etc/letsencrypt/options-ssl-nginx.conf; + ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; + + client_max_body_size 10m; + + # Block admin from main domain — redirect to admin subdomain + location /admin/ { + return 301 https://admin.k-boris.tech$request_uri; + } + + location / { + proxy_pass http://127.0.0.1:8080; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } +}