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::Mount
Attributes inherited from Chef::Provider
#action, #current_resource, #logger, #new_resource, #recipe_name, #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, #device_unchanged?, #disable_fs, #enable_fs, #mounted?, #remount_fs
Methods included from Mixin::ShellOut
apply_default_env, maybe_add_timeout, #shell_out, #shell_out!
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, #define_resource_requirements, #description, #events, include_resource_dsl?, include_resource_dsl_module, #introduced, #node, #process_resource_requirements, provides, provides?, #requirements, #resource_collection, #resource_updated?, #run_action, #set_updated_status, supports?, 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::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) ⇒ Windows
Returns a new instance of Windows.
36 37 38 39 |
# File 'lib/chef/provider/mount/windows.rb', line 36 def initialize(new_resource, run_context) super @mount = nil end |
Instance Method Details
#is_volume(name) ⇒ Object
32 33 34 |
# File 'lib/chef/provider/mount/windows.rb', line 32 def is_volume(name) name =~ /^\\\\\?\\Volume\{[\w-]+\}\\$/ ? true : false end |
#load_current_resource ⇒ Object
41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 |
# File 'lib/chef/provider/mount/windows.rb', line 41 def load_current_resource if is_volume(@new_resource.device) @mount = Chef::Util::Windows::Volume.new(@new_resource.mount_point) else # assume network drive @mount = Chef::Util::Windows::NetUse.new(@new_resource.mount_point) end @current_resource = Chef::Resource::Mount.new(@new_resource.name) @current_resource.mount_point(@new_resource.mount_point) logger.trace("Checking for mount point #{@current_resource.mount_point}") begin @current_resource.device(@mount.device) logger.trace("#{@current_resource.device} mounted on #{@new_resource.mount_point}") @current_resource.mounted(true) rescue ArgumentError => e @current_resource.mounted(false) logger.trace("#{@new_resource.mount_point} is not mounted: #{e.message}") end end |
#mount_fs ⇒ Object
62 63 64 65 66 67 68 69 70 71 72 |
# File 'lib/chef/provider/mount/windows.rb', line 62 def mount_fs unless @current_resource.mounted @mount.add(remote: @new_resource.device, username: @new_resource.username, domainname: @new_resource.domain, password: @new_resource.password) logger.trace("#{@new_resource} is mounted at #{@new_resource.mount_point}") else logger.trace("#{@new_resource} is already mounted at #{@new_resource.mount_point}") end end |
#umount_fs ⇒ Object
74 75 76 77 78 79 80 81 |
# File 'lib/chef/provider/mount/windows.rb', line 74 def umount_fs if @current_resource.mounted @mount.delete logger.trace("#{@new_resource} is no longer mounted at #{@new_resource.mount_point}") else logger.trace("#{@new_resource} is not mounted at #{@new_resource.mount_point}") end end |