]> git.openstreetmap.org Git - chef.git/blob - cookbooks/serverinfo/recipes/default.rb
serverinfo: mark node data as sensitive to limit logging
[chef.git] / cookbooks / serverinfo / recipes / default.rb
1 #
2 # Cookbook:: serverinfo
3 # Recipe:: default
4 #
5 # Copyright:: 2015, 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 #     https://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 include_recipe "accounts"
21 include_recipe "apache"
22 include_recipe "git"
23 include_recipe "ruby"
24
25 package %w[
26   gcc
27   g++
28   make
29   libssl-dev
30   zlib1g-dev
31   pkg-config
32 ]
33
34 directory "/srv/hardware.openstreetmap.org" do
35   owner "serverinfo"
36   group "serverinfo"
37   mode "755"
38 end
39
40 git "/srv/hardware.openstreetmap.org" do
41   action :sync
42   repository "https://github.com/osmfoundation/osmf-server-info.git"
43   depth 1
44   user "serverinfo"
45   group "serverinfo"
46   notifies :run, "bundle_install[/srv/hardware.openstreetmap.org]"
47 end
48
49 nodes = { :rows => search(:node, "*:*") }
50 roles = { :rows => search(:role, "*:*") }
51
52 file "/srv/hardware.openstreetmap.org/_data/nodes.json" do
53   content nodes.to_json
54   mode "644"
55   owner "serverinfo"
56   group "serverinfo"
57   notifies :run, "bundle_exec[/srv/hardware.openstreetmap.org]"
58   sensitive true
59 end
60
61 file "/srv/hardware.openstreetmap.org/_data/roles.json" do
62   content roles.to_json
63   mode "644"
64   owner "serverinfo"
65   group "serverinfo"
66   notifies :run, "bundle_exec[/srv/hardware.openstreetmap.org]"
67 end
68
69 bundle_config "/srv/hardware.openstreetmap.org" do
70   action :create
71   user "serverinfo"
72   group "serverinfo"
73   settings "deployment" => "true",
74            "without" => "development:test",
75            "jobs" => node.cpu_cores.to_s
76   notifies :run, "bundle_exec[/srv/hardware.openstreetmap.org]"
77 end
78
79 bundle_install "/srv/hardware.openstreetmap.org" do
80   action :nothing
81   user "serverinfo"
82   group "serverinfo"
83   notifies :run, "bundle_exec[/srv/hardware.openstreetmap.org]"
84 end
85
86 bundle_exec "/srv/hardware.openstreetmap.org" do
87   action :nothing
88   command "jekyll build --trace --disable-disk-cache --baseurl=https://hardware.openstreetmap.org"
89   user "serverinfo"
90   group "serverinfo"
91   environment "LANG" => "C.UTF-8"
92 end
93
94 ssl_certificate "hardware.openstreetmap.org" do
95   domains ["hardware.openstreetmap.org", "hardware.osm.org", "hardware.osmfoundation.org"]
96   notifies :reload, "service[apache2]"
97 end
98
99 apache_site "hardware.openstreetmap.org" do
100   template "apache.erb"
101   directory "/srv/hardware.openstreetmap.org/_site"
102   variables :aliases => ["hardware.osm.org", "hardware.osmfoundation.org"]
103 end