Support SMB mount option overrides

This commit is contained in:
Chris Roberts 2018-01-12 17:23:00 -08:00
parent 6b1646eb51
commit b1c38c282e
2 changed files with 56 additions and 7 deletions

View File

@ -25,16 +25,19 @@ module VagrantPlugins
# Ensure password is scrubbed # Ensure password is scrubbed
Vagrant::Util::CredentialScrubber.sensitive(smb_password) Vagrant::Util::CredentialScrubber.sensitive(smb_password)
options[:mount_options] ||= [] mnt_opts = []
if machine.env.host.capability?(:smb_mount_options) if machine.env.host.capability?(:smb_mount_options)
options[:mount_options] += machine.env.host.capability(:smb_mount_options) mnt_opts += machine.env.host.capability(:smb_mount_options)
else else
options[:mount_options] << "sec=ntlm" mnt_opts << "sec=ntlmssp"
end end
options[:mount_options] << "credentials=/etc/smb_creds_#{name}" mnt_opts << "credentials=/etc/smb_creds_#{name}"
mnt_opts << "uid=#{mount_uid}"
mnt_opts << "gid=#{mount_gid}"
mount_options = "-o uid=#{mount_uid},gid=#{mount_gid}" mnt_opts = merge_mount_options(mnt_opts, options[:mount_options] || [])
mount_options += ",#{Array(options[:mount_options]).join(",")}" if options[:mount_options]
mount_options = "-o #{mnt_opts.join(",")}"
mount_command = "mount -t cifs #{mount_options} #{mount_device} #{expanded_guest_path}" mount_command = "mount -t cifs #{mount_options} #{mount_device} #{expanded_guest_path}"
# Create the guest path if it doesn't exist # Create the guest path if it doesn't exist
@ -76,6 +79,21 @@ SCRIPT
emit_upstart_notification(machine, expanded_guest_path) emit_upstart_notification(machine, expanded_guest_path)
end end
def self.merge_mount_options(base, overrides)
base = base.join(",").split(",")
overrides = overrides.join(",").split(",")
b_kv = Hash[base.map{|item| item.split("=", 2) }]
o_kv = Hash[overrides.map{|item| item.split("=", 2) }]
merged = {}.tap do |opts|
(b_kv.keys + o_kv.keys).uniq.each do |key|
opts[key] = o_kv.fetch(key, b_kv[key])
end
end
merged.map do |key, value|
[key, value].compact.join("=")
end
end
end end
end end
end end

View File

@ -7,7 +7,9 @@ describe "VagrantPlugins::GuestLinux::Cap::MountSMBSharedFolder" do
.guest_capabilities[:linux] .guest_capabilities[:linux]
end end
let(:machine) { double("machine") } let(:machine) { double("machine", env: env) }
let(:env) { double("env", host: host) }
let(:host) { double("host") }
let(:guest) { double("guest") } let(:guest) { double("guest") }
let(:comm) { VagrantTests::DummyCommunicator::Communicator.new(machine) } let(:comm) { VagrantTests::DummyCommunicator::Communicator.new(machine) }
let(:mount_owner){ "vagrant" } let(:mount_owner){ "vagrant" }
@ -29,6 +31,7 @@ describe "VagrantPlugins::GuestLinux::Cap::MountSMBSharedFolder" do
before do before do
allow(machine).to receive(:communicate).and_return(comm) allow(machine).to receive(:communicate).and_return(comm)
allow(host).to receive(:capability?).and_return(false)
end end
after do after do
@ -72,5 +75,33 @@ describe "VagrantPlugins::GuestLinux::Cap::MountSMBSharedFolder" do
expect(comm).to receive(:sudo).with(/emit/) expect(comm).to receive(:sudo).with(/emit/)
cap.mount_smb_shared_folder(machine, mount_name, mount_guest_path, folder_options) cap.mount_smb_shared_folder(machine, mount_name, mount_guest_path, folder_options)
end end
context "with custom mount options" do
let(:folder_options) do
{
owner: mount_owner,
group: mount_group,
smb_host: "localhost",
smb_username: "user",
smb_password: "pass",
mount_options: ["ro", "sec=custom"]
}
end
it "adds given mount options to command" do
expect(comm).to receive(:sudo).with(/ro/, any_args)
cap.mount_smb_shared_folder(machine, mount_name, mount_guest_path, folder_options)
end
it "replaces defined options" do
expect(comm).to receive(:sudo).with(/sec=custom/, any_args)
cap.mount_smb_shared_folder(machine, mount_name, mount_guest_path, folder_options)
end
it "does not include replaced options" do
expect(comm).not_to receive(:sudo).with(/sec=ntlm/, any_args)
cap.mount_smb_shared_folder(machine, mount_name, mount_guest_path, folder_options)
end
end
end end
end end