5 # Copyright:: 2021, OpenStreetMap Foundation
7 # Licensed under the Apache License, Version 2.0 (the "License");
8 # you may not use this file except in compliance with the License.
9 # You may obtain a copy of the License at
11 # https://www.apache.org/licenses/LICENSE-2.0
13 # Unless required by applicable law or agreed to in writing, software
14 # distributed under the License is distributed on an "AS IS" BASIS,
15 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 # See the License for the specific language governing permissions and
17 # limitations under the License.
20 include_recipe "accounts"
21 include_recipe "docker"
25 passwords = data_bag_item("community", "passwords")
26 license_keys = data_bag_item("geoipupdate", "license-keys") unless kitchen?
28 prometheus_servers = search(:node, "recipes:prometheus\\:\\:server").map do |server|
29 server.ipaddresses(:role => :external)
32 # Disable any default installed apache2 service. Web server is embedded within the discourse docker container
34 action [:disable, :stop]
37 directory "/srv/community.openstreetmap.org" do
43 directory "/srv/community.openstreetmap.org/shared" do
49 directory "/srv/community.openstreetmap.org/files" do
55 template "/srv/community.openstreetmap.org/files/update-feeds.atom" do
56 source "update-feeds.atom.erb"
62 git "/srv/community.openstreetmap.org/docker" do
64 repository "https://github.com/discourse/discourse_docker.git"
65 # Revision pin not possible as launch wrapper automatically updates git repo.
70 notifies :run, "notify_group[discourse_container_new_data]"
71 notifies :run, "notify_group[discourse_container_new_web_only]"
72 notifies :run, "notify_group[discourse_container_new_mail_receiver]"
75 template "/srv/community.openstreetmap.org/docker/containers/data.yml" do
80 variables :passwords => passwords
81 notifies :run, "notify_group[discourse_container_new_data]"
84 template "/srv/community.openstreetmap.org/docker/containers/web_only.yml" do
85 source "web_only.yml.erb"
89 variables :license_keys => license_keys, :passwords => passwords,
90 :prometheus_servers => prometheus_servers
91 notifies :run, "notify_group[discourse_container_new_web_only]"
94 template "/srv/community.openstreetmap.org/docker/containers/mail-receiver.yml" do
95 source "mail-receiver.yml.erb"
99 variables :passwords => passwords
100 notifies :run, "notify_group[discourse_container_new_mail_receiver]"
103 ssl_certificate "community.openstreetmap.org" do
104 domains ["community.openstreetmap.org", "community.osm.org", "communities.openstreetmap.org", "communities.osm.org", "c.openstreetmap.org", "c.osm.org", "forum.openstreetmap.org", "forum.osm.org"]
105 notifies :run, "notify_group[discourse_container_new_web_only]"
106 notifies :run, "notify_group[discourse_container_new_mail_receiver]"
109 notify_group "discourse_container_new_web_only" do
110 notifies :run, "execute[discourse_container_data_start]", :immediately # noop if site up
111 notifies :run, "execute[discourse_container_web_only_bootstrap]", :immediately # site up but runs in parallel. Slow
112 notifies :run, "execute[discourse_container_web_only_destroy]", :immediately # site down
113 notifies :run, "execute[discourse_container_data_rebuild]", :immediately # site down
114 notifies :run, "execute[discourse_container_web_only_start]", :immediately # site restore
117 notify_group "discourse_container_new_data" do
118 notifies :run, "execute[discourse_container_web_only_destroy]", :immediately # site down
119 notifies :run, "execute[discourse_container_data_rebuild]", :immediately # site down
120 notifies :run, "execute[discourse_container_web_only_start]", :immediately # site restore
123 notify_group "discourse_container_new_mail_receiver" do
124 notifies :run, "execute[discourse_container_mail_receiver_rebuild]", :immediately
127 # Attempt at a failsafe to ensure all containers are running
128 notify_group "discourse_container_ensure_all_running" do
130 notifies :run, "execute[discourse_container_data_start]", :delayed
131 notifies :run, "execute[discourse_container_web_only_start]", :delayed
132 notifies :run, "execute[discourse_container_mail_receiver_start]", :delayed
135 execute "discourse_container_data_start" do
137 command "./launcher start data"
138 cwd "/srv/community.openstreetmap.org/docker/"
143 execute "discourse_container_data_rebuild" do
145 command "./launcher rebuild data"
146 cwd "/srv/community.openstreetmap.org/docker/"
151 execute "discourse_container_web_only_bootstrap" do
153 command "./launcher bootstrap web_only"
154 cwd "/srv/community.openstreetmap.org/docker/"
159 execute "discourse_container_web_only_destroy" do
161 command "./launcher destroy web_only"
162 cwd "/srv/community.openstreetmap.org/docker/"
167 execute "discourse_container_web_only_start" do
169 command "./launcher start web_only"
170 cwd "/srv/community.openstreetmap.org/docker/"
175 # Rebuild: Stop Destroy Bootstap Start
176 execute "discourse_container_mail_receiver_rebuild" do
178 command "./launcher rebuild mail-receiver"
179 cwd "/srv/community.openstreetmap.org/docker/"
184 execute "discourse_container_mail_receiver_start" do
186 command "./launcher start mail-receiver"
187 cwd "/srv/community.openstreetmap.org/docker/"
192 template "/etc/cron.daily/community-backup" do
193 source "backup.cron.erb"
199 node.default[:prometheus][:exporters][443] = {
200 :name => "community",
201 :address => "#{node[:prometheus][:address]}:443",
202 :sni => "community.openstreetmap.org"