X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/90a349e0bc558441e65156eabb585c578d93fbfd..e0eb12fed2fb98b8930c4e2d60b43d2b9fa3e2b5:/cookbooks/web/recipes/rails.rb diff --git a/cookbooks/web/recipes/rails.rb b/cookbooks/web/recipes/rails.rb index 14eacc50a..be51e2d8c 100644 --- a/cookbooks/web/recipes/rails.rb +++ b/cookbooks/web/recipes/rails.rb @@ -8,7 +8,7 @@ # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # -# http://www.apache.org/licenses/LICENSE-2.0 +# https://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, @@ -31,6 +31,8 @@ db_passwords = data_bag_item("db", "passwords") ssl_certificate "www.openstreetmap.org" do domains ["www.openstreetmap.org", "www.osm.org", "api.openstreetmap.org", "api.osm.org", + "maps.openstreetmap.org", "maps.osm.org", + "mapz.openstreetmap.org", "mapz.osm.org", "openstreetmap.org", "osm.org"] notifies :reload, "service[apache2]" end @@ -45,18 +47,17 @@ template "/etc/cron.hourly/passenger" do mode 0o755 end +ruby_version = node[:passenger][:ruby_version] rails_directory = "#{node[:web][:base_directory]}/rails" -piwik_configuration = data_bag_item("web", "piwik").to_hash.reject do |k, _| - %w[chef_type data_bag id].include?(k) -end +piwik = data_bag_item("web", "piwik") rails_port "www.openstreetmap.org" do - ruby node[:passenger][:ruby_version] + ruby ruby_version directory rails_directory user "rails" group "rails" - repository "git://git.openstreetmap.org/rails.git" + repository "https://git.openstreetmap.org/public/rails.git" revision "live" database_host node[:web][:database_host] database_name "openstreetmap" @@ -73,7 +74,9 @@ rails_port "www.openstreetmap.org" do potlatch2_key web_passwords["potlatch2_key"] id_key web_passwords["id_key"] oauth_key web_passwords["oauth_key"] - piwik_configuration piwik_configuration + piwik_configuration "location" => piwik[:location], + "site" => piwik[:site], + "goals" => piwik[:goals].to_hash google_auth_id "651529786092-6c5ahcu0tpp95emiec8uibg11asmk34t.apps.googleusercontent.com" google_auth_secret web_passwords["google_auth_secret"] google_openid_realm "https://www.openstreetmap.org" @@ -88,6 +91,21 @@ rails_port "www.openstreetmap.org" do mapzen_valhalla_key web_passwords["mapzen_valhalla_key"] thunderforest_key web_passwords["thunderforest_key"] totp_key web_passwords["totp_key"] + csp_enforce true +end + +systemd_service "rails-jobs" do + description "Rails job queue runner" + type "simple" + user "rails" + working_directory rails_directory + exec_start "/usr/local/bin/bundle#{ruby_version} exec rake jobs:work" + restart "on-failure" + private_tmp true + private_devices true + protect_system "full" + protect_home true + no_new_privileges true end package "libjson-xs-perl"