#
-# Cookbook Name:: stateofthemap
+# Cookbook:: stateofthemap
# Recipe:: default
#
-# Copyright 2013, OpenStreetMap Foundation
+# Copyright:: 2013, OpenStreetMap Foundation
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
action :sync
repository "https://git.openstreetmap.org/public/stateofthemap.git"
revision "chooser"
+ depth 1
user "root"
group "root"
end
directory "/srv/2007.stateofthemap.org" do
owner "wordpress"
group "wordpress"
- mode 0o755
+ mode "755"
end
wordpress_site "2007.stateofthemap.org" do
database_user "sotm2007"
database_password passwords["sotm2007"]
database_prefix "wp_sotm_"
+ fpm_prometheus_port 12007
end
wordpress_theme "2007.stateofthemap.org-refreshwp-11" do
directory "/srv/2008.stateofthemap.org" do
owner "wordpress"
group "wordpress"
- mode 0o755
+ mode "755"
end
wordpress_site "2008.stateofthemap.org" do
database_user "sotm2008"
database_password passwords["sotm2008"]
database_prefix "wp_sotm08_"
+ fpm_prometheus_port 12008
end
wordpress_theme "2008.stateofthemap.org-refreshwp-11" do
directory "/srv/2009.stateofthemap.org" do
owner "wordpress"
group "wordpress"
- mode 0o755
+ mode "755"
end
git "/srv/2009.stateofthemap.org" do
action :sync
repository "https://git.openstreetmap.org/public/stateofthemap.git"
revision "resources-2009"
+ depth 1
user "wordpress"
group "wordpress"
end
urls "/register" => "/srv/2009.stateofthemap.org/register",
"/register-pro-user" => "/srv/2009.stateofthemap.org/register-pro-user",
"/podcasts" => "/srv/2009.stateofthemap.org/podcasts"
+ fpm_prometheus_port 12009
end
wordpress_theme "2009.stateofthemap.org-aerodrome" do
directory "/srv/2010.stateofthemap.org" do
owner "wordpress"
group "wordpress"
- mode 0o755
+ mode "755"
end
git "/srv/2010.stateofthemap.org" do
action :sync
repository "https://git.openstreetmap.org/public/stateofthemap.git"
revision "resources-2010"
+ depth 1
user "wordpress"
group "wordpress"
end
database_user "sotm2010"
database_password passwords["sotm2010"]
urls "/register" => "/srv/2010.stateofthemap.org/register"
+ fpm_prometheus_port 12010
end
wordpress_theme "2010.stateofthemap.org-aerodrome" do
plugin "sitepress-multilingual-cms"
site "2010.stateofthemap.org"
repository "https://git.openstreetmap.org/private/sitepress-multilingual-cms.git"
+ not_if { ENV["TEST_KITCHEN"] }
end
wordpress_plugin "2010.stateofthemap.org-wp-sticky" do
directory "/srv/2011.stateofthemap.org" do
owner "wordpress"
group "wordpress"
- mode 0o755
+ mode "755"
end
git "/srv/2011.stateofthemap.org" do
action :sync
repository "https://git.openstreetmap.org/public/stateofthemap.git"
revision "resources-2011"
+ depth 1
user "wordpress"
group "wordpress"
end
database_user "sotm2011"
database_password passwords["sotm2011"]
urls "/register" => "/srv/2011.stateofthemap.org/register"
+ fpm_prometheus_port 12011
end
wordpress_theme "2011.stateofthemap.org-aerodrome" do
plugin "sitepress-multilingual-cms"
site "2011.stateofthemap.org"
repository "https://git.openstreetmap.org/private/sitepress-multilingual-cms.git"
+ not_if { ENV["TEST_KITCHEN"] }
end
wordpress_plugin "2011.stateofthemap.org-wp-sticky" do
directory "/srv/2012.stateofthemap.org" do
owner "wordpress"
group "wordpress"
- mode 0o755
+ mode "755"
end
git "/srv/2012.stateofthemap.org" do
action :sync
repository "https://git.openstreetmap.org/public/stateofthemap.git"
revision "resources-2012"
+ depth 1
user "wordpress"
group "wordpress"
end
database_user "sotm2012"
database_password passwords["sotm2012"]
urls "/register" => "/srv/2012.stateofthemap.org/register"
+ fpm_prometheus_port 12012
end
wordpress_theme "2012.stateofthemap.org-aerodrome" do
plugin "sitepress-multilingual-cms"
site "2012.stateofthemap.org"
repository "https://git.openstreetmap.org/private/sitepress-multilingual-cms.git"
+ not_if { ENV["TEST_KITCHEN"] }
end
wordpress_plugin "2012.stateofthemap.org-wp-sticky" do
action :sync
repository "https://git.openstreetmap.org/public/stateofthemap.git"
revision "site-#{year}"
+ depth 1
user "root"
group "root"
end
ssl_certificate "#{year}.stateofthemap.org" do
- domains ["#{year}.stateofthemap.org", "#{year}.stateofthemap.com"]
+ domains ["#{year}.stateofthemap.org", "#{year}.stateofthemap.com", "#{year}.sotm.org"]
notifies :reload, "service[apache2]"
end
end
end
-%w[2016 2017 2018].each do |year|
+package %w[
+ gcc
+ g++
+ make
+ ruby
+ ruby-dev
+ libssl-dev
+ zlib1g-dev
+ pkg-config
+]
+
+apache_module "expires"
+apache_module "rewrite"
+
+gem_package "bundler" do
+ version "1.17.3"
+end
+
+gem_package "bundler" do
+ version "2.1.4"
+end
+
+%w[2016 2017 2018 2019 2020].each do |year|
git "/srv/#{year}.stateofthemap.org" do
action :sync
- repository "git://github.com/openstreetmap/stateofthemap-#{year}.git"
+ repository "https://github.com/openstreetmap/stateofthemap-#{year}.git"
+ depth 1
user "root"
group "root"
- notifies :run, "execute[/srv/#{year}.stateofthemap.org]"
+ notifies :run, "execute[/srv/#{year}.stateofthemap.org/Gemfile]"
end
directory "/srv/#{year}.stateofthemap.org/_site" do
- mode 0o755
+ mode "755"
+ owner "nobody"
+ group "nogroup"
+ end
+
+ # Workaround https://github.com/jekyll/jekyll/issues/7804
+ # by creating a .jekyll-cache folder
+ directory "/srv/#{year}.stateofthemap.org/.jekyll-cache" do
+ mode "755"
owner "nobody"
group "nogroup"
end
+ execute "/srv/#{year}.stateofthemap.org/Gemfile" do
+ action :nothing
+ command "bundle install --deployment"
+ cwd "/srv/#{year}.stateofthemap.org"
+ user "root"
+ group "root"
+ notifies :run, "execute[/srv/#{year}.stateofthemap.org]"
+ only_if { ::File.exist?("/srv/#{year}.stateofthemap.org/Gemfile") }
+ end
+
execute "/srv/#{year}.stateofthemap.org" do
action :nothing
- command "jekyll build --trace"
+ command "bundle exec jekyll build --trace --baseurl=https://#{year}.stateofthemap.org"
cwd "/srv/#{year}.stateofthemap.org"
user "nobody"
group "nogroup"
end
ssl_certificate "#{year}.stateofthemap.org" do
- domains ["#{year}.stateofthemap.org", "#{year}.stateofthemap.com"]
+ domains ["#{year}.stateofthemap.org", "#{year}.stateofthemap.com", "#{year}.sotm.org"]
notifies :reload, "service[apache2]"
end
source "backup.cron.erb"
owner "root"
group "root"
- mode 0o750
+ mode "750"
variables :passwords => passwords
end