From: Tom Hughes Date: Sun, 23 Mar 2014 22:13:00 +0000 (+0000) Subject: Rework civicrm using wordpress instead of drupal X-Git-Url: https://git.openstreetmap.org/chef.git/commitdiff_plain/793d8c6dbd1ca8d7cf74072bf0fd8b796ac50038 Rework civicrm using wordpress instead of drupal --- diff --git a/cookbooks/civicrm/attributes/default.rb b/cookbooks/civicrm/attributes/default.rb index 8fefdfcd7..55ca5003e 100644 --- a/cookbooks/civicrm/attributes/default.rb +++ b/cookbooks/civicrm/attributes/default.rb @@ -1 +1 @@ -default[:civicrm][:version] = "4.2.7" +default[:civicrm][:version] = "4.4.4" diff --git a/cookbooks/civicrm/metadata.rb b/cookbooks/civicrm/metadata.rb index 4c991bc9f..ad57baf1e 100644 --- a/cookbooks/civicrm/metadata.rb +++ b/cookbooks/civicrm/metadata.rb @@ -5,5 +5,5 @@ license "Apache 2.0" description "Installs and configures CiviCRM" long_description IO.read(File.join(File.dirname(__FILE__), 'README.md')) version "1.0.0" -depends "drupal" +depends "wordpress" depends "mysql" diff --git a/cookbooks/civicrm/recipes/default.rb b/cookbooks/civicrm/recipes/default.rb index 58cea555e..93cb3d9ed 100644 --- a/cookbooks/civicrm/recipes/default.rb +++ b/cookbooks/civicrm/recipes/default.rb @@ -17,7 +17,7 @@ # limitations under the License. # -include_recipe "drupal" +include_recipe "wordpress" include_recipe "mysql" passwords = data_bag_item("civicrm", "passwords") @@ -34,127 +34,91 @@ mysql_database "civicrm" do permissions "civicrm@localhost" => :all end -drupal_site "crm.osmfoundation.org" do - title "CiviCRM" +wordpress_site "crm.osmfoundation.org" do + ssl_enabled true database_name "civicrm" - database_username "civicrm" + database_user "civicrm" database_password database_password - admin_password admin_password -end - -directory "/usr/local/share/civicrm" do - owner "root" - group "root" - mode "0755" end civicrm_version = node[:civicrm][:version] -civicrm_directory = "/usr/local/share/civicrm/#{civicrm_version}" +civicrm_directory = "/srv/crm.osmfoundation.org/wp-content/plugins/civicrm" -subversion civicrm_directory do - action :export - repository "http://svn.civicrm.org/civicrm/tags/tarballs/#{node[:civicrm][:version]}" - user "root" +directory "/opt/civicrm-#{civicrm_version}" do + owner "root" group "root" + mode 0755 end -link "/usr/share/drupal7/sites/all/modules/civicrm" do - to "/usr/local/share/civicrm/#{node[:civicrm][:version]}" -end - -directory "/data/crm.osmfoundation.org/civicrm" do - owner "www-data" - group "www-data" - mode "0775" -end - -ruby_block "#{civicrm_directory}/civicrm.settings.php" do - block do - out = File.new("#{civicrm_directory}/civicrm.settings.php", "w") - - File.foreach("#{civicrm_directory}/templates/CRM/common/civicrm.settings.php.tpl") do |line| - line.gsub!(/%%cms%%/, "Drupal") - line.gsub!(/%%CMSdbUser%%/, "civicrm") - line.gsub!(/%%CMSdbPass%%/, database_password) - line.gsub!(/%%CMSdbHost%%/, "localhost") - line.gsub!(/%%CMSdbName%%/, "civicrm") - line.gsub!(/%%dbUser%%/, "civicrm") - line.gsub!(/%%dbPass%%/, database_password) - line.gsub!(/%%dbHost%%/, "localhost") - line.gsub!(/%%dbName%%/, "civicrm") - line.gsub!(/%%crmRoot%%/, "/usr/share/drupal7/sites/all/modules/civicrm") - line.gsub!(/%%templateCompileDir%%/, "/data/crm.osmfoundation.org/civicrm") - line.gsub!(/%%baseURL%%/, "http://crm.osmfoundation.org/") - line.gsub!(/%%siteKey%%/, site_key) - - out.print(line) - end - - out.close - end - - not_if do - File.exist?("#{civicrm_directory}/civicrm.settings.php") and - File.mtime("#{civicrm_directory}/civicrm.settings.php") >= File.mtime("#{civicrm_directory}/templates/CRM/common/civicrm.settings.php.tpl") - end -end - -link "/etc/drupal/7/sites/crm.osmfoundation.org/civicrm.settings.php" do - to "#{civicrm_directory}/civicrm.settings.php" -end - -template "#{civicrm_directory}/settings_location.php" do - source "settings_location.php.erb" +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" + mode 0644 + backup false end -execute "civicrm-load-acl" do - action :nothing - command "mysql --user=civicrm --password=#{database_password} civicrm < sql/civicrm_acl.mysql" - cwd "/usr/share/drupal7/sites/all/modules/civicrm" - user "root" +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 + backup false end -execute "civicrm-load-data" do +execute "/var/cache/chef/civicrm-#{civicrm_version}-wordpress.zip" do action :nothing - command "mysql --user=civicrm --password=#{database_password} civicrm < sql/civicrm_data.mysql" - cwd "/usr/share/drupal7/sites/all/modules/civicrm" + command "unzip -qq /var/cache/chef/civicrm-#{civicrm_version}-wordpress.zip" + cwd "/opt/civicrm-#{civicrm_version}" user "root" group "root" - notifies :run, "execute[civicrm-load-acl]" + subscribes :run, "remote_file[/var/cache/chef/civicrm-#{civicrm_version}-wordpress.zip]" end -execute "civicrm-load" do +execute "/var/cache/chef/civicrm-#{civicrm_version}-l10n.tar.gz" do action :nothing - command "mysql --user=civicrm --password=#{database_password} civicrm < sql/civicrm.mysql" - cwd "/usr/share/drupal7/sites/all/modules/civicrm" + command "tar -zxf /var/cache/chef/civicrm-#{civicrm_version}-l10n.tar.gz" + cwd "/opt/civicrm-#{civicrm_version}/civicrm" user "root" group "root" - notifies :run, "execute[civicrm-load-data]" + subscribes :run, "remote_file[/var/cache/chef/civicrm-#{civicrm_version}-l10n.tar.gz]" end -execute "civicrm-gencode" do - command "php GenCode.php" - cwd "#{civicrm_directory}/xml" - user "root" - group "root" - creates "#{civicrm_directory}/civicrm-version.php" - notifies :run, "execute[civicrm-load]" +link civicrm_directory do + to "/opt/civicrm-#{civicrm_version}/civicrm" end -directory "/data/crm.osmfoundation.org/civicrm/en_US" do +directory "/srv/crm.osmfoundation.org/wp-content/plugins/files" do owner "www-data" group "www-data" - mode "0775" + mode 0755 end -directory "/data/crm.osmfoundation.org/civicrm/en_US/ConfigAndLog" do - owner "www-data" - group "www-data" - mode "0775" +settings = edit_file "#{civicrm_directory}/civicrm/templates/CRM/common/civicrm.settings.php.template" do |line| + line.gsub!(/%%cms%%/, "WordPress") + line.gsub!(/%%CMSdbUser%%/, "civicrm") + line.gsub!(/%%CMSdbPass%%/, database_password) + line.gsub!(/%%CMSdbHost%%/, "localhost") + line.gsub!(/%%CMSdbName%%/, "civicrm") + line.gsub!(/%%dbUser%%/, "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!(/%%siteKey%%/, site_key) + + line +end + +file "#{civicrm_directory}/civicrm/civicrm.settings.php" do + owner "root" + group "root" + mode 0644 + content settings end template "/etc/cron.daily/osmf-crm-backup" do diff --git a/cookbooks/civicrm/templates/default/backup.cron.erb b/cookbooks/civicrm/templates/default/backup.cron.erb index 4a5469ed4..83421ff0f 100644 --- a/cookbooks/civicrm/templates/default/backup.cron.erb +++ b/cookbooks/civicrm/templates/default/backup.cron.erb @@ -8,7 +8,7 @@ B=osmf-crm-$D.tar.gz mkdir $T/osmf-crm-$D mysqldump --user=civicrm --password=<%= @passwords["database"] %> --opt --skip-lock-tables civicrm > $T/osmf-crm-$D/civicrm.sql -ln -s /data/crm.osmfoundation.org $T/osmf-crm-$D/www +ln -s /srv/crm.osmfoundation.org $T/osmf-crm-$D/www export GZIP="--rsyncable -9" export RSYNC_RSH="ssh -ax -c arcfour" diff --git a/cookbooks/civicrm/templates/default/settings_location.php.erb b/cookbooks/civicrm/templates/default/settings_location.php.erb deleted file mode 100644 index 3e0249dc4..000000000 --- a/cookbooks/civicrm/templates/default/settings_location.php.erb +++ /dev/null @@ -1,10 +0,0 @@ - diff --git a/roles/foundation.rb b/roles/foundation.rb index 8e763bfce..b6a324772 100644 --- a/roles/foundation.rb +++ b/roles/foundation.rb @@ -8,7 +8,7 @@ default_attributes( :keepalive => false }, :apt => { - :sources => [ "brightbox", "aw-drupal" ] + :sources => [ "brightbox" ] }, :memcached => { :memory_limit => 400,