]> git.openstreetmap.org Git - chef.git/blob - cookbooks/dev/recipes/default.rb
Revert "Allow dev users to sudo cat their apache logs"
[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 "nodejs"
28 include_recipe "postgresql"
29
30 package "php-apc"
31 package "php-db"
32 package "php-cgiwrap"
33 package "php-pear"
34
35 package "php5-cgi"
36 package "php5-cli"
37 package "php5-curl"
38 package "php5-fpm"
39 package "php5-imagick"
40 package "php5-mcrypt"
41 package "php5-mysql"
42 package "php5-pgsql"
43 package "php5-sqlite"
44
45 package "pngcrush"
46 package "pngquant"
47
48 package "python"
49 package "python-argparse"
50 package "python-beautifulsoup"
51 package "python-cheetah"
52 package "python-dateutil"
53 package "python-magic"
54 package "python-psycopg2"
55 package "python-gdal"
56
57 nodejs_package "svgo"
58
59 easy_install_package "geojson"
60
61 apache_module "env"
62 apache_module "expires"
63 apache_module "proxy"
64 apache_module "proxy_fcgi"
65 apache_module "rewrite"
66 apache_module "wsgi"
67 apache_module "headers"
68
69 gem_package "sqlite3"
70
71 gem_package "rails" do
72   version "3.0.9"
73 end
74
75 service "php5-fpm" do
76   provider Chef::Provider::Service::Upstart
77   action [:enable, :start]
78   supports :status => true, :restart => true, :reload => true
79 end
80
81 template "/etc/php5/fpm/pool.d/default.conf" do
82   source "fpm-default.conf.erb"
83   owner "root"
84   group "root"
85   mode 0644
86   notifies :reload, "service[php5-fpm]"
87 end
88
89 file "/etc/php5/fpm/pool.d/www.conf" do
90   action :delete
91   notifies :reload, "service[php5-fpm]"
92 end
93
94 package "phppgadmin"
95
96 template "/etc/phppgadmin/config.inc.php" do
97   source "phppgadmin.conf.erb"
98   owner "root"
99   group "root"
100   mode 0644
101 end
102
103 file "/etc/apache2/conf.d/phppgadmin" do
104   action :delete
105 end
106
107 apache_site "phppgadmin.dev.openstreetmap.org" do
108   template "apache.phppgadmin.erb"
109 end
110
111 search(:accounts, "*:*").each do |account|
112   name = account["id"]
113   details = node[:accounts][:users][name] || {}
114
115   next unless %w(user administrator).include?(details[:status])
116
117   user_home = details[:home] || account["home"] || "#{node[:accounts][:home]}/#{name}"
118
119   next unless File.directory?("#{user_home}/public_html")
120
121   port = 7000 + account["uid"].to_i
122
123   template "/etc/php5/fpm/pool.d/#{name}.conf" do
124     source "fpm.conf.erb"
125     owner "root"
126     group "root"
127     mode 0644
128     variables :user => name, :port => port
129     notifies :reload, "service[php5-fpm]"
130   end
131
132   apache_site "#{name}.dev.openstreetmap.org" do
133     template "apache.user.erb"
134     directory "#{user_home}/public_html"
135     variables :user => name, :port => port
136   end
137 end
138
139 if node[:postgresql][:clusters][:"9.3/main"]
140   postgresql_user "apis" do
141     cluster "9.3/main"
142   end
143
144   template "/usr/local/bin/cleanup-rails-assets" do
145     cookbook "web"
146     source "cleanup-assets.erb"
147     owner "root"
148     group "root"
149     mode 0755
150   end
151
152   node[:dev][:rails].each do |name, details|
153     database_name = details[:database] || "apis_#{name}"
154     site_name = "#{name}.apis.dev.openstreetmap.org"
155     rails_directory = "/srv/#{name}.apis.dev.openstreetmap.org"
156
157     if details[:repository]
158       site_aliases = details[:aliases] || []
159       secret_key_base = details[:secret_key_base] || SecureRandom.base64(96)
160
161       node.normal[:dev][:rails][name][:secret_key_base] = secret_key_base
162
163       postgresql_database database_name do
164         cluster "9.3/main"
165         owner "apis"
166       end
167
168       postgresql_extension "#{database_name}_btree_gist" do
169         cluster "9.3/main"
170         database database_name
171         extension "btree_gist"
172       end
173
174       rails_port site_name do
175         ruby node[:passenger][:ruby_version]
176         directory rails_directory
177         user "apis"
178         group "apis"
179         repository details[:repository]
180         revision details[:revision]
181         database_port node[:postgresql][:clusters][:"9.3/main"][:port]
182         database_name database_name
183         database_username "apis"
184         run_migrations true
185       end
186
187       template "#{rails_directory}/config/initializers/setup.rb" do
188         source "rails.setup.rb.erb"
189         owner "apis"
190         group "apis"
191         mode 0644
192         variables :site => site_name
193         notifies :run, "execute[#{rails_directory}]"
194       end
195
196       apache_site site_name do
197         template "apache.rails.erb"
198         variables :name => site_name, :aliases => site_aliases, :secret_key_base => secret_key_base
199       end
200     else
201       apache_site site_name do
202         action [:delete]
203       end
204
205       directory rails_directory do
206         action :delete
207         recursive true
208       end
209
210       file "/etc/cron.daily/rails-#{site_name.tr('.', '-')}" do
211         action :delete
212       end
213
214       postgresql_database database_name do
215         action :drop
216         cluster "9.3/main"
217       end
218
219       node.normal[:dev][:rails].delete(name)
220     end
221   end
222
223   directory "/srv/apis.dev.openstreetmap.org" do
224     owner "apis"
225     group "apis"
226     mode 0755
227   end
228
229   template "/srv/apis.dev.openstreetmap.org/index.html" do
230     source "apis.html.erb"
231     owner "apis"
232     group "apis"
233     mode 0644
234   end
235
236   apache_site "apis.dev.openstreetmap.org" do
237     template "apache.apis.erb"
238   end
239
240   node[:postgresql][:clusters].each_key do |name|
241     postgresql_munin name do
242       cluster name
243       database "ALL"
244     end
245   end
246 end