takes_options = [
Option("-H", "--URL", help="LDB URL for database or target server",
type=str, metavar="URL", dest="H"),
+ Option("-b", "--base-dn",
+ help="Specify base DN to use.",
+ type=str),
Option("--full-dn", dest="full_dn", default=False, action='store_true',
help="Display DNs including the base DN."),
]
"versionopts": options.VersionOptions,
}
- def run(self, sambaopts=None, credopts=None, versionopts=None, H=None,
+ def run(self,
+ sambaopts=None,
+ credopts=None,
+ versionopts=None,
+ H=None,
+ base_dn=None,
full_dn=False):
lp = sambaopts.get_loadparm()
creds = credopts.get_credentials(lp, fallback_machine=True)
samdb = SamDB(url=H, session_info=system_session(),
credentials=creds, lp=lp)
- domain_dn = ldb.Dn(samdb, samdb.domain_dn())
- res = samdb.search(domain_dn, scope=ldb.SCOPE_SUBTREE,
+ search_dn = ldb.Dn(samdb, samdb.domain_dn())
+ if base_dn:
+ search_dn = samdb.normalize_dn_in_domain(base_dn)
+
+ res = samdb.search(search_dn,
+ scope=ldb.SCOPE_SUBTREE,
expression="(objectClass=organizationalUnit)",
attrs=[])
if (len(res) == 0):
for msg in sorted(res, key=attrgetter('dn')):
if not full_dn:
+ domain_dn = ldb.Dn(samdb, samdb.domain_dn())
msg.dn.remove_base_components(len(domain_dn))
self.outf.write("%s\n" % str(msg.dn))