From 7d017d7feb3c3890da79c5c77400a5e52e8a88c5 Mon Sep 17 00:00:00 2001 From: "Guillaume \"B.B.\" Van Hemmen" Date: Mon, 21 Oct 2024 10:18:32 +0200 Subject: [PATCH] #0000 - Reorganize and enhance the NGINX configuration structure Introduce a refined NGINX configuration template with user, worker settings, and modular include directives. This improves clarity and allows easier integration of additional configuration files, while maintaining existing CORS settings. --- Dockerfile | 2 +- nginx-extra.conf | 18 ++++++++++++++++++ nginx.conf | 38 -------------------------------------- 3 files changed, 19 insertions(+), 39 deletions(-) create mode 100644 nginx-extra.conf delete mode 100644 nginx.conf diff --git a/Dockerfile b/Dockerfile index 3c91e38..62b3354 100644 --- a/Dockerfile +++ b/Dockerfile @@ -5,7 +5,7 @@ FROM nginx:alpine3.20 COPY dist /usr/share/nginx/html # Copy custom Nginx configuration file to the container -COPY nginx.conf /etc/nginx/nginx.conf +COPY nginx-extra.conf /etc/nginx/conf.d/nginx-extra.conf # Expose the port that the application is running on EXPOSE 80 diff --git a/nginx-extra.conf b/nginx-extra.conf new file mode 100644 index 0000000..71230cc --- /dev/null +++ b/nginx-extra.conf @@ -0,0 +1,18 @@ +location / { + # other settings... + # Allow CORS for all domains (or specify a particular domain instead of *) + add_header 'Access-Control-Allow-Origin' '*'; + # Allow specific headers + add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept, Authorization'; + # Allow specific methods + add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS'; + if ($request_method = 'OPTIONS') { + add_header 'Access-Control-Allow-Origin' '*'; + add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept, Authorization'; + add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS'; + add_header 'Access-Control-Max-Age' 1728000; + add_header 'Content-Type' 'text/plain; charset=utf-8'; + add_header 'Content-Length' 0; + return 204; + } +} diff --git a/nginx.conf b/nginx.conf deleted file mode 100644 index 4ee8485..0000000 --- a/nginx.conf +++ /dev/null @@ -1,38 +0,0 @@ -user www-data; - worker_processes auto; - pid /run/nginx.pid; - include /etc/nginx/modules-enabled/*.conf; - - events { - worker_connections 768; - } - - http { - server { - listen 80; - server_name yourdomain.com; - - location / { - # other settings... - # Allow CORS for all domains (or specify a particular domain instead of *) - add_header 'Access-Control-Allow-Origin' '*'; - # Allow specific headers - add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept, Authorization'; - # Allow specific methods - add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS'; - if ($request_method = 'OPTIONS') { - add_header 'Access-Control-Allow-Origin' '*'; - add_header 'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept, Authorization'; - add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS'; - add_header 'Access-Control-Max-Age' 1728000; - add_header 'Content-Type' 'text/plain; charset=utf-8'; - add_header 'Content-Length' 0; - return 204; - } - } - } - - # Include other server and configuration files - include /etc/nginx/conf.d/*.conf; - include /etc/nginx/sites-enabled/*; - }