diff options
author | Giampaolo Lauria <lauria2@yahoo.com> | 2011-06-28 15:06:41 -0400 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2011-07-21 10:32:24 +1000 |
commit | 2cca4a44fe7247af85110c9b7e3c64363464bfd4 (patch) | |
tree | c8fc8dd266cdce2f5b0f9460d7778ce16d6f32d1 /source4/scripting | |
parent | 9f32f86018ac6463586bcac74424730a1aa9ac3b (diff) | |
download | samba-2cca4a44fe7247af85110c9b7e3c64363464bfd4.tar.gz samba-2cca4a44fe7247af85110c9b7e3c64363464bfd4.tar.bz2 samba-2cca4a44fe7247af85110c9b7e3c64363464bfd4.zip |
samba-tool: moved join to domain join
This is part of the samba-tool work to fit the object-action model
Signed-off-by: Andrew Tridgell <tridge@samba.org>
Diffstat (limited to 'source4/scripting')
-rw-r--r-- | source4/scripting/python/samba/netcmd/domain.py | 58 |
1 files changed, 57 insertions, 1 deletions
diff --git a/source4/scripting/python/samba/netcmd/domain.py b/source4/scripting/python/samba/netcmd/domain.py index d13f87e798..f56dd97b81 100644 --- a/source4/scripting/python/samba/netcmd/domain.py +++ b/source4/scripting/python/samba/netcmd/domain.py @@ -27,7 +27,9 @@ import samba.getopt as options import ldb import os from samba import Ldb -from samba.net import Net +from samba.net import Net, LIBNET_JOIN_AUTOMATIC +from samba.dcerpc.misc import SEC_CHAN_WKSTA +from samba.join import join_RODC, join_DC from samba.auth import system_session from samba.samdb import SamDB from samba.dcerpc.samr import DOMAIN_PASSWORD_COMPLEX, DOMAIN_PASSWORD_STORE_CLEARTEXT @@ -70,6 +72,59 @@ class cmd_domain_dumpkeys(Command): +class cmd_domain_join(Command): + """Joins domain as either member or backup domain controller [server connection needed]""" + + synopsis = "%prog domain join <dnsdomain> [DC | RODC | MEMBER] [options]" + + takes_optiongroups = { + "sambaopts": options.SambaOptions, + "versionopts": options.VersionOptions, + "credopts": options.CredentialsOptions, + } + + takes_options = [ + Option("--server", help="DC to join", type=str), + Option("--site", help="site to join", type=str), + Option("--targetdir", help="where to store provision", type=str), + ] + + takes_args = ["domain", "role?"] + + def run(self, domain, role=None, sambaopts=None, credopts=None, + versionopts=None, server=None, site=None, targetdir=None): + lp = sambaopts.get_loadparm() + creds = credopts.get_credentials(lp) + net = Net(creds, lp, server=credopts.ipaddress) + + if site is None: + site = "Default-First-Site-Name" + + netbios_name = lp.get("netbios name") + + if not role is None: + role = role.upper() + + if role is None or role == "MEMBER": + (join_password, sid, domain_name) = net.join_member(domain, + netbios_name, + LIBNET_JOIN_AUTOMATIC) + + self.outf.write("Joined domain %s (%s)\n" % (domain_name, sid)) + return + elif role == "DC": + join_DC(server=server, creds=creds, lp=lp, domain=domain, + site=site, netbios_name=netbios_name, targetdir=targetdir) + return + elif role == "RODC": + join_RODC(server=server, creds=creds, lp=lp, domain=domain, + site=site, netbios_name=netbios_name, targetdir=targetdir) + return + else: + raise CommandError("Invalid role %s (possible values: MEMBER, BDC, RODC)" % role) + + + class cmd_domain_level(Command): """Raises domain and forest function levels""" @@ -467,6 +522,7 @@ class cmd_domain(SuperCommand): subcommands = {} subcommands["dumpkeys"] = cmd_domain_dumpkeys() + subcommands["join"] = cmd_domain_join() subcommands["level"] = cmd_domain_level() subcommands["machinepassword"] = cmd_domain_machinepassword() subcommands["passwordsettings"] = cmd_domain_passwordsettings() |