Class: Chef::Provider::Mount::Windows
- Inherits:
-
Chef::Provider::Mount
- Object
- Chef::Provider
- Chef::Provider::Mount
- Chef::Provider::Mount::Windows
- Defined in:
- lib/chef/provider/mount/windows.rb
Instance Attribute Summary
Attributes inherited from Chef::Provider
#action, #current_resource, #new_resource, #run_context
Instance Method Summary collapse
-
#initialize(new_resource, run_context) ⇒ Windows
constructor
A new instance of Windows.
- #is_volume(name) ⇒ Object
- #load_current_resource ⇒ Object
- #mount_fs ⇒ Object
- #umount_fs ⇒ Object
Methods inherited from Chef::Provider::Mount
#action_disable, #action_enable, #action_mount, #action_remount, #action_umount, #disable_fs, #enable_fs, #remount_fs, #whyrun_supported?
Methods included from Mixin::Command
#chdir_or_tmpdir, #handle_command_failures, #output_of_command, #run_command, #run_command_with_systems_locale
Methods included from Mixin::Command::Windows
Methods included from Mixin::Command::Unix
Methods inherited from Chef::Provider
#action_nothing, build_from_file, #cleanup_after_converge, #converge, #cookbook_name, #define_resource_requirements, #events, #node, #process_resource_requirements, #requirements, #resource_collection, #run_action, #whyrun_mode?, #whyrun_supported?
Methods included from Mixin::ConvertToClassName
#convert_to_class_name, #convert_to_snake_case, #filename_to_qualified_string, #snake_case_basename
Methods included from Mixin::EnforceOwnershipAndPermissions
#access_controls, #enforce_ownership_and_permissions
Methods included from Mixin::RecipeDefinitionDSLCore
Methods included from Mixin::Language
#data_bag, #data_bag_item, #platform?, #platform_family?, #search, #value_for_platform, #value_for_platform_family
Constructor Details
#initialize(new_resource, run_context) ⇒ Windows
Returns a new instance of Windows.
34 35 36 37 |
# File 'lib/chef/provider/mount/windows.rb', line 34 def initialize(new_resource, run_context) super @mount = nil end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method in the class Chef::Mixin::RecipeDefinitionDSLCore
Instance Method Details
#is_volume(name) ⇒ Object
30 31 32 |
# File 'lib/chef/provider/mount/windows.rb', line 30 def is_volume(name) name =~ /^\\\\\?\\Volume\{[\w-]+\}\\$/ ? true : false end |
#load_current_resource ⇒ Object
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 |
# File 'lib/chef/provider/mount/windows.rb', line 39 def load_current_resource if is_volume(@new_resource.device) @mount = Chef::Util::Windows::Volume.new(@new_resource.name) else #assume network drive @mount = Chef::Util::Windows::NetUse.new(@new_resource.name) end @current_resource = Chef::Resource::Mount.new(@new_resource.name) @current_resource.mount_point(@new_resource.mount_point) Chef::Log.debug("Checking for mount point #{@current_resource.mount_point}") begin @current_resource.device(@mount.device) Chef::Log.debug("#{@current_resource.device} mounted on #{@new_resource.mount_point}") @current_resource.mounted(true) rescue ArgumentError => e @current_resource.mounted(false) Chef::Log.debug("#{@new_resource.mount_point} is not mounted: #{e.}") end end |
#mount_fs ⇒ Object
60 61 62 63 64 65 66 67 |
# File 'lib/chef/provider/mount/windows.rb', line 60 def mount_fs unless @current_resource.mounted @mount.add(@new_resource.device) Chef::Log.debug("#{@new_resource} is mounted at #{@new_resource.mount_point}") else Chef::Log.debug("#{@new_resource} is already mounted at #{@new_resource.mount_point}") end end |
#umount_fs ⇒ Object
69 70 71 72 73 74 75 76 |
# File 'lib/chef/provider/mount/windows.rb', line 69 def umount_fs if @current_resource.mounted @mount.delete Chef::Log.debug("#{@new_resource} is no longer mounted at #{@new_resource.mount_point}") else Chef::Log.debug("#{@new_resource} is not mounted at #{@new_resource.mount_point}") end end |