]> git.openstreetmap.org Git - chef.git/blob - cookbooks/chef/recipes/repository.rb
nominatim: reinstate fail2ban on restricted_ips.log
[chef.git] / cookbooks / chef / recipes / repository.rb
1 #
2 # Cookbook Name:: chef
3 # Recipe:: repository
4 #
5 # Copyright 2013, 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 include_recipe "git"
21
22 keys = data_bag_item("chef", "keys")
23
24 directory "/var/lib/chef" do
25   owner "chefrepo"
26   group "chefrepo"
27   mode 0o2775
28 end
29
30 git "/var/lib/chef" do
31   action :checkout
32   repository node[:chef][:repository]
33   revision "master"
34   user "chefrepo"
35   group "chefrepo"
36 end
37
38 directory "/var/lib/chef/.chef" do
39   owner "chefrepo"
40   group "chefrepo"
41   mode 0o2775
42 end
43
44 file "/var/lib/chef/.chef/client.pem" do
45   content keys["git"].join("\n")
46   owner "chefrepo"
47   group "chefrepo"
48   mode 0o660
49 end
50
51 cookbook_file "/var/lib/chef/.chef/knife.rb" do
52   source "knife.rb"
53   owner "chefrepo"
54   group "chefrepo"
55   mode 0o660
56 end
57
58 template "#{node[:chef][:repository]}/hooks/post-receive" do
59   source "post-receive.erb"
60   owner "chefrepo"
61   group "chefrepo"
62   mode 0o750
63 end
64
65 template "/etc/cron.daily/chef-repository-backup" do
66   source "repository-backup.cron.erb"
67   owner "root"
68   group "root"
69   mode 0o755
70 end