X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/c198686d51e5616b0c693e78eab55966a8522420..644f12460af63db5fa70baa490def90dd7374ad7:/cookbooks/dev/recipes/default.rb?ds=sidebyside diff --git a/cookbooks/dev/recipes/default.rb b/cookbooks/dev/recipes/default.rb index fd5db8de0..d33534491 100644 --- a/cookbooks/dev/recipes/default.rb +++ b/cookbooks/dev/recipes/default.rb @@ -67,6 +67,7 @@ package %w[ libboost-program-options-dev libboost-regex-dev libboost-system-dev + libbytes-random-secure-perl libcairo2-dev libcrypto++-dev libcurl4-openssl-dev @@ -79,6 +80,7 @@ package %w[ libmemcached-dev libpqxx-dev libtool + libxml-twig-perl libxml2-dev libyajl-dev lua-any @@ -296,7 +298,7 @@ if node[:postgresql][:clusters][:"15/main"] systemd_service "rails-jobs@" do description "Rails job queue runner" type "simple" - environment "RAILS_ENV" => "production", "SLEEP_DELAY" => "60" + environment_file "/etc/default/rails-%i" user "apis" working_directory "/srv/%i.apis.dev.openstreetmap.org/rails" exec_start "#{node[:ruby][:bundle]} exec rails jobs:work" @@ -316,16 +318,17 @@ if node[:postgresql][:clusters][:"15/main"] type "forking" environment_file "/etc/default/cgimap-%i" user "apis" - exec_start "/srv/%i.apis.dev.openstreetmap.org/cgimap/openstreetmap-cgimap --daemon --port $CGIMAP_PORT --instances 5" + group "www-data" + umask "0002" + exec_start "/srv/%i.apis.dev.openstreetmap.org/cgimap/build/openstreetmap-cgimap --daemon --instances 5" exec_reload "/bin/kill -HUP $MAINPID" + runtime_directory "cgimap-%i" sandbox :enable_network => true restrict_address_families "AF_UNIX" read_write_paths ["/srv/%i.apis.dev.openstreetmap.org/logs", "/srv/%i.apis.dev.openstreetmap.org/rails/tmp"] restart "on-failure" end - cgimap_port = 9000 - Dir.glob("/srv/*.apis.dev.openstreetmap.org").each do |dir| node.default_unless[:dev][:rails][File.basename(dir).split(".").first] = {} end @@ -384,6 +387,12 @@ if node[:postgresql][:clusters][:"15/main"] mode "755" end + openssl_rsa_private_key "#{site_directory}/doorkeeper.key" do + owner "root" + group "root" + mode "0400" + end + rails_port site_name do directory rails_directory user "apis" @@ -400,6 +409,7 @@ if node[:postgresql][:clusters][:"15/main"] csp_enforce true run_migrations true trace_use_job_queue true + doorkeeper_signing_key lazy { File.read("#{site_directory}/doorkeeper.key") } end template "#{rails_directory}/config/initializers/setup.rb" do @@ -411,6 +421,14 @@ if node[:postgresql][:clusters][:"15/main"] notifies :restart, "rails_port[#{site_name}]" end + template "/etc/default/rails-#{name}" do + source "rails.environment.erb" + owner "root" + group "root" + mode "0600" + variables :secret_key_base => secret_key_base + end + service "rails-jobs@#{name}" do action [:enable, :start] supports :restart => true @@ -428,31 +446,28 @@ if node[:postgresql][:clusters][:"15/main"] group "apis" end - execute "#{cgimap_directory}/autogen.sh" do - action :nothing - command "./autogen.sh" - cwd cgimap_directory + directory "#{cgimap_directory}/build" do user "apis" group "apis" - subscribes :run, "git[#{cgimap_directory}]", :immediately + mode "0755" end - execute "#{cgimap_directory}/configure" do + execute "#{cgimap_directory}/CMakeLists.txt" do action :nothing - command "./configure --with-fcgi=/usr --with-boost-libdir=/usr/lib/x86_64-linux-gnu --enable-yajl" - cwd cgimap_directory + command "cmake .." + cwd "#{cgimap_directory}/build" user "apis" group "apis" - subscribes :run, "execute[#{cgimap_directory}/autogen.sh]", :immediately + subscribes :run, "git[#{cgimap_directory}]", :immediately end - execute "#{cgimap_directory}/Makefile" do + execute "#{cgimap_directory}/build/Makefile" do action :nothing command "make -j" - cwd cgimap_directory + cwd "#{cgimap_directory}/build" user "apis" group "apis" - subscribes :run, "execute[#{cgimap_directory}/configure]", :immediately + subscribes :run, "execute[#{cgimap_directory}/CMakeLists.txt]", :immediately end template "/etc/default/cgimap-#{name}" do @@ -460,15 +475,16 @@ if node[:postgresql][:clusters][:"15/main"] owner "root" group "root" mode "640" - variables :cgimap_port => cgimap_port, + variables :cgimap_socket => "/run/cgimap-#{name}/socket", :database_port => node[:postgresql][:clusters][:"15/main"][:port], :database_name => database_name, - :log_directory => log_directory + :log_directory => log_directory, + :options => details[:cgimap_options] end service "cgimap@#{name}" do action [:start, :enable] - subscribes :restart, "execute[#{cgimap_directory}/Makefile]" + subscribes :restart, "execute[#{cgimap_directory}/build/Makefile]" subscribes :restart, "template[/etc/default/cgimap-#{name}]" subscribes :restart, "systemd_service[cgimap@]" end @@ -485,7 +501,7 @@ if node[:postgresql][:clusters][:"15/main"] :aliases => site_aliases, :secret_key_base => secret_key_base, :cgimap_enabled => details.key?(:cgimap_repository), - :cgimap_port => cgimap_port + :cgimap_socket => "/run/cgimap-#{name}/socket" end template "/etc/logrotate.d/apis-#{name}" do @@ -497,8 +513,6 @@ if node[:postgresql][:clusters][:"15/main"] :log_directory => log_directory, :rails_directory => rails_directory end - - cgimap_port += 1 else file "/etc/logrotate.d/apis-#{name}" do action :delete @@ -593,3 +607,16 @@ end apache_site "ooc.openstreetmap.org" do template "apache.ooc.erb" end + +directory "/etc/systemd/system/user-.slice.d" do + owner "root" + group "root" + mode "0755" +end + +template "/etc/systemd/system/user-.slice.d/99-chef.conf" do + source "user-slice.conf.erb" + owner "root" + group "root" + mode "0644" +end