From 64f8947dd5ba1ad49f9d737c779a53db26804be3 Mon Sep 17 00:00:00 2001 From: Andrea Dell'Amico Date: Mon, 28 Nov 2016 16:40:45 +0100 Subject: [PATCH] library/roles/nginx: Add a snippet to enable CORS. --- nginx/defaults/main.yml | 3 +++ nginx/templates/nginx-cors.conf.j2 | 13 +++++++++++++ 2 files changed, 16 insertions(+) create mode 100644 nginx/templates/nginx-cors.conf.j2 diff --git a/nginx/defaults/main.yml b/nginx/defaults/main.yml index ab5514c6..8d0dd90b 100644 --- a/nginx/defaults/main.yml +++ b/nginx/defaults/main.yml @@ -15,6 +15,7 @@ nginx_conf_snippets: - letsencrypt-proxy.conf - nginx-proxy-params.conf - nginx-server-ssl.conf + - nginx-cors.conf nginx_old_snippets: - compression.conf @@ -55,6 +56,8 @@ nginx_proxy_send_timeout: 120s nginx_client_max_body_size: 32000M nginx_client_body_timeout: 240s +nginx_cors_acl_origin: 'http?://(localhost)' + # Find a set of acceptable defaults for the cache setup nginx_cache_enabled: False diff --git a/nginx/templates/nginx-cors.conf.j2 b/nginx/templates/nginx-cors.conf.j2 new file mode 100644 index 00000000..69dd1888 --- /dev/null +++ b/nginx/templates/nginx-cors.conf.j2 @@ -0,0 +1,13 @@ +# set $cors ''; +# if ($http_origin ~* '{{ nginx_cors_acl_origin }}') { +# set $cors 'true'; +# } +# if ($cors = 'true') { + add_header 'Access-Control-Allow-Origin' "$http_origin"; + add_header 'Access-Control-Allow-Credentials' 'true'; + add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS'; + add_header 'Access-Control-Allow-Headers' 'Accept,Authorization,Cache-Control,Content-Type,DNT,If-Modified-Since,Keep-Alive,Origin,User-Agent,X-Mx-ReqToken,X-Requested-With'; +# } +if ($request_method = 'OPTIONS') { + return 204; +}