55 lines
1.6 KiB
Plaintext
55 lines
1.6 KiB
Plaintext
server {
|
|
listen 80;
|
|
server_name localhost;
|
|
|
|
# Redirigir todo el tráfico HTTP a HTTPS
|
|
return 301 https://$host$request_uri;
|
|
}
|
|
|
|
server {
|
|
listen 443 ssl;
|
|
server_name localhost;
|
|
root /var/www/html/public;
|
|
index index.html index.php;
|
|
|
|
ssl_certificate /etc/nginx/certs/server.crt; # Ruta al certificado
|
|
ssl_certificate_key /etc/nginx/certs/server.key; # Ruta a la clave
|
|
|
|
# Reescritura para corregir las URLs con doble barra, pero sin cambiar el path de los archivos
|
|
# Reescribir URL con doble barra
|
|
location /opengnsys/rest/ {
|
|
# Eliminar la doble barra cuando exista entre /rest/ y /ous/
|
|
rewrite ^(/opengnsys/rest)//(.*)$ $1/$2 break;
|
|
|
|
# Proxy hacia el backend
|
|
proxy_pass https://127.0.0.1:8443;
|
|
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;
|
|
}
|
|
|
|
# Bloque principal para archivos
|
|
location / {
|
|
try_files $uri $uri/ /index.php?$args;
|
|
}
|
|
|
|
# Manejo de PHP
|
|
location ~ \.php$ {
|
|
include fastcgi_params;
|
|
fastcgi_pass php:9000;
|
|
fastcgi_split_path_info ^(.+\.php)(/.*)$;
|
|
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
|
fastcgi_param PATH_INFO $request_uri;
|
|
fastcgi_param PATH_TRANSLATED $document_root$fastcgi_script_name;
|
|
}
|
|
|
|
# Bloque para errores PHP
|
|
location ~ \.php$ {
|
|
return 404;
|
|
}
|
|
|
|
error_log /var/log/nginx/error.log;
|
|
access_log /var/log/nginx/access.log;
|
|
}
|