# # Author:: AJ Christensen () # Copyright:: Copyright (c) 2008 Opscode, Inc. # License:: Apache License, Version 2.0 # # 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 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # require 'chef/mixin/command' require 'chef/provider' class Chef class Provider class Service < Chef::Provider include Chef::Mixin::Command def initialize(new_resource, run_context) super @enabled = nil end def action_enable if @current_resource.enabled Chef::Log.debug("#{@new_resource}: not enabling, already enabled") else Chef::Log.debug("#{@new_resource}: attempting to enable") if enable_service @new_resource.updated_by_last_action(true) Chef::Log.info("#{@new_resource}: enabled successfully") end end end def action_disable if @current_resource.enabled Chef::Log.debug("#{@new_resource}: attempting to disable") if disable_service @new_resource.updated_by_last_action(true) Chef::Log.info("#{@new_resource}: disabled successfully") end else Chef::Log.debug("#{@new_resource}: not disabling, already disabled") end end def action_start unless @current_resource.running Chef::Log.debug("#{@new_resource}: attempting to start") if start_service @new_resource.updated_by_last_action(true) Chef::Log.info("Started service #{@new_resource} successfully") end else Chef::Log.debug("#{@new_resource}: not starting, already running") end end def action_stop if @current_resource.running Chef::Log.debug("#{@new_resource}: attempting to stop") if stop_service @new_resource.updated_by_last_action(true) Chef::Log.info("#{@new_resource}: stopped successfully") end else Chef::Log.debug("#{@new_resource}: not stopping, already stopped") end end def action_restart Chef::Log.debug("#{@new_resource}: attempting to restart") if restart_service @new_resource.updated_by_last_action(true) Chef::Log.info("#{@new_resource}: restarted successfully") end end def action_reload unless (@new_resource.supports[:reload] || @new_resource.reload_command) raise Chef::Exceptions::UnsupportedAction, "#{self.to_s} does not support :reload" end if @current_resource.running Chef::Log.debug("#{@new_resource}: attempting to reload") if reload_service @new_resource.updated_by_last_action(true) Chef::Log.info("#{@new_resource}: reloaded successfully") end end end def enable_service raise Chef::Exceptions::UnsupportedAction, "#{self.to_s} does not support :enable" end def disable_service raise Chef::Exceptions::UnsupportedAction, "#{self.to_s} does not support :disable" end def start_service raise Chef::Exceptions::UnsupportedAction, "#{self.to_s} does not support :start" end def stop_service raise Chef::Exceptions::UnsupportedAction, "#{self.to_s} does not support :stop" end def restart_service raise Chef::Exceptions::UnsupportedAction, "#{self.to_s} does not support :restart" end def reload_service raise Chef::Exceptions::UnsupportedAction, "#{self.to_s} does not support :restart" end end end end