]> git.openstreetmap.org Git - chef.git/blob - cookbooks/dev/recipes/default.rb
apache ssl: Do not pass OCSP stapling failures to client
[chef.git] / cookbooks / dev / recipes / default.rb
1 #
2 # Cookbook Name:: dev
3 # Recipe:: default
4 #
5 # Copyright 2011, 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 require "securerandom"
22
23 include_recipe "apache"
24 include_recipe "passenger"
25 include_recipe "git"
26 include_recipe "mysql"
27 include_recipe "postgresql"
28
29 package "php-apc"
30 package "php-db"
31 package "php-cgiwrap"
32 package "php-pear"
33
34 package "php5-cgi"
35 package "php5-cli"
36 package "php5-curl"
37 package "php5-fpm"
38 package "php5-imagick"
39 package "php5-mcrypt"
40 package "php5-mysql"
41 package "php5-pgsql"
42 package "php5-sqlite"
43
44 package "python"
45 package "python-argparse"
46 package "python-beautifulsoup"
47 package "python-cheetah"
48 package "python-dateutil"
49 package "python-magic"
50 package "python-psycopg2"
51
52 easy_install_package "geojson"
53
54 apache_module "env"
55 apache_module "expires"
56 apache_module "fastcgi-handler"
57 apache_module "rewrite"
58 apache_module "wsgi"
59
60 gem_package "sqlite3"
61
62 gem_package "rails" do
63   version "3.0.9"
64 end
65
66 service "php5-fpm" do
67   action [ :enable, :start ]
68   supports :status => true, :restart => true, :reload => true
69 end
70
71 template "/etc/php5/fpm/pool.d/default.conf" do
72   source "fpm-default.conf.erb"
73   owner "root"
74   group "root"
75   mode 0644
76   notifies :reload, "service[php5-fpm]"
77 end
78
79 file "/etc/php5/fpm/pool.d/www.conf" do
80   action :delete
81   notifies :reload, "service[php5-fpm]"
82 end
83
84 package "phppgadmin"
85
86 template "/etc/phppgadmin/config.inc.php" do
87   source "phppgadmin.conf.erb"
88   owner "root"
89   group "root"
90   mode 0644
91 end
92
93 link "/etc/apache2/conf.d/phppgadmin" do
94   action :delete
95 end
96
97 apache_site "phppgadmin.dev.openstreetmap.org" do
98   template "apache.phppgadmin.erb"
99 end
100
101 search(:accounts, "*:*").each do |account|
102   name = account["id"]
103   details = node[:accounts][:users][name] || {}
104
105   if ["user","administrator"].include?(details[:status])
106     user_home = details[:home] || account["home"] || "#{node[:accounts][:home]}/#{name.to_s}"
107
108     if File.directory?("#{user_home}/public_html")
109       template "/etc/php5/fpm/pool.d/#{name}.conf" do
110         source "fpm.conf.erb"
111         owner "root"
112         group "root"
113         mode 0644
114         variables :user => name
115         notifies :reload, "service[php5-fpm]"
116       end
117
118       apache_site "#{name}.dev.openstreetmap.org" do
119         template "apache.user.erb"
120         directory "#{user_home}/public_html"
121         variables :user => name
122       end
123     end
124   end
125 end
126
127 if node[:postgresql][:clusters][:"9.1/main"]
128   postgresql_user "apis" do
129     cluster "9.1/main"
130   end
131
132   node[:dev][:rails].each do |name,details|
133     database_name = details[:database] || "apis_#{name}"
134     site_name = "#{name}.apis.dev.openstreetmap.org"
135     site_aliases = details[:aliases] || []
136     rails_directory = "/srv/#{name}.apis.dev.openstreetmap.org"
137     secret_key_base = details[:secret_key_base] || SecureRandom.base64(96)
138
139     node.set[:dev][:rails][name][:secret_key_base] = secret_key_base
140
141     postgresql_database database_name do
142       cluster "9.1/main"
143       owner "apis"
144     end
145
146     postgresql_extension "#{database_name}_btree_gist" do
147       cluster "9.1/main"
148       database database_name
149       extension "btree_gist"
150     end
151
152     rails_port site_name do
153       ruby node[:passenger][:ruby_version]
154       directory rails_directory
155       user "apis"
156       group "apis"
157       repository details[:repository]
158       revision details[:revision]
159       database_port node[:postgresql][:clusters][:"9.1/main"][:port]
160       database_name database_name
161       database_username "apis"
162       run_migrations true
163     end
164
165     template "#{rails_directory}/config/initializers/setup.rb" do
166       source "rails.setup.rb.erb"
167       owner "apis"
168       group "apis"
169       mode 0644
170       variables :site => site_name
171       notifies :touch, "file[#{rails_directory}/tmp/restart.txt]"
172     end
173
174     apache_site site_name do
175       template "apache.rails.erb"
176       variables :name => site_name, :aliases => site_aliases, :secret_key_base => secret_key_base
177     end
178   end
179
180   Dir.glob("/srv/*.apis.dev.openstreetmap.org").each do |rails_directory|
181     name = File.basename(rails_directory, ".apis.dev.openstreetmap.org")
182
183     unless node[:dev][:rails].include?(name) and node[:dev][:rails][name].include?(:repository)
184       database_config = YAML.load_file("#{rails_directory}/config/database.yml")
185       database_name = database_config["production"]["database"]
186       site_name = "#{name}.apis.dev.openstreetmap.org"
187
188       apache_site site_name do
189         action [ :delete ]
190       end
191
192       directory rails_directory do
193         action :delete
194         recursive true
195       end
196
197       file "/etc/cron.daily/rails-#{name}" do
198         action :delete
199       end
200
201       postgresql_database database_name do
202         action :drop
203         cluster "9.1/main"
204       end
205     end
206   end
207
208   directory "/srv/apis.dev.openstreetmap.org" do
209     owner "apis"
210     group "apis"
211     mode 0755
212   end
213
214   template "/srv/apis.dev.openstreetmap.org/index.html" do
215     source "apis.html.erb"
216     owner "apis"
217     group "apis"
218     mode 0644
219   end
220
221   apache_site "apis.dev.openstreetmap.org" do
222     template "apache.apis.erb"
223   end
224
225   node[:postgresql][:clusters].each do |name,details|
226     postgresql_munin name do
227       cluster name
228       database "ALL"
229     end
230   end
231 end