X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/c87a97890768b4427f078d7deda0d1edf4bb39ce..f9acb65826eba9302b5e39a740e16fee8386076d:/cookbooks/blogs/recipes/default.rb diff --git a/cookbooks/blogs/recipes/default.rb b/cookbooks/blogs/recipes/default.rb index 165befb5e..6b181f209 100644 --- a/cookbooks/blogs/recipes/default.rb +++ b/cookbooks/blogs/recipes/default.rb @@ -20,29 +20,16 @@ include_recipe "accounts" include_recipe "apache" include_recipe "git" - -ruby_version = if node[:lsb][:release].to_f < 20.04 - "2.5" - else - "2.7" - end +include_recipe "ruby" package %W[ - ruby#{ruby_version} - ruby#{ruby_version}-dev make gcc g++ libsqlite3-dev + sqlite3 ] -gem_package "bundler#{ruby_version}" do - package_name "bundler" - version "~> 2.1.4" - gem_binary "gem#{ruby_version}" - options "--format-executable" -end - directory "/srv/blogs.openstreetmap.org" do owner "blogs" group "blogs" @@ -55,22 +42,20 @@ git "/srv/blogs.openstreetmap.org" do depth 1 user "blogs" group "blogs" - notifies :run, "execute[/srv/blogs.openstreetmap.org/Gemfile]", :immediately + notifies :run, "bundle_install[/srv/blogs.openstreetmap.org]", :immediately end -execute "/srv/blogs.openstreetmap.org/Gemfile" do +bundle_install "/srv/blogs.openstreetmap.org" do action :nothing - command "bundle#{ruby_version} install --deployment" - cwd "/srv/blogs.openstreetmap.org" - user "blogs" - group "blogs" - notifies :run, "execute[/srv/blogs.openstreetmap.org]", :immediately + options "--deployment" + user "root" + group "root" + notifies :run, "bundle_exec[/srv/blogs.openstreetmap.org]", :immediately end -execute "/srv/blogs.openstreetmap.org" do +bundle_exec "/srv/blogs.openstreetmap.org" do action :nothing - command "bundle#{ruby_version} exec pluto build -t osm -o build" - cwd "/srv/blogs.openstreetmap.org" + command "pluto build -t osm -o build" user "blogs" group "blogs" end @@ -91,12 +76,29 @@ template "/usr/local/bin/blogs-update" do owner "root" group "root" mode "0755" - variables :ruby_version => ruby_version end -cron_d "blogs" do - minute "*/30" +systemd_service "blogs-update" do + description "Update blog aggregator" + exec_start "/usr/local/bin/blogs-update" user "blogs" - command "/usr/local/bin/blogs-update" - mailto "admins@openstreetmap.org" + sandbox :enable_network => true + read_write_paths "/srv/blogs.openstreetmap.org" +end + +systemd_timer "blogs-update" do + description "Update blog aggregator" + on_boot_sec "15m" + on_unit_inactive_sec "30m" +end + +service "blogs-update.timer" do + action [:enable, :start] +end + +template "/etc/cron.daily/blogs-backup" do + source "backup.cron.erb" + owner "root" + group "root" + mode "0755" end