2026-03-19 17:02:17 +00:00
|
|
|
server {
|
2026-06-19 05:03:18 -04:00
|
|
|
# Host-networked: listen on the app's own port directly (NOT 80, which the
|
|
|
|
|
# host's main nginx already owns). The app is reached at http(s)://<node>:18083.
|
|
|
|
|
listen 18083;
|
2026-03-19 17:02:17 +00:00
|
|
|
server_name _;
|
|
|
|
|
|
|
|
|
|
root /usr/share/nginx/html;
|
|
|
|
|
index index.html;
|
|
|
|
|
|
2026-06-19 05:03:18 -04:00
|
|
|
# Proxy the archipelago backend same-origin so the browser never makes a
|
|
|
|
|
# cross-origin request (no CORS, no host-nginx route dependency). The app is
|
|
|
|
|
# served on this node's :18083; cookies are scoped by host (not port), so the
|
|
|
|
|
# browser already carries the `session` (HttpOnly) and `csrf_token` cookies
|
|
|
|
|
# set by the main UI. We forward both, plus the X-CSRF-Token header, to the
|
|
|
|
|
# backend on 127.0.0.1:5678 (reachable because this container is host-networked).
|
|
|
|
|
#
|
|
|
|
|
# This mirrors fips-ui / electrs-ui. The old bridge + 18083→80 mapping forced
|
|
|
|
|
# cross-origin fetches that broke on http-only nodes (blank fields, QR
|
|
|
|
|
# "failed to fetch").
|
|
|
|
|
location = /lnd-connect-info {
|
|
|
|
|
proxy_pass http://127.0.0.1:5678/lnd-connect-info;
|
|
|
|
|
proxy_http_version 1.1;
|
|
|
|
|
proxy_set_header Host $host;
|
|
|
|
|
proxy_set_header Cookie $http_cookie;
|
|
|
|
|
proxy_set_header X-CSRF-Token $http_x_csrf_token;
|
|
|
|
|
proxy_set_header X-Real-IP $remote_addr;
|
|
|
|
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
|
|
|
proxy_connect_timeout 10s;
|
|
|
|
|
proxy_read_timeout 60s;
|
|
|
|
|
add_header Cache-Control "no-store, no-cache, must-revalidate";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
location /proxy/lnd/ {
|
|
|
|
|
proxy_pass http://127.0.0.1:5678/proxy/lnd/;
|
|
|
|
|
proxy_http_version 1.1;
|
|
|
|
|
proxy_set_header Host $host;
|
|
|
|
|
proxy_set_header Cookie $http_cookie;
|
|
|
|
|
proxy_set_header X-CSRF-Token $http_x_csrf_token;
|
|
|
|
|
proxy_set_header X-Real-IP $remote_addr;
|
|
|
|
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
|
|
|
proxy_connect_timeout 10s;
|
|
|
|
|
proxy_read_timeout 60s;
|
|
|
|
|
add_header Cache-Control "no-store";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
location /api/container/logs {
|
|
|
|
|
proxy_pass http://127.0.0.1:5678/api/container/logs;
|
|
|
|
|
proxy_http_version 1.1;
|
|
|
|
|
proxy_set_header Host $host;
|
|
|
|
|
proxy_set_header Cookie $http_cookie;
|
|
|
|
|
proxy_set_header X-CSRF-Token $http_x_csrf_token;
|
|
|
|
|
proxy_set_header X-Real-IP $remote_addr;
|
|
|
|
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
|
|
|
proxy_connect_timeout 10s;
|
|
|
|
|
proxy_read_timeout 30s;
|
|
|
|
|
add_header Cache-Control "no-store";
|
|
|
|
|
}
|
|
|
|
|
|
2026-03-19 17:02:17 +00:00
|
|
|
location / {
|
2026-06-19 05:03:18 -04:00
|
|
|
add_header Cache-Control "no-cache";
|
2026-03-19 17:02:17 +00:00
|
|
|
try_files $uri $uri/ /index.html;
|
|
|
|
|
}
|
|
|
|
|
}
|