X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/8457be7e5e08d50425a5f705046ecd5830483a53..9d1da497d442b16de5ab68a9cf74f832059734e7:/cookbooks/wordpress/resources/plugin.rb?ds=sidebyside diff --git a/cookbooks/wordpress/resources/plugin.rb b/cookbooks/wordpress/resources/plugin.rb index a1f5ad729..078b926f5 100644 --- a/cookbooks/wordpress/resources/plugin.rb +++ b/cookbooks/wordpress/resources/plugin.rb @@ -1,14 +1,14 @@ # -# Cookbook Name:: wordpress +# Cookbook:: wordpress # Resource:: wordpress_plugin # -# 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 # -# 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, @@ -17,16 +17,95 @@ # limitations under the License. # -actions :create, :delete +unified_mode true + 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 :plugin, :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 plugin_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 "755" + end + else + plugin_repository = new_resource.repository || default_repository + + if plugin_repository.end_with?(".git") + git plugin_directory do + action :sync + repository plugin_repository + revision new_resource.revision + user node[:wordpress][:user] + group node[:wordpress][:group] + end + else + subversion plugin_directory do + action :sync + repository plugin_repository + user node[:wordpress][:user] + group node[:wordpress][:group] + ignore_failure plugin_repository.start_with?("https://plugins.svn.wordpress.org/") + end + end + end + + execute "wp-cli plugin activate #{new_resource.plugin}" do + command "/opt/wp-cli/wp --path='#{site_directory}' plugin activate '#{new_resource.plugin}'" + user "www-data" + group "www-data" + not_if "/opt/wp-cli/wp --path='#{site_directory}' plugin is-active '#{new_resource.plugin}'" + ignore_failure plugin_repository.start_with?("https://plugins.svn.wordpress.org/") + end +end + +action :delete do + execute "wp-cli plugin deactivate #{new_resource.plugin}" do + command "/opt/wp-cli/wp --path='#{site_directory}' plugin deactivate '#{new_resource.plugin}'" + user "www-data" + group "www-data" + only_if "/opt/wp-cli/wp --path='#{site_directory}' plugin is-active '#{new_resource.plugin}'" + end + + directory plugin_directory do + action :delete + recursive true + end +end + +action_class do + def site_directory + node[:wordpress][:sites][new_resource.site][:directory] + end + + def plugin_directory + "#{site_directory}/wp-content/plugins/#{new_resource.plugin}" + end + + def default_repository + version = new_resource.version || + Chef::Wordpress.current_plugin_version(new_resource.plugin) + + if version =~ /trunk/ + "https://plugins.svn.wordpress.org/#{new_resource.plugin}/trunk" + else + "https://plugins.svn.wordpress.org/#{new_resource.plugin}/tags/#{version}" + end + end +end def after_created notifies :reload, "service[apache2]" if reload_apache