mirror of
https://github.com/samba-team/samba.git
synced 2025-01-10 01:18:15 +03:00
samba-tool: Add -P to options.CredentialsOptions
This matches our other binaries, and allows samba-tool commands to run with the machine account. Signed-off-by: Andrew Bartlett <abartlet@samba.org> Reviewed-by: Stefan Metzmacher <metze@samba.org>
This commit is contained in:
parent
90d03a65bc
commit
63dbf4388a
@ -126,8 +126,9 @@ class CredentialsOptions(optparse.OptionGroup):
|
|||||||
"""Command line options for specifying credentials."""
|
"""Command line options for specifying credentials."""
|
||||||
|
|
||||||
def __init__(self, parser):
|
def __init__(self, parser):
|
||||||
self.no_pass = True
|
self.ask_for_password = True
|
||||||
self.ipaddress = None
|
self.ipaddress = None
|
||||||
|
self.machine_pass = False
|
||||||
optparse.OptionGroup.__init__(self, parser, "Credentials Options")
|
optparse.OptionGroup.__init__(self, parser, "Credentials Options")
|
||||||
self.add_option("--simple-bind-dn", metavar="DN", action="callback",
|
self.add_option("--simple-bind-dn", metavar="DN", action="callback",
|
||||||
callback=self._set_simple_bind_dn, type=str,
|
callback=self._set_simple_bind_dn, type=str,
|
||||||
@ -140,8 +141,9 @@ class CredentialsOptions(optparse.OptionGroup):
|
|||||||
self.add_option("-W", "--workgroup", metavar="WORKGROUP",
|
self.add_option("-W", "--workgroup", metavar="WORKGROUP",
|
||||||
action="callback", type=str,
|
action="callback", type=str,
|
||||||
help="Workgroup", callback=self._parse_workgroup)
|
help="Workgroup", callback=self._parse_workgroup)
|
||||||
self.add_option("-N", "--no-pass", action="store_true",
|
self.add_option("-N", "--no-pass", action="callback",
|
||||||
help="Don't ask for a password")
|
help="Don't ask for a password",
|
||||||
|
callback=self._set_no_password)
|
||||||
self.add_option("-k", "--kerberos", metavar="KERBEROS",
|
self.add_option("-k", "--kerberos", metavar="KERBEROS",
|
||||||
action="callback", type=str,
|
action="callback", type=str,
|
||||||
help="Use Kerberos", callback=self._set_kerberos)
|
help="Use Kerberos", callback=self._set_kerberos)
|
||||||
@ -149,17 +151,29 @@ class CredentialsOptions(optparse.OptionGroup):
|
|||||||
action="callback", type=str,
|
action="callback", type=str,
|
||||||
help="IP address of server",
|
help="IP address of server",
|
||||||
callback=self._set_ipaddress)
|
callback=self._set_ipaddress)
|
||||||
|
self.add_option("-P", "--machine-pass",
|
||||||
|
action="callback",
|
||||||
|
help="Use stored machine account password",
|
||||||
|
callback=self._set_machine_pass)
|
||||||
self.creds = Credentials()
|
self.creds = Credentials()
|
||||||
|
|
||||||
def _parse_username(self, option, opt_str, arg, parser):
|
def _parse_username(self, option, opt_str, arg, parser):
|
||||||
self.creds.parse_string(arg)
|
self.creds.parse_string(arg)
|
||||||
|
self.machine_pass = False
|
||||||
|
|
||||||
def _parse_workgroup(self, option, opt_str, arg, parser):
|
def _parse_workgroup(self, option, opt_str, arg, parser):
|
||||||
self.creds.set_domain(arg)
|
self.creds.set_domain(arg)
|
||||||
|
|
||||||
def _set_password(self, option, opt_str, arg, parser):
|
def _set_password(self, option, opt_str, arg, parser):
|
||||||
self.creds.set_password(arg)
|
self.creds.set_password(arg)
|
||||||
self.no_pass = False
|
self.ask_for_password = False
|
||||||
|
self.machine_pass = False
|
||||||
|
|
||||||
|
def _set_no_password(self, option, opt_str, arg, parser):
|
||||||
|
self.ask_for_password = False
|
||||||
|
|
||||||
|
def _set_machine_pass(self, option, opt_str, arg, parser):
|
||||||
|
self.machine_pass = True
|
||||||
|
|
||||||
def _set_ipaddress(self, option, opt_str, arg, parser):
|
def _set_ipaddress(self, option, opt_str, arg, parser):
|
||||||
self.ipaddress = arg
|
self.ipaddress = arg
|
||||||
@ -177,7 +191,9 @@ class CredentialsOptions(optparse.OptionGroup):
|
|||||||
:return: Credentials object
|
:return: Credentials object
|
||||||
"""
|
"""
|
||||||
self.creds.guess(lp)
|
self.creds.guess(lp)
|
||||||
if self.no_pass:
|
if self.machine_pass:
|
||||||
|
self.creds.set_machine_account(lp)
|
||||||
|
elif self.ask_for_password:
|
||||||
self.creds.set_cmdline_callbacks()
|
self.creds.set_cmdline_callbacks()
|
||||||
|
|
||||||
# possibly fallback to using the machine account, if we have
|
# possibly fallback to using the machine account, if we have
|
||||||
|
Loading…
Reference in New Issue
Block a user