Skip to content

Commit

Permalink
Support use of symlinks for device paths
Browse files Browse the repository at this point in the history
This change improves the mounted? check. Symlinks are now resolved to
their canonical path. Checks if the device is mounted at a specific mount point

Signed-off-by: Jakob Pfeiffer <jakob.pfeiffer@m-net.de>
  • Loading branch information
Jakob Pfeiffer committed Dec 9, 2024
1 parent f68356e commit 666625a
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 7 deletions.
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ All notable changes to this project will be documented in this file.

## Unreleased

- Support use of symlinks for device paths

## 4.1.0 - *2024-12-09*

- Add validation to the filesystem label property, limiting to a maximum length of 12 characters
Expand Down
30 changes: 27 additions & 3 deletions libraries/fs.rb
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,33 @@ module FilesystemMod
NET_FS_TYPES = %w(nfs nfs4 cifs smp nbd).freeze unless const_defined?(:NET_FS_TYPES)
NFS_TYPES = %w(nfs nfs4).freeze unless const_defined?(:NFS_TYPES)

# Check to determine if the device is mounted.
def mounted?(device)
shell_out("grep -q '#{device}' /proc/mounts").exitstatus != 0 ? nil : shell_out("grep -q '#{device}' /proc/mounts").exitstatus
def canonical_path(path)
File.exist?(path) && File.realpath(path) || path
end

# Check to determine if a device is mounted.
def mounted?(params = {})
params.is_a?(String) && params = { device: params } # backward compatibility

mounts = File.readlines('/proc/mounts').map(&:split).map do |field|
{
device: field[0].start_with?('/dev/') && canonical_path(field[0]) || field[0],
mountpoint: field[1],
}
end

if params.key?(:device) && params.key?(:mountpoint)
mounts.select do |mount|
mount[:device] == canonical_path(params[:device]) &&
mount[:mountpoint] == params[:mountpoint].chomp('/')
end.any?
elsif params.key?(:device)
mounts.select { |mount| mount[:device] == canonical_path(params[:device]) }.any?
elsif params.key?(:mountpoint)
mounts.select { |mount| mount[:mountpoint] == params[:mountpoint].chomp('/') }.any?
else
raise 'Invalid parameters passed to method "mounted?"'
end
end

# Check to determine if the mount is frozen.
Expand Down
6 changes: 2 additions & 4 deletions resources/default.rb
Original file line number Diff line number Diff line change
Expand Up @@ -153,7 +153,7 @@ def mount_point(mount_location)
wait_for_device unless ::File.exist?(device) || netfs?(fstype)

# We only try and create a filesystem if the device exists and is unmounted
unless mounted?(device)
unless mounted?(device: device)

# Install the filesystem's default package and recipes as configured in default attributes.
fs_tools = node['filesystem_tools'].fetch(fstype, nil)
Expand Down Expand Up @@ -259,9 +259,7 @@ def mount_point(mount_location)
fstype fstype
options options
action :mount
# Pathname.new(mount).mountpoint? would be a better check but might
# cause different behavior
not_if "mount | grep #{device}\" \" | grep #{mount}\" \""
not_if { mounted?(device: device, mountpoint: mount) }
end

# set directory attributes within the mounted file system
Expand Down

0 comments on commit 666625a

Please sign in to comment.