]> git.openstreetmap.org Git - chef.git/blobdiff - cookbooks/wordpress/resources/theme.rb
Merge remote-tracking branch 'github/pull/713'
[chef.git] / cookbooks / wordpress / resources / theme.rb
index 019b9c6122462ebc9e7e7850b7ad7e606ead8a3f..2c4ceda4e5d1947fb048762512818c8b63ae4415 100644 (file)
@@ -1,14 +1,14 @@
 #
 #
-# Cookbook Name:: wordpress
+# Cookbook:: wordpress
 # Resource:: wordpress_theme
 #
 # Resource:: wordpress_theme
 #
-# Copyright 2015, OpenStreetMap Foundation
+# Copyright:: 2015, 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
 #
 #
 # 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,
 #
 # Unless required by applicable law or agreed to in writing, software
 # distributed under the License is distributed on an "AS IS" BASIS,
 # limitations under the License.
 #
 
 # limitations under the License.
 #
 
-actions :create, :delete
+unified_mode true
+
 default_action :create
 
 default_action :create
 
-attribute :name, :kind_of => String, :name_attribute => true
-attribute :site, :kind_of => String, :required => true
-attribute :source, :kind_of => String
-attribute :version, :kind_of => String
-attribute :repository, :kind_of => String
-attribute :revision, :kind_of => String
-attribute :reload_apache, :kind_of => [TrueClass, FalseClass], :default => true
+property :theme, :kind_of => String, :name_property => true
+property :site, :kind_of => String, :required => true
+property :source, :kind_of => String
+property :version, :kind_of => String
+property :repository, :kind_of => String
+property :revision, :kind_of => String
+property :reload_apache, :kind_of => [TrueClass, FalseClass], :default => true
+
+action :create do
+  if new_resource.source
+    remote_directory theme_directory do
+      cookbook "wordpress"
+      source new_resource.source
+      owner node[:wordpress][:user]
+      group node[:wordpress][:group]
+      mode "755"
+      files_owner node[:wordpress][:user]
+      files_group node[:wordpress][:group]
+      files_mode "644"
+    end
+  else
+    theme_repository = new_resource.repository || default_repository
+
+    if theme_repository.end_with?(".git")
+      git theme_directory do
+        action :sync
+        repository theme_repository
+        revision new_resource.revision
+        user node[:wordpress][:user]
+        group node[:wordpress][:group]
+      end
+    elsif theme_repository.end_with?(".zip")
+      zip_path = "#{Chef::Config[:file_cache_path]}/#{new_resource.theme}.zip"
+
+      remote_file zip_path do
+        source theme_repository
+        action :create
+      end
+
+      archive_file zip_path do
+        destination theme_directory
+        action :nothing
+        overwrite true
+        group node[:wordpress][:group]
+        owner node[:wordpress][:user]
+        subscribes :extract, "remote_file[#{zip_path}]", :immediately
+      end
+    else
+      subversion theme_directory do
+        action :sync
+        repository theme_repository
+        user node[:wordpress][:user]
+        group node[:wordpress][:group]
+        ignore_failure theme_repository.start_with?("https://themes.svn.wordpress.org/")
+      end
+    end
+  end
+end
+
+action :delete do
+  directory theme_directory do
+    action :delete
+    recursive true
+  end
+end
+
+action_class do
+  def site_directory
+    node[:wordpress][:sites][new_resource.site][:directory]
+  end
+
+  def theme_directory
+    "#{site_directory}/wp-content/themes/#{new_resource.theme}"
+  end
+
+  def default_repository
+    "https://themes.svn.wordpress.org/#{new_resource.theme}/#{new_resource.version}"
+  end
+end
 
 def after_created
   notifies :reload, "service[apache2]" if reload_apache
 
 def after_created
   notifies :reload, "service[apache2]" if reload_apache