Set server_protocol to https for all rails port instances
[chef.git] / cookbooks / web / definitions / rails_port.rb
1 #
2 # Cookbook Name:: web
3 # Definition:: rails_port
4 #
5 # Copyright 2012, OpenStreetMap Foundation
6 #
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
10 #
11 #     http://www.apache.org/licenses/LICENSE-2.0
12 #
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.
18 #
19
20 require "yaml"
21
22 define :rails_port, :action => [:create, :enable] do
23   name = params[:name]
24   ruby_version = params[:ruby] || "1.9.1"
25   rails_directory = params[:directory] || "/srv/#{name}"
26   rails_user = params[:user]
27   rails_group = params[:group]
28   rails_repository = params[:repository] || "git://git.openstreetmap.org/rails.git"
29   rails_revision = params[:revision] || "live"
30   run_migrations = params[:run_migrations] || false
31   status = params[:status] || "online"
32
33   database_params = {
34     :host => params[:database_host],
35     :port => params[:database_port],
36     :name => params[:database_name],
37     :username => params[:database_username],
38     :password => params[:database_password]
39   }
40
41   package "ruby#{ruby_version}"
42   package "ruby#{ruby_version}-dev"
43   package "rubygems#{ruby_version}" if ruby_version.to_f < 1.9
44   package "irb#{ruby_version}" if ruby_version.to_f < 1.9
45   package "imagemagick"
46   package "nodejs"
47   package "geoip-database"
48
49   package "g++"
50   package "pkg-config"
51   package "libpq-dev"
52   package "libsasl2-dev"
53   package "libxml2-dev"
54   package "libxslt1-dev"
55   package "libmemcached-dev"
56
57   gem_package "bundler#{ruby_version}" do
58     package_name "bundler"
59     version "1.3.5"
60     gem_binary "gem#{ruby_version}"
61     options "--format-executable"
62   end
63
64   file "/usr/lib/ruby/1.8/rack.rb" do
65     action :delete
66   end
67
68   directory "/usr/lib/ruby/1.8/rack" do
69     action :delete
70     recursive true
71   end
72
73   directory rails_directory do
74     owner rails_user
75     group rails_group
76     mode 0o2775
77   end
78
79   git rails_directory do
80     action :sync
81     repository rails_repository
82     revision rails_revision
83     user rails_user
84     group rails_group
85     notifies :run, "execute[#{rails_directory}/Gemfile]"
86     notifies :run, "execute[#{rails_directory}/public/assets]"
87     notifies :delete, "file[#{rails_directory}/public/export/embed.html]"
88     notifies :run, "execute[#{rails_directory}]"
89   end
90
91   directory "#{rails_directory}/tmp" do
92     owner rails_user
93     group rails_group
94   end
95
96   file "#{rails_directory}/config/environment.rb" do
97     owner rails_user
98     group rails_group
99   end
100
101   template "#{rails_directory}/config/database.yml" do
102     cookbook "web"
103     source "database.yml.erb"
104     owner rails_user
105     group rails_group
106     mode 0o664
107     variables database_params
108     notifies :run, "execute[#{rails_directory}]"
109   end
110
111   application_yml = edit_file "#{rails_directory}/config/example.application.yml" do |line|
112     line.gsub!(/^( *)#server_protocol:.*$/, "\\1server_protocol: \"https\"")
113     line.gsub!(/^( *)#server_url:.*$/, "\\1server_url: \"#{name}\"")
114
115     if params[:email_from]
116       line.gsub!(/^( *)email_from:.*$/, "\\1email_from: \"#{params[:email_from]}\"")
117     end
118
119     line.gsub!(/^( *)status:.*$/, "\\1status: :#{status}")
120
121     if params[:messages_domain]
122       line.gsub!(/^( *)#messages_domain:.*$/, "\\1messages_domain: \"#{params[:messages_domain]}\"")
123     end
124
125     line.gsub!(/^( *)#geonames_username:.*$/, "\\1geonames_username: \"openstreetmap\"")
126
127     line.gsub!(/^( *)#geoip_database:.*$/, "\\1geoip_database: \"/usr/share/GeoIP/GeoIPv6.dat\"")
128
129     if params[:gpx_dir]
130       line.gsub!(/^( *)gpx_trace_dir:.*$/, "\\1gpx_trace_dir: \"#{params[:gpx_dir]}/traces\"")
131       line.gsub!(/^( *)gpx_image_dir:.*$/, "\\1gpx_image_dir: \"#{params[:gpx_dir]}/images\"")
132     end
133
134     if params[:attachments_dir]
135       line.gsub!(/^( *)attachments_dir:.*$/, "\\1attachments_dir: \"#{params[:attachments_dir]}\"")
136     end
137
138     if params[:log_path]
139       line.gsub!(/^( *)#log_path:.*$/, "\\1log_path: \"#{params[:log_path]}\"")
140     end
141
142     if params[:logstash_path]
143       line.gsub!(/^( *)#logstash_path:.*$/, "\\1logstash_path: \"#{params[:logstash_path]}\"")
144     end
145
146     if params[:memcache_servers]
147       line.gsub!(/^( *)#memcache_servers:.*$/, "\\1memcache_servers: [ \"#{params[:memcache_servers].join('", "')}\" ]")
148     end
149
150     if params[:potlatch2_key]
151       line.gsub!(/^( *)#potlatch2_key:.*$/, "\\1potlatch2_key: \"#{params[:potlatch2_key]}\"")
152     end
153
154     if params[:id_key]
155       line.gsub!(/^( *)#id_key:.*$/, "\\1id_key: \"#{params[:id_key]}\"")
156     end
157
158     if params[:oauth_key]
159       line.gsub!(/^( *)#oauth_key:.*$/, "\\1oauth_key: \"#{params[:oauth_key]}\"")
160     end
161
162     if params[:nominatim_url]
163       line.gsub!(/^( *)nominatim_url:.*$/, "\\1nominatim_url: \"#{params[:nominatim_url]}\"")
164     end
165
166     if params[:osrm_url]
167       line.gsub!(/^( *)osrm_url:.*$/, "\\1osrm_url: \"#{params[:osrm_url]}\"")
168     end
169
170     if params[:google_auth_id]
171       line.gsub!(/^( *)#google_auth_id:.*$/, "\\1google_auth_id: \"#{params[:google_auth_id]}\"")
172       line.gsub!(/^( *)#google_auth_secret:.*$/, "\\1google_auth_secret: \"#{params[:google_auth_secret]}\"")
173       line.gsub!(/^( *)#google_openid_realm:.*$/, "\\1google_openid_realm: \"#{params[:google_openid_realm]}\"")
174     end
175
176     if params[:facebook_auth_id]
177       line.gsub!(/^( *)#facebook_auth_id:.*$/, "\\1facebook_auth_id: \"#{params[:facebook_auth_id]}\"")
178       line.gsub!(/^( *)#facebook_auth_secret:.*$/, "\\1facebook_auth_secret: \"#{params[:facebook_auth_secret]}\"")
179     end
180
181     if params[:windowslive_auth_id]
182       line.gsub!(/^( *)#windowslive_auth_id:.*$/, "\\1windowslive_auth_id: \"#{params[:windowslive_auth_id]}\"")
183       line.gsub!(/^( *)#windowslive_auth_secret:.*$/, "\\1windowslive_auth_secret: \"#{params[:windowslive_auth_secret]}\"")
184     end
185
186     if params[:github_auth_id]
187       line.gsub!(/^( *)#github_auth_id:.*$/, "\\1github_auth_id: \"#{params[:github_auth_id]}\"")
188       line.gsub!(/^( *)#github_auth_secret:.*$/, "\\1github_auth_secret: \"#{params[:github_auth_secret]}\"")
189     end
190
191     if params[:wikipedia_auth_id]
192       line.gsub!(/^( *)#wikipedia_auth_id:.*$/, "\\1wikipedia_auth_id: \"#{params[:wikipedia_auth_id]}\"")
193       line.gsub!(/^( *)#wikipedia_auth_secret:.*$/, "\\1wikipedia_auth_secret: \"#{params[:wikipedia_auth_secret]}\"")
194     end
195
196     if params[:mapquest_key]
197       line.gsub!(/^( *)#mapquest_key:.*$/, "\\1mapquest_key: \"#{params[:mapquest_key]}\"")
198     end
199
200     if params[:mapzen_valhalla_key]
201       line.gsub!(/^( *)#mapzen_valhalla_key:.*$/, "\\1mapzen_valhalla_key: \"#{params[:mapzen_valhalla_key]}\"")
202     end
203
204     if params[:thunderforest_key]
205       line.gsub!(/^( *)#thunderforest_key:.*$/, "\\1thunderforest_key: \"#{params[:thunderforest_key]}\"")
206     end
207
208     if params[:totp_key]
209       line.gsub!(/^( *)#totp_key:.*$/, "\\1totp_key: \"#{params[:totp_key]}\"")
210     end
211
212     line.gsub!(/^( *)require_terms_seen:.*$/, "\\1require_terms_seen: true")
213     line.gsub!(/^( *)require_terms_agreed:.*$/, "\\1require_terms_agreed: true")
214
215     line
216   end
217
218   file "#{rails_directory}/config/application.yml" do
219     owner rails_user
220     group rails_group
221     mode 0o664
222     content application_yml
223     notifies :run, "execute[#{rails_directory}/public/assets]"
224   end
225
226   if params[:piwik_configuration]
227     file "#{rails_directory}/config/piwik.yml" do
228       owner rails_user
229       group rails_group
230       mode 0o664
231       content YAML.dump(params[:piwik_configuration])
232       notifies :run, "execute[#{rails_directory}/public/assets]"
233     end
234   else
235     file "#{rails_directory}/config/piwik.yml" do
236       action :delete
237       notifies :run, "execute[#{rails_directory}/public/assets]"
238     end
239   end
240
241   execute "#{rails_directory}/Gemfile" do
242     action :nothing
243     command "bundle#{ruby_version} install"
244     cwd rails_directory
245     user "root"
246     group "root"
247     environment "NOKOGIRI_USE_SYSTEM_LIBRARIES" => "yes"
248     subscribes :run, "gem_package[bundler#{ruby_version}]"
249     notifies :run, "execute[#{rails_directory}]"
250   end
251
252   execute "#{rails_directory}/db/migrate" do
253     action :nothing
254     command "bundle#{ruby_version} exec rake db:migrate"
255     cwd rails_directory
256     user rails_user
257     group rails_group
258     subscribes :run, "git[#{rails_directory}]"
259     notifies :run, "execute[#{rails_directory}]"
260     only_if { run_migrations }
261   end
262
263   execute "#{rails_directory}/public/assets" do
264     action :nothing
265     command "bundle#{ruby_version} exec rake assets:precompile"
266     environment "RAILS_ENV" => "production"
267     cwd rails_directory
268     user rails_user
269     group rails_group
270     notifies :run, "execute[#{rails_directory}]"
271   end
272
273   file "#{rails_directory}/public/export/embed.html" do
274     action :nothing
275   end
276
277   execute "#{rails_directory}/lib/quad_tile/extconf.rb" do
278     command "ruby extconf.rb"
279     cwd "#{rails_directory}/lib/quad_tile"
280     user rails_user
281     group rails_group
282     not_if do
283       File.exist?("#{rails_directory}/lib/quad_tile/quad_tile_so.so") &&
284         File.mtime("#{rails_directory}/lib/quad_tile/quad_tile_so.so") >= File.mtime("#{rails_directory}/lib/quad_tile/extconf.rb") &&
285         File.mtime("#{rails_directory}/lib/quad_tile/quad_tile_so.so") >= File.mtime("#{rails_directory}/lib/quad_tile/quad_tile.c") &&
286         File.mtime("#{rails_directory}/lib/quad_tile/quad_tile_so.so") >= File.mtime("#{rails_directory}/lib/quad_tile/quad_tile.h")
287     end
288     notifies :run, "execute[#{rails_directory}/lib/quad_tile/Makefile]"
289   end
290
291   execute "#{rails_directory}/lib/quad_tile/Makefile" do
292     action :nothing
293     command "make"
294     cwd "#{rails_directory}/lib/quad_tile"
295     user rails_user
296     group rails_group
297     notifies :run, "execute[#{rails_directory}]"
298   end
299
300   execute rails_directory do
301     action :nothing
302     command "passenger-config restart-app --ignore-app-not-running #{rails_directory}"
303     user "root"
304     group "root"
305     only_if { File.exist?("/usr/bin/passenger-config") }
306   end
307
308   template "/etc/cron.daily/rails-#{name.tr('.', '-')}" do
309     cookbook "web"
310     source "rails.cron.erb"
311     owner "root"
312     group "root"
313     mode 0o755
314     variables :directory => rails_directory
315   end
316 end