X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/a68415b8f2bf106b6ea5948b0605c897b516ef4f..699e157e3d708f38064eea9072aa210fe5ccac30:/cookbooks/forum/recipes/default.rb diff --git a/cookbooks/forum/recipes/default.rb b/cookbooks/forum/recipes/default.rb index d21fd2534..ae32e4d01 100644 --- a/cookbooks/forum/recipes/default.rb +++ b/cookbooks/forum/recipes/default.rb @@ -1,14 +1,14 @@ # -# Cookbook Name:: forum +# Cookbook:: forum # Recipe:: default # -# Copyright 2014, OpenStreetMap Foundation +# Copyright:: 2014, OpenStreetMap Foundation # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # -# http://www.apache.org/licenses/LICENSE-2.0 +# https://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, @@ -16,21 +16,36 @@ # See the License for the specific language governing permissions and # limitations under the License. # -include_recipe "apache::ssl" + +include_recipe "accounts" +include_recipe "apache" include_recipe "git" include_recipe "mysql" +include_recipe "php::fpm" + +cache_dir = Chef::Config[:file_cache_path] passwords = data_bag_item("forum", "passwords") -package "php" -package "php-cli" -package "php-mysql" -package "php-apcu" +package %w[ + php-cli + php-mysql + php-xml + php-apcu +] -apache_module "php7.0" +apache_module "env" +apache_module "rewrite" -apache_site "default" do - action [:disable] +ssl_certificate "forum.openstreetmap.org" do + domains ["forum.openstreetmap.org", "forum.osm.org"] + notifies :reload, "service[apache2]" +end + +php_fpm "forum.openstreetmap.org" do + php_admin_values "open_basedir" => "/srv/forum.openstreetmap.org/html/:/usr/share/php/:/tmp/", + "disable_functions" => "exec,shell_exec,system,passthru,popen,proc_open" + prometheus_port 9253 end apache_site "forum.openstreetmap.org" do @@ -40,28 +55,56 @@ end directory "/srv/forum.openstreetmap.org" do owner "forum" group "forum" - mode 0o755 + mode "755" end git "/srv/forum.openstreetmap.org/html/" do action :sync - repository "http://github.com/fluxbb/fluxbb.git" - revision "refs/tags/fluxbb-1.5.6" + repository "http://github.com/openstreetmap/openstreetmap-forum.git" + revision "openstreetmap-1.5.10" depth 1 user "forum" group "forum" + notifies :reload, "service[apache2]" +end + +remote_file "#{cache_dir}/air3_v0.8.tar.gz" do + action :create_if_missing + source "https://github.com/natrius/air3/archive/refs/tags/v0.8.tar.gz" + owner "root" + group "root" + mode "644" + backup false +end + +archive_file "#{cache_dir}/air3_v0.8.tar.gz" do + action :nothing + destination "/srv/forum.openstreetmap.org/html/style" + strip_components 1 + overwrite true + owner "forum" + group "forum" + subscribes :extract, "remote_file[#{cache_dir}/air3_v0.8.tar.gz]", :immediately end directory "/srv/forum.openstreetmap.org/html/cache/" do owner "www-data" group "www-data" - mode 0o755 + mode "755" end directory "/srv/forum.openstreetmap.org/html/img/avatars/" do owner "www-data" group "www-data" - mode 0o755 + mode "755" +end + +template "/srv/forum.openstreetmap.org/html/config.php" do + source "config.php.erb" + owner "forum" + group "www-data" + mode "440" + variables :passwords => passwords end mysql_user "forum@localhost" do @@ -76,6 +119,6 @@ template "/etc/cron.daily/forum-backup" do source "backup.cron.erb" owner "root" group "root" - mode 0o750 + mode "750" variables :passwords => passwords end