map $original_uri $api_uri { ~^/api(/.*$) $1; default $original_uri; } server { listen 80; server_name localhost; root /usr/share/nginx/html/public; client_max_body_size ${NGINX_MAX_BODY_SIZE}; access_log /dev/stdout; error_log /dev/stderr error; index index.html index.htm index.php; # Frontend proxy location / { proxy_http_version 1.1; proxy_pass http://ui: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; proxy_set_header X-Forwarded-Host $host; proxy_set_header X-Forwarded-Port $server_port; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "Upgrade"; } # HMR websocket support location /_nuxt { proxy_pass http://ui:3000; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_cache_bypass $http_upgrade; } # API handling location ~/(api|open|local\/temp|forms\/assets)/ { set $original_uri $uri; try_files $uri $uri/ /index.php$is_args$args; } location ~ \.php$ { fastcgi_split_path_info ^(.+\.php)(/.+)$; fastcgi_pass api:9000; fastcgi_index index.php; include fastcgi_params; fastcgi_param SCRIPT_FILENAME $document_root/index.php; fastcgi_param REQUEST_URI $api_uri; fastcgi_read_timeout 300; } # Deny access to . files location ~ /\. { deny all; } }