Support SMB mount option overrides
This commit is contained in:
parent
6b1646eb51
commit
b1c38c282e
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue