1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-25 06:04:04 +03:00

samba-tool: gpo: Refactor code using utility functions

This commit is contained in:
Amitay Isaacs 2012-07-03 14:16:41 +10:00
parent 5ca24346bf
commit a9c4336733

View File

@ -624,13 +624,13 @@ class cmd_dellink(Command):
"credopts": options.CredentialsOptions, "credopts": options.CredentialsOptions,
} }
takes_args = ['container_dn', 'gpo'] takes_args = ['container', 'gpo']
takes_options = [ takes_options = [
Option("-H", help="LDB URL for database or target server", type=str), Option("-H", help="LDB URL for database or target server", type=str),
] ]
def run(self, container_dn, gpo, H=None, sambaopts=None, credopts=None, def run(self, container, gpo, H=None, sambaopts=None, credopts=None,
versionopts=None): versionopts=None):
self.lp = sambaopts.get_loadparm() self.lp = sambaopts.get_loadparm()
@ -642,42 +642,12 @@ class cmd_dellink(Command):
# Check if valid GPO # Check if valid GPO
try: try:
msg = get_gpo_info(self.sambdb, gpo=gpo)[0] get_gpo_info(self.samdb, gpo=gpo)[0]
except Exception, e: except Exception, e:
raise CommandError("GPO %s does not exist" % gpo, e) raise CommandError("GPO %s does not exist" % gpo, e)
gpo_dn = get_gpo_dn(self.samdb, gpo)
# Check if valid Container DN and get existing GPlinks
try:
msg = self.samdb.search(base=container_dn, scope=ldb.SCOPE_BASE,
expression="(objectClass=*)",
attrs=['gPlink'])[0]
except Exception, e:
raise CommandError("Could not find container DN %s" % dn, e)
if 'gPLink' in msg:
gplist = parse_gplink(msg['gPLink'][0])
for g in gplist:
if g['dn'].lower() == gpo_dn.lower():
gplist.remove(g)
break
else:
raise CommandError("Specified GPO is not linked to this container")
m = ldb.Message()
m.dn = ldb.Dn(self.samdb, container_dn)
if gplist:
gplink_str = encode_gplink(gplist)
m['new_value'] = ldb.MessageElement(gplink_str, ldb.FLAG_MOD_REPLACE, 'gPLink')
else:
m['new_value'] = ldb.MessageElement('', ldb.FLAG_MOD_DELETE, 'gPLink')
try:
self.samdb.modify(m)
except Exception, e:
raise CommandError("Error Removing GPO Link (%s)" % e)
container_dn = ldb.Dn(self.samdb, container)
del_gpo_link(self.samdb, container_dn, gpo)
self.outf.write("Deleted GPO link.\n") self.outf.write("Deleted GPO link.\n")
cmd_getlink().run(container_dn, H, sambaopts, credopts, versionopts) cmd_getlink().run(container_dn, H, sambaopts, credopts, versionopts)
@ -921,12 +891,10 @@ class cmd_create(Command):
self.samdb.transaction_start() self.samdb.transaction_start()
try: try:
# Add cn=<guid> # Add cn=<guid>
gpo_dn = self.samdb.get_default_basedn() gpo_dn = get_gpo_dn(self.samdb, gpo)
gpo_dn.add_child(ldb.Dn(self.samdb, "CN=Policies,CN=System"))
gpo_dn.add_child(ldb.Dn(self.samdb, "CN=%s" % gpo))
m = ldb.Message() m = ldb.Message()
m.dn = ldb.Dn(self.samdb, gpo_dn.get_linearized()) m.dn = gpo_dn
m['a01'] = ldb.MessageElement("groupPolicyContainer", ldb.FLAG_MOD_ADD, "objectClass") m['a01'] = ldb.MessageElement("groupPolicyContainer", ldb.FLAG_MOD_ADD, "objectClass")
m['a02'] = ldb.MessageElement(displayname, ldb.FLAG_MOD_ADD, "displayName") m['a02'] = ldb.MessageElement(displayname, ldb.FLAG_MOD_ADD, "displayName")
m['a03'] = ldb.MessageElement(unc_path, ldb.FLAG_MOD_ADD, "gPCFileSysPath") m['a03'] = ldb.MessageElement(unc_path, ldb.FLAG_MOD_ADD, "gPCFileSysPath")