Class: Chef::Provider::Service::Init
- Inherits:
-
Simple
- Object
- Chef::Provider
- Chef::Provider::Service
- Simple
- Chef::Provider::Service::Init
- Defined in:
- lib/chef/provider/service/init.rb
Instance Attribute Summary collapse
-
#init_command ⇒ Object
Returns the value of attribute init_command.
Attributes inherited from Simple
Attributes inherited from Chef::Provider
#action, #current_resource, #logger, #new_resource, #recipe_name, #run_context
Class Method Summary collapse
Instance Method Summary collapse
- #define_resource_requirements ⇒ Object
-
#initialize(new_resource, run_context) ⇒ Init
constructor
A new instance of Init.
- #reload_service ⇒ Object
- #restart_service ⇒ Object
- #start_service ⇒ Object
- #stop_service ⇒ Object
Methods inherited from Simple
#load_current_resource, #shared_resource_requirements
Methods inherited from Chef::Provider::Service
#action_disable, #action_enable, #action_mask, #action_reload, #action_restart, #action_start, #action_stop, #action_unmask, #disable_service, #enable_service, #load_current_resource, #load_new_resource_state, #mask_service, #shared_resource_requirements, #supports, #unmask_service, #user_services_requirements
Methods inherited from Chef::Provider
action, #action_nothing, #check_resource_semantics!, #cleanup_after_converge, #compile_and_converge_action, #converge_by, #converge_if_changed, #cookbook_name, #description, #events, include_resource_dsl?, include_resource_dsl_module, #introduced, #load_current_resource, #node, #process_resource_requirements, provides, provides?, #requirements, #resource_collection, #resource_updated?, #run_action, #set_updated_status, use_inline_resources, #whyrun_mode?, #whyrun_supported?
Methods included from Mixin::Provides
#provided_as, #provides, #provides?
Methods included from Mixin::DescendantsTracker
#descendants, descendants, direct_descendants, #direct_descendants, find_descendants_by_name, #find_descendants_by_name, #inherited, store_inherited
Methods included from Mixin::LazyModuleInclude
#descendants, #include, #included
Methods included from Mixin::ShellOut
apply_default_env, maybe_add_timeout, #shell_out, #shell_out!
Methods included from Mixin::PowershellOut
#powershell_out, #powershell_out!
Methods included from Mixin::WindowsArchitectureHelper
#assert_valid_windows_architecture!, #disable_wow64_file_redirection, #forced_32bit_override_required?, #is_i386_process_on_x86_64_windows?, #node_supports_windows_architecture?, #node_windows_architecture, #restore_wow64_file_redirection, #valid_windows_architecture?, #with_os_architecture, #wow64_architecture_override_required?, #wow64_directory
Methods included from Mixin::PowershellExec
Methods included from DSL::Powershell
Methods included from DSL::RegistryHelper
#registry_data_exists?, #registry_get_subkeys, #registry_get_values, #registry_has_subkeys?, #registry_key_exists?, #registry_value_exists?
Methods included from DSL::DataQuery
#data_bag, #data_bag_item, #search, #tagged?
Methods included from EncryptedDataBagItem::CheckEncrypted
Methods included from DSL::PlatformIntrospection
#older_than_win_2012_or_8?, #platform?, #platform_family?, #value_for_platform, #value_for_platform_family
Methods included from Mixin::NotifyingBlock
#notifying_block, #subcontext_block
Methods included from DSL::DeclareResource
#build_resource, #declare_resource, #delete_resource, #delete_resource!, #edit_resource, #edit_resource!, #find_resource, #find_resource!, #resources, #with_run_context
Constructor Details
#initialize(new_resource, run_context) ⇒ Init
Returns a new instance of Init.
35 36 37 38 |
# File 'lib/chef/provider/service/init.rb', line 35 def initialize(new_resource, run_context) super @init_command = "/etc/init.d/#{@new_resource.service_name}" end |
Instance Attribute Details
#init_command ⇒ Object
Returns the value of attribute init_command.
27 28 29 |
# File 'lib/chef/provider/service/init.rb', line 27 def init_command @init_command end |
Class Method Details
.supports?(resource, action) ⇒ Boolean
31 32 33 |
# File 'lib/chef/provider/service/init.rb', line 31 def self.supports?(resource, action) service_script_exist?(:initd, resource.service_name) end |
Instance Method Details
#define_resource_requirements ⇒ Object
40 41 42 43 44 45 46 47 48 49 50 51 52 53 |
# File 'lib/chef/provider/service/init.rb', line 40 def define_resource_requirements # do not call super here, inherit only shared_requirements shared_resource_requirements requirements.assert(:start, :stop, :restart, :reload) do |a| a.assertion do custom_command_for_action?(action) || ::File.exist?(default_init_command) end a.(Chef::Exceptions::Service, "#{default_init_command} does not exist!") a.whyrun("Init script '#{default_init_command}' doesn't exist, assuming a prior action would have created it.") do # blindly assume that the service exists but is stopped in why run mode: @status_load_success = false end end end |
#reload_service ⇒ Object
83 84 85 86 87 88 89 |
# File 'lib/chef/provider/service/init.rb', line 83 def reload_service if @new_resource.reload_command super elsif supports[:reload] shell_out!("#{default_init_command} reload", default_env: false) end end |
#restart_service ⇒ Object
71 72 73 74 75 76 77 78 79 80 81 |
# File 'lib/chef/provider/service/init.rb', line 71 def restart_service if @new_resource.restart_command super elsif supports[:restart] shell_out!("#{default_init_command} restart", default_env: false) else stop_service sleep 1 start_service end end |
#start_service ⇒ Object
55 56 57 58 59 60 61 |
# File 'lib/chef/provider/service/init.rb', line 55 def start_service if @new_resource.start_command super else shell_out!("#{default_init_command} start", default_env: false) end end |
#stop_service ⇒ Object
63 64 65 66 67 68 69 |
# File 'lib/chef/provider/service/init.rb', line 63 def stop_service if @new_resource.stop_command super else shell_out!("#{default_init_command} stop", default_env: false) end end |