From d13fa69cea28740529475fb903039962476c3c25 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20Andr=C3=A9?= Date: Fri, 12 Aug 2016 10:18:59 +0200 Subject: [PATCH] Add CORS settings Allow configuring CORS settings. Change-Id: I17c6298d051a25ce1917f4c4b32bfafe76c6e367 --- manifests/cors.pp | 58 +++++++++++++++++++ .../notes/heat_cors-10be802ba4227f07.yaml | 3 + spec/classes/heat_cors_spec.rb | 49 ++++++++++++++++ 3 files changed, 110 insertions(+) create mode 100644 manifests/cors.pp create mode 100644 releasenotes/notes/heat_cors-10be802ba4227f07.yaml create mode 100644 spec/classes/heat_cors_spec.rb diff --git a/manifests/cors.pp b/manifests/cors.pp new file mode 100644 index 00000000..efbd683e --- /dev/null +++ b/manifests/cors.pp @@ -0,0 +1,58 @@ +# == Class: heat::cors +# +# Configure the heat cors +# +# === Parameters +# +# [*allowed_origin*] +# (Optional) Indicate whether this resource may be shared with the domain +# received in the requests "origin" header. +# (string value) +# Defaults to $::os_service_default. +# +# [*allow_credentials*] +# (Optional) Indicate that the actual request can include user credentials. +# (boolean value) +# Defaults to $::os_service_default. +# +# [*expose_headers*] +# (Optional) Indicate which headers are safe to expose to the API. +# (list value) +# Defaults to $::os_service_default. +# +# [*max_age*] +# (Optional) Maximum cache age of CORS preflight requests. +# (integer value) +# Defaults to $::os_service_default. +# +# [*allow_methods*] +# (Optional) Indicate which methods can be used during the actual request. +# (list value) +# Defaults to $::os_service_default. +# +# [*allow_headers*] +# (Optional) Indicate which header field names may be used during the actual +# request. +# (list value) +# Defaults to $::os_service_default. +# +class heat::cors ( + $allowed_origin = $::os_service_default, + $allow_credentials = $::os_service_default, + $expose_headers = $::os_service_default, + $max_age = $::os_service_default, + $allow_methods = $::os_service_default, + $allow_headers = $::os_service_default, +) { + + include ::heat::deps + + oslo::cors { 'heat_config': + allowed_origin => $allowed_origin, + allow_credentials => $allow_credentials, + expose_headers => $expose_headers, + max_age => $max_age, + allow_methods => $allow_methods, + allow_headers => $allow_headers, + } +} diff --git a/releasenotes/notes/heat_cors-10be802ba4227f07.yaml b/releasenotes/notes/heat_cors-10be802ba4227f07.yaml new file mode 100644 index 00000000..0927c4e3 --- /dev/null +++ b/releasenotes/notes/heat_cors-10be802ba4227f07.yaml @@ -0,0 +1,3 @@ +--- +features: + - allows configuring CORS settings. diff --git a/spec/classes/heat_cors_spec.rb b/spec/classes/heat_cors_spec.rb new file mode 100644 index 00000000..88efbbb9 --- /dev/null +++ b/spec/classes/heat_cors_spec.rb @@ -0,0 +1,49 @@ +require 'spec_helper' + +describe 'heat::cors' do + + shared_examples_for 'heat cors' do + it 'configure cors default params' do + is_expected.to contain_heat_config('cors/allowed_origin').with_value('') + is_expected.to contain_heat_config('cors/allow_credentials').with_value('') + is_expected.to contain_heat_config('cors/expose_headers').with_value('') + is_expected.to contain_heat_config('cors/max_age').with_value('') + is_expected.to contain_heat_config('cors/allow_methods').with_value('') + is_expected.to contain_heat_config('cors/allow_headers').with_value('') + end + + context 'with specific parameters' do + let :params do + { :allowed_origin => '*', + :allow_credentials => true, + :expose_headers => 'Content-Language,Expires', + :max_age => 3600, + :allow_methods => 'GET,POST,PUT,DELETE,OPTIONS', + :allow_headers => 'Content-Type,Cache-Control', + } + end + + it 'configure cors params' do + is_expected.to contain_heat_config('cors/allowed_origin').with_value('*') + is_expected.to contain_heat_config('cors/allow_credentials').with_value(true) + is_expected.to contain_heat_config('cors/expose_headers').with_value('Content-Language,Expires') + is_expected.to contain_heat_config('cors/max_age').with_value(3600) + is_expected.to contain_heat_config('cors/allow_methods').with_value('GET,POST,PUT,DELETE,OPTIONS') + is_expected.to contain_heat_config('cors/allow_headers').with_value('Content-Type,Cache-Control') + end + end + end + + on_supported_os({ + :supported_os => OSDefaults.get_supported_os + }).each do |os,facts| + context "on #{os}" do + let (:facts) do + facts.merge!(OSDefaults.get_facts()) + end + + it_configures 'heat cors' + end + end + +end