]> git.openstreetmap.org Git - chef.git/blobdiff - cookbooks/dmca/recipes/default.rb
Improve sandboxing of prometheus collectors
[chef.git] / cookbooks / dmca / recipes / default.rb
index c0bd959a630852b4dfe1f7a6ef38b74e34dc4dd4..eafadd787a7d9ee6ef274341acd64a2b2d41278a 100644 (file)
 #
 
 include_recipe "apache"
-include_recipe "php::apache"
+include_recipe "php::fpm"
 
-directory "/srv/dmca.openstreetmap.org" do
-  owner "root"
-  group "root"
-  mode 0o755
+apache_module "proxy"
+apache_module "proxy_fcgi"
+
+package "composer"
+
+git "/srv/dmca.openstreetmap.org" do
+  action :sync
+  repository "https://github.com/openstreetmap/dmca-website.git"
+  revision "main"
+  depth 1
+  notifies :run, "execute[/srv/dmca.openstreetmap.org/composer.json]", :immediately
 end
 
-remote_directory "/srv/dmca.openstreetmap.org/html" do
-  source "html"
-  owner "root"
-  group "root"
-  mode 0o755
-  files_owner "root"
-  files_group "root"
-  files_mode 0o644
+execute "/srv/dmca.openstreetmap.org/composer.json" do
+  action :nothing
+  command "composer install --no-dev"
+  cwd "/srv/dmca.openstreetmap.org/"
+  environment "COMPOSER_HOME" => "/srv/dmca.openstreetmap.org/"
 end
 
 ssl_certificate "dmca.openstreetmap.org" do
@@ -41,6 +45,12 @@ ssl_certificate "dmca.openstreetmap.org" do
   notifies :reload, "service[apache2]"
 end
 
+php_fpm "dmca.openstreetmap.org" do
+  php_admin_values "open_basedir" => "/srv/dmca.openstreetmap.org/:/usr/share/php/:/tmp/",
+                   "disable_functions" => "exec,shell_exec,system,passthru,popen,proc_open"
+  prometheus_port 11201
+end
+
 apache_site "dmca.openstreetmap.org" do
   template "apache.erb"
   directory "/srv/dmca.openstreetmap.org"