X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/4b489e186749ef86b87942c0c5eca32c8632662c..f1fd88c6c91dc9119d630bd48eb02c90ebb41e09:/cookbooks/civicrm/recipes/default.rb diff --git a/cookbooks/civicrm/recipes/default.rb b/cookbooks/civicrm/recipes/default.rb index d7453f888..ed8f51f42 100644 --- a/cookbooks/civicrm/recipes/default.rb +++ b/cookbooks/civicrm/recipes/default.rb @@ -8,7 +8,7 @@ # 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, @@ -20,10 +20,11 @@ include_recipe "wordpress" include_recipe "mysql" +package "wkhtmltopdf" + passwords = data_bag_item("civicrm", "passwords") database_password = passwords["database"] -admin_password = passwords["admin"] site_key = passwords["key"] mysql_user "civicrm@localhost" do @@ -34,37 +35,55 @@ mysql_database "civicrm" do permissions "civicrm@localhost" => :all end -wordpress_site "crm.osmfoundation.org" do - ssl_enabled false +wordpress_site "join.osmfoundation.org" do + aliases "crm.osmfoundation.org" database_name "civicrm" database_user "civicrm" database_password database_password end +wordpress_theme "osmblog-wp-theme" do + site "join.osmfoundation.org" + repository "git://github.com/harry-wood/osmblog-wp-theme.git" +end + +wordpress_plugin "registration-honeypot" do + site "join.osmfoundation.org" +end + +wordpress_plugin "sitepress-multilingual-cms" do + site "join.osmfoundation.org" + repository "https://git.openstreetmap.org/private/sitepress-multilingual-cms.git" +end + +wordpress_plugin "contact-form-7" do + site "join.osmfoundation.org" +end + civicrm_version = node[:civicrm][:version] -civicrm_directory = "/srv/crm.osmfoundation.org/wp-content/plugins/civicrm" +civicrm_directory = "/srv/join.osmfoundation.org/wp-content/plugins/civicrm" directory "/opt/civicrm-#{civicrm_version}" do - owner "root" - group "root" - mode 0755 + owner "wordpress" + group "wordpress" + mode 0o755 end remote_file "/var/cache/chef/civicrm-#{civicrm_version}-wordpress.zip" do action :create_if_missing - source "http://downloads.sourceforge.net/project/civicrm/civicrm-stable/#{civicrm_version}/civicrm-#{civicrm_version}-wordpress.zip" - owner "root" - group "root" - mode 0644 + source "https://download.civicrm.org/civicrm-#{civicrm_version}-wordpress.zip" + owner "wordpress" + group "wordpress" + mode 0o644 backup false end remote_file "/var/cache/chef/civicrm-#{civicrm_version}-l10n.tar.gz" do action :create_if_missing - source "http://downloads.sourceforge.net/project/civicrm/civicrm-stable/#{civicrm_version}/civicrm-#{civicrm_version}-l10n.tar.gz" - owner "root" - group "root" - mode 0644 + source "https://download.civicrm.org/civicrm-#{civicrm_version}-l10n.tar.gz" + owner "wordpress" + group "wordpress" + mode 0o644 backup false end @@ -72,28 +91,51 @@ execute "/var/cache/chef/civicrm-#{civicrm_version}-wordpress.zip" do action :nothing command "unzip -qq /var/cache/chef/civicrm-#{civicrm_version}-wordpress.zip" cwd "/opt/civicrm-#{civicrm_version}" - user "root" - group "root" - subscribes :run, "remote_file[/var/cache/chef/civicrm-#{civicrm_version}-wordpress.zip]" + user "wordpress" + group "wordpress" + subscribes :run, "remote_file[/var/cache/chef/civicrm-#{civicrm_version}-wordpress.zip]", :immediately end execute "/var/cache/chef/civicrm-#{civicrm_version}-l10n.tar.gz" do action :nothing command "tar -zxf /var/cache/chef/civicrm-#{civicrm_version}-l10n.tar.gz" cwd "/opt/civicrm-#{civicrm_version}/civicrm" - user "root" - group "root" - subscribes :run, "remote_file[/var/cache/chef/civicrm-#{civicrm_version}-l10n.tar.gz]" + user "wordpress" + group "wordpress" + subscribes :run, "remote_file[/var/cache/chef/civicrm-#{civicrm_version}-l10n.tar.gz]", :immediately end -link civicrm_directory do - to "/opt/civicrm-#{civicrm_version}/civicrm" +execute "/opt/civicrm-#{civicrm_version}/civicrm" do + action :nothing + command "rsync --archive --delete /opt/civicrm-#{civicrm_version}/civicrm/ #{civicrm_directory}" + user "wordpress" + group "wordpress" + subscribes :run, "execute[/var/cache/chef/civicrm-#{civicrm_version}-wordpress.zip]", :immediately + subscribes :run, "execute[/var/cache/chef/civicrm-#{civicrm_version}-l10n.tar.gz]", :immediately end -directory "/srv/crm.osmfoundation.org/wp-content/plugins/files" do +directory "/srv/join.osmfoundation.org/wp-content/plugins/files" do owner "www-data" group "www-data" - mode 0755 + mode 0o755 +end + +extensions_directory = "/srv/join.osmfoundation.org/wp-content/plugins/civicrm-extensions" + +directory extensions_directory do + owner "wordpress" + group "wordpress" + mode 0o755 +end + +node[:civicrm][:extensions].each_value do |details| + git "#{extensions_directory}/#{details[:name]}" do + action :sync + repository details[:repository] + revision details[:revision] + user "wordpress" + group "wordpress" + end end settings = edit_file "#{civicrm_directory}/civicrm/templates/CRM/common/civicrm.settings.php.template" do |line| @@ -106,25 +148,35 @@ settings = edit_file "#{civicrm_directory}/civicrm/templates/CRM/common/civicrm. line.gsub!(/%%dbPass%%/, database_password) line.gsub!(/%%dbHost%%/, "localhost") line.gsub!(/%%dbName%%/, "civicrm") - line.gsub!(/%%crmRoot%%/, "#{civicrm_directory}/civicrm") - line.gsub!(/%%templateCompileDir%%/, "/srv/crm.osmfoundation.org/wp-content/plugins/files/civicrm/templates_c") - line.gsub!(/%%baseURL%%/, "http://crm.osmfoundation.org/") + line.gsub!(/%%crmRoot%%/, "#{civicrm_directory}/civicrm/") + line.gsub!(/%%templateCompileDir%%/, "/srv/join.osmfoundation.org/wp-content/plugins/files/civicrm/templates_c/") + line.gsub!(/%%baseURL%%/, "http://join.osmfoundation.org/") line.gsub!(/%%siteKey%%/, site_key) + line.gsub!(%r{// *(.*'ext_repo_url'.*)$}, "\\1") + line.gsub!(%r{// *define\('CIVICRM_CMSDIR', '/path/to/install/root/'\);}, "define('CIVICRM_CMSDIR', '/srv/join.osmfoundation.org');") line end -file "#{civicrm_directory}/civicrm/civicrm.settings.php" do +file "#{civicrm_directory}/civicrm.settings.php" do + owner "wordpress" + group "wordpress" + mode 0o644 + content settings +end + +template "/etc/cron.d/osmf-crm" do + source "cron.erb" owner "root" group "root" - mode 0644 - content settings + mode 0o600 + variables :directory => civicrm_directory, :passwords => passwords end template "/etc/cron.daily/osmf-crm-backup" do source "backup.cron.erb" owner "root" group "root" - mode 0750 + mode 0o750 variables :passwords => passwords end