| server { |
| listen 5173; |
| server_name localhost; |
| |
| |
| root /usr/share/nginx/html; |
| index index.html; |
| |
| |
| gzip on; |
| gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript; |
| |
| |
| |
| location /api/ { |
| proxy_pass http://api:8000/api/; |
| proxy_http_version 1.1; |
| 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; |
| |
| |
| add_header Access-Control-Allow-Origin *; |
| add_header Access-Control-Allow-Methods "GET, POST, PUT, DELETE, OPTIONS"; |
| add_header Access-Control-Allow-Headers "Authorization, Content-Type"; |
| |
| |
| if ($request_method = OPTIONS) { |
| return 204; |
| } |
| } |
| |
| |
| |
| location /ws/ { |
| proxy_pass http://api:8000/ws/; |
| proxy_http_version 1.1; |
| proxy_set_header Upgrade $http_upgrade; |
| proxy_set_header Connection "upgrade"; |
| 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_read_timeout 3600s; |
| proxy_send_timeout 3600s; |
| } |
| |
| |
| location / { |
| try_files $uri $uri/ /index.html; |
| } |
|
|
| |
| location = /health { |
| add_header Content-Type text/plain; |
| return 200 'ok'; |
| } |
| |
| |
| location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg|woff|woff2|ttf|eot)$ { |
| expires 1y; |
| add_header Cache-Control "public, immutable"; |
| } |
| } |
|
|
|
|