X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/4f745d06c1d93398437caaa2bc88ab7fb86ebe96..35f220a555dee107786152d3daff4d66d1655e56:/cookbooks/web/definitions/rails_port.rb diff --git a/cookbooks/web/definitions/rails_port.rb b/cookbooks/web/definitions/rails_port.rb index 23c98cbaf..79a9cc836 100644 --- a/cookbooks/web/definitions/rails_port.rb +++ b/cookbooks/web/definitions/rails_port.rb @@ -69,53 +69,6 @@ define :rails_port, :action => [:create, :enable] do recursive true end - execute rails_directory do - action :nothing - command "passenger-config restart-app #{rails_directory}" - user "root" - group "root" - only_if { File.exist?("/usr/bin/passenger-config") } - end - - file "#{rails_directory}/public/export/embed.html" do - action :nothing - end - - execute "#{rails_directory}/public/assets" do - action :nothing - command "bundle#{ruby_version} exec rake#{ruby_version} assets:precompile" - environment "RAILS_ENV" => "production" - cwd rails_directory - user rails_user - group rails_group - notifies :delete, "file[#{rails_directory}/public/export/embed.html]", :immediate - notifies :run, "execute[#{rails_directory}]", :immediate - end - - execute "#{rails_directory}/db/migrate" do - action :nothing - command "bundle#{ruby_version} exec rake#{ruby_version} db:migrate" - cwd rails_directory - user rails_user - group rails_group - notifies :run, "execute[#{rails_directory}/public/assets]", :immediate - end - - execute "#{rails_directory}/Gemfile" do - action :nothing - command "bundle#{ruby_version} install" - cwd rails_directory - user "root" - group "root" - environment "NOKOGIRI_USE_SYSTEM_LIBRARIES" => "yes" - if run_migrations - notifies :run, "execute[#{rails_directory}/db/migrate]", :immediate - else - notifies :run, "execute[#{rails_directory}/public/assets]", :immediate - end - subscribes :run, "gem_package[bundler#{ruby_version}]" - end - directory rails_directory do owner rails_user group rails_group @@ -128,7 +81,10 @@ define :rails_port, :action => [:create, :enable] do revision rails_revision user rails_user group rails_group - notifies :run, "execute[#{rails_directory}/Gemfile]", :immediate + notifies :run, "execute[#{rails_directory}/Gemfile]" + notifies :run, "execute[#{rails_directory}/public/assets]" + notifies :delete, "file[#{rails_directory}/public/export/embed.html]" + notifies :run, "execute[#{rails_directory}]" end directory "#{rails_directory}/tmp" do @@ -189,7 +145,7 @@ define :rails_port, :action => [:create, :enable] do end if params[:memcache_servers] - line.gsub!(/^( *)#memcache_servers:.*$/, "\\1memcache_servers: [ \"#{params[:memcache_servers].join("\", \"")}\" ]") + line.gsub!(/^( *)#memcache_servers:.*$/, "\\1memcache_servers: [ \"#{params[:memcache_servers].join('", "')}\" ]") end if params[:potlatch2_key] @@ -208,6 +164,10 @@ define :rails_port, :action => [:create, :enable] do line.gsub!(/^( *)nominatim_url:.*$/, "\\1nominatim_url: \"#{params[:nominatim_url]}\"") end + if params[:osrm_url] + line.gsub!(/^( *)osrm_url:.*$/, "\\1osrm_url: \"#{params[:osrm_url]}\"") + end + if params[:google_auth_id] line.gsub!(/^( *)#google_auth_id:.*$/, "\\1google_auth_id: \"#{params[:google_auth_id]}\"") line.gsub!(/^( *)#google_auth_secret:.*$/, "\\1google_auth_secret: \"#{params[:google_auth_secret]}\"") @@ -261,6 +221,42 @@ define :rails_port, :action => [:create, :enable] do end end + execute "#{rails_directory}/Gemfile" do + action :nothing + command "bundle#{ruby_version} install" + cwd rails_directory + user "root" + group "root" + environment "NOKOGIRI_USE_SYSTEM_LIBRARIES" => "yes" + subscribes :run, "gem_package[bundler#{ruby_version}]" + notifies :run, "execute[#{rails_directory}]" + end + + execute "#{rails_directory}/db/migrate" do + action :nothing + command "bundle#{ruby_version} exec rake#{ruby_version} db:migrate" + cwd rails_directory + user rails_user + group rails_group + subscribes :run, "git[#{rails_directory}]" + notifies :run, "execute[#{rails_directory}]" + only_if { run_migrations } + end + + execute "#{rails_directory}/public/assets" do + action :nothing + command "bundle#{ruby_version} exec rake#{ruby_version} assets:precompile" + environment "RAILS_ENV" => "production" + cwd rails_directory + user rails_user + group rails_group + notifies :run, "execute[#{rails_directory}]" + end + + file "#{rails_directory}/public/export/embed.html" do + action :nothing + end + execute "#{rails_directory}/lib/quad_tile/extconf.rb" do command "ruby extconf.rb" cwd "#{rails_directory}/lib/quad_tile" @@ -283,7 +279,15 @@ define :rails_port, :action => [:create, :enable] do notifies :run, "execute[#{rails_directory}]" end - template "/etc/cron.daily/rails-#{name}" do + execute rails_directory do + action :nothing + command "passenger-config restart-app --ignore-app-not-running #{rails_directory}" + user "root" + group "root" + only_if { File.exist?("/usr/bin/passenger-config") } + end + + template "/etc/cron.daily/rails-#{name.tr('.', '-')}" do cookbook "web" source "rails.cron.erb" owner "root"