]> git.openstreetmap.org Git - chef.git/blob - cookbooks/piwik/recipes/default.rb
removing non-functional web page from allowed external images
[chef.git] / cookbooks / piwik / recipes / default.rb
1 #
2 # Cookbook Name:: piwik
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 #     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 "apache"
21 include_recipe "mysql"
22
23 passwords = data_bag_item("piwik", "passwords")
24
25 package "php"
26 package "php-cli"
27 package "php-curl"
28 package "php-mbstring"
29 package "php-mysql"
30 package "php-gd"
31 package "php-xml"
32 package "php-apcu"
33
34 package "geoipupdate"
35
36 apache_module "php7.2"
37
38 version = node[:piwik][:version]
39
40 directory "/opt/piwik-#{version}" do
41   owner "root"
42   group "root"
43   mode "0755"
44 end
45
46 remote_file "#{Chef::Config[:file_cache_path]}/piwik-#{version}.zip" do
47   source "https://builds.matomo.org/piwik-#{version}.zip"
48   not_if { File.exist?("/opt/piwik-#{version}/piwik") }
49 end
50
51 execute "unzip-piwik-#{version}" do
52   command "unzip -q #{Chef::Config[:file_cache_path]}/piwik-#{version}.zip"
53   cwd "/opt/piwik-#{version}"
54   user "root"
55   group "root"
56   not_if { File.exist?("/opt/piwik-#{version}/piwik") }
57 end
58
59 directory "/opt/piwik-#{version}/piwik/config" do
60   owner "www-data"
61   group "www-data"
62   mode "0755"
63 end
64
65 template "/opt/piwik-#{version}/piwik/config/config.ini.php" do
66   source "config.erb"
67   owner "root"
68   group "root"
69   mode "0644"
70   variables :passwords => passwords,
71             :directory => "/opt/piwik-#{version}/piwik",
72             :plugins => node[:piwik][:plugins]
73 end
74
75 directory "/opt/piwik-#{version}/piwik/tmp" do
76   owner "www-data"
77   group "www-data"
78   mode "0755"
79 end
80
81 link "/opt/piwik-#{version}/piwik/misc/GeoLite2-ASN.mmdb" do
82   to "/var/lib/GeoIP/GeoLite2-ASN.mmdb"
83 end
84
85 link "/opt/piwik-#{version}/piwik/misc/GeoLite2-City.mmdb" do
86   to "/var/lib/GeoIP/GeoLite2-City.mmdb"
87 end
88
89 link "/opt/piwik-#{version}/piwik/misc/GeoLite2-Country.mmdb" do
90   to "/var/lib/GeoIP/GeoLite2-Country.mmdb"
91 end
92
93 link "/srv/piwik.openstreetmap.org" do
94   to "/opt/piwik-#{version}/piwik"
95   notifies :restart, "service[apache2]"
96 end
97
98 mysql_user "piwik@localhost" do
99   password passwords["database"]
100 end
101
102 mysql_database "piwik" do
103   permissions "piwik@localhost" => :all
104 end
105
106 ssl_certificate "piwik.openstreetmap.org" do
107   domains ["piwik.openstreetmap.org", "piwik.osm.org"]
108   notifies :reload, "service[apache2]"
109 end
110
111 apache_site "piwik.openstreetmap.org" do
112   template "apache.erb"
113 end
114
115 template "/etc/cron.d/piwiki" do
116   source "cron.erb"
117   owner "root"
118   group "root"
119   mode "0644"
120 end