svn commit: samba r25489 - in branches/4.0-python: . source/scripting/bin

jelmer at samba.org jelmer at samba.org
Wed Oct 3 19:48:01 GMT 2007


Author: jelmer
Date: 2007-10-03 19:48:00 +0000 (Wed, 03 Oct 2007)
New Revision: 25489

WebSVN: http://websvn.samba.org/cgi-bin/viewcvs.cgi?view=rev&root=samba&rev=25489

Log:
Convert samba3dump to python.
Modified:
   branches/4.0-python/
   branches/4.0-python/source/scripting/bin/samba3dump


Changeset:

Property changes on: branches/4.0-python
___________________________________________________________________
Name: bzr:revision-info
...skipped...
Name: bzr:revision-id:v3-trunk0
...skipped...

Modified: branches/4.0-python/source/scripting/bin/samba3dump
===================================================================
--- branches/4.0-python/source/scripting/bin/samba3dump	2007-10-03 19:22:02 UTC (rev 25488)
+++ branches/4.0-python/source/scripting/bin/samba3dump	2007-10-03 19:48:00 UTC (rev 25489)
@@ -1,234 +1,168 @@
-#!/bin/sh
-exec smbscript "$0" ${1+"$@"}
-/*
-	Dump Samba3 data
-	Copyright Jelmer Vernooij 2005
-	Released under the GNU GPL v2 or later
-*/
+#!/usr/bin/python
+#
+#	Dump Samba3 data
+#	Copyright Jelmer Vernooij 2005-2007
+#	Released under the GNU GPL v3 or later
+#
 
-options = GetOptions(ARGV,
-		"POPT_AUTOHELP",
-		"POPT_COMMON_SAMBA",
-		"POPT_COMMON_VERSION",
-		'format=s',
-		'quiet', 'blank');
+import getopt
+import optparse
+import sys
 
-if (options == undefined) {
-   println("Failed to parse options");
-   return -1;
-}
+sys.path.append("scripting/python")
 
-if (options.format == undefined) {
-	options.format = "summary";
-}
+import options
+import param
 
-if (options.format != "summary" && options.format != "full") {
-	printf("Unknown format %s\n", options.format);
-	return -1;
-}
+parser = optparse.OptionParser("samba3dump [options]")
+parser.add_option_group(options.SambaOptions(parser))
+parser.add_option_group(options.VersionOptions(parser))
+parser.add_option("--quiet", help="Be quiet")
+parser.add_option("--blank", help="Blank existing users")
+parser.add_option("--format", type="choice", choices=["summary", "full"], help="What format to output")
 
-libinclude("base.js");
+(opts, args) = parser.parse_args()
 
-if (options.ARGV.length != 2) {
-	println("Usage: samba3dump <libdir> <smb.conf>");
-	return -1;
-}
+if opts.format is None:
+	opts.format = "summary"
 
-function print_header(txt)
-{
-	printf("\n%s\n", txt);
-	println("==========================================");
-}
+if len(args) != 2:
+	parser.print_usage()
+	sys.exit(1)
 
-function print_samba3_policy(pol)
-{
-	print_header("Account Policies");
-	printf("Min password length: %d\n", pol.min_password_length);
-	printf("Password history length: %d\n", pol.password_history);
-	printf("User must logon to change password: %d\n", pol.user_must_logon_to_change_password);
-	printf("Maximum password age: %d\n", pol.maximum_password_age);
-	printf("Minimum password age: %d\n", pol.minimum_password_age);
-	printf("Lockout duration: %d\n", pol.lockout_duration);
-	printf("Reset Count Minutes: %d\n", pol.reset_count_minutes);
-	printf("Bad Lockout Minutes: %d\n", pol.bad_lockout_minutes);
-	printf("Disconnect Time: %d\n", pol.disconnect_time);
-	printf("Refuse Machine Password Change: %d\n", pol.refuse_machine_password_change);
-}
+def print_header(txt):
+	print "\n%s\n" % txt
+	print "=========================================="
 
-function print_samba3_sam(samba3)
-{
-	var i;
-	print_header("SAM Database");
+def print_samba3_policy(pol):
+	print_header("Account Policies")
+	print "Min password length: %d\n" % pol.min_password_length
+	print "Password history length: %d\n"% pol.password_history
+	print "User must logon to change password: %d\n" % pol.user_must_logon_to_change_password
+	print "Maximum password age: %d\n" % pol.maximum_password_age
+	print "Minimum password age: %d\n" % pol.minimum_password_age
+	print "Lockout duration: %d\n" % pol.lockout_duration
+	print "Reset Count Minutes: %d\n" % pol.reset_count_minutes
+	print "Bad Lockout Minutes: %d\n" % pol.bad_lockout_minutes
+	print "Disconnect Time: %d\n" % pol.disconnect_time
+	print "Refuse Machine Password Change: %d\n" % pol.refuse_machine_password_change
+
+def print_samba3_sam(samba3):
+	print_header("SAM Database")
 	
-	for (i in samba3.samaccounts) {
-		var a = samba3.samaccounts[i];
-		printf("%d: %s\n", a.user_rid, a.username);
-	}
-}
+	for a in samba3.samaccounts:
+		print "%d: %s\n" % (a.user_rid, a.username)
 
-function print_samba3_shares(samba3)
-{
-	var i, j;
-	print_header("Configured shares");
-	for (i in samba3.shares) {
-		var s = samba3.shares[i];
-		printf("--- %s ---\n", s.name);
+def print_samba3_shares(samba3):
+	print_header("Configured shares")
+	for s in samba3.shares:
+		print "--- %s ---\n" % s.name
 
-		for (j in s.parameters) {
-			var p = s.parameters[j];
-			printf("\t%s = %s\n", p.name, p.value);
-		}
+		for p in s.parameters:
+			print "\t%s = %s\n" % (p.name, p.value)
 
-		println("");
-	}
-}
+		print "\n"
 
-function print_samba3_secrets(secrets)
-{
-	var i;
-	print_header("Secrets");
+def print_samba3_secrets(secrets):
+	print_header("Secrets")
 
-	println("IPC Credentials:");
-	if (secrets.ipc_cred.username_obtained) 
-		printf("	User: %s\n", secrets.ipc_cred.get_username);
-	if (secrets.ipc_cred.password_obtained)
-		printf("	Password: %s\n", secrets.ipc_cred.get_password);
+	println("IPC Credentials:")
+	if secrets.ipc_cred.username_obtained:
+		print "	User: %s\n" % secrets.ipc_cred.get_username
+	if secrets.ipc_cred.password_obtained:
+		print "	Password: %s\n" % secrets.ipc_cred.get_password
+	if secrets.ipc_cred.domain_obtained:
+		print "	Domain: %s\n\n" % secrets.ipc_cred.get_domain
 
-	if (secrets.ipc_cred.domain_obtained)
-		printf("	Domain: %s\n\n", secrets.ipc_cred.get_domain);
+	print "LDAP passwords:\n"
+	for pw in secrets.ldappws:
+		print "\t%s -> %s\n" (pw.dn, pw.password)
+	print "\n"
 
-	println("LDAP passwords:");
-	for (i in secrets.ldappws) {
-		var pw = secrets.ldappws[i];
-		printf("\t%s -> %s\n", pw.dn, pw.password);
-	}
-	println("");
+	print("Domains:\n")
+	for d in secrets.domains:
+		print "\t--- %s ---\n" % d.name
+		print "\tSID: %s\n" % d.sid
+		print "\tGUID: %s\n" % d.guid
+		print "\tPlaintext pwd: %s\n" % d.plaintext_pw
+		print "\tLast Changed: %lu\n" % d.last_change_time
+		print "\tSecure Channel Type: %d\n\n" % d.sec_channel_type
 
-	println("Domains:");
-	for (i in secrets.domains) {
-		var d = secrets.domains[i];
-		printf("\t--- %s ---\n", d.name);
-		printf("\tSID: %s\n", d.sid);
-		printf("\tGUID: %s\n", d.guid);
-		printf("\tPlaintext pwd: %s\n", d.plaintext_pw);
-		printf("\tLast Changed: %lu\n", d.last_change_time);
-		printf("\tSecure Channel Type: %d\n\n", d.sec_channel_type);
-	}
+	print "Trusted domains:\n"
+	for td in secrets.trusted_domains:
+		for name in td.uni_name:
+			print "\t--- %s ---\n" % name
+		print "\tPassword: %s\n" % td.password
+		print "\tModified: %lu\n" % td.mod_time
+		print "\tSID: %s\n" % td.domain_sid
 
-	println("Trusted domains:");
-	for (i in secrets.trusted_domains) {
-		var td = secrets.trusted_domains[i];
-		for (j = 0; j < td.uni_name_len; j++) {
-			printf("\t--- %s ---\n", td.uni_name[j]);
-		}
-		printf("\tPassword: %s\n", td.pass);
-		printf("\tModified: %lu\n", td.mod_time);
-		printf("\tSID: %s\n", td.domain_sid);
-	}
-}
+def print_samba3_regdb(regdb):
+	print_header("Registry")
 
-function print_samba3_regdb(regdb)
-{
-	var i, j;
-	print_header("Registry");
+	for k in regdb.keys:
+		print "%s\n" % k.name
+		for v in k.values:
+			print "\t%s: type %d, length %d\n" % (v.name, v.type, v.data.length)
 
-	for (i in regdb.keys) {
-		var k = regdb.keys[i];
-		printf("%s\n", k.name);
-		for (j in k.values) {
-			var v = k.values[j];
-			printf("\t%s: type %d, length %d\n", v.name, v.type, v.data.length);
-		}
-	}
-}
+def print_samba3_winsdb(samba3):
+	print_header("WINS Database")
 
-function print_samba3_winsdb(samba3)
-{
-	var i;
-	print_header("WINS Database");
+	for e in samba3.winsentries:
+		print "%s, nb_flags: %x, type: %d, ttl: %lu, %d ips, fst: %s\n" % (e.name, e.nb_flags, e.type, e.ttl, e.ips.length, e.ips[0])
 
-	for (i in samba3.winsentries) {
-		var e = samba3.winsentries[i];
-		printf("%s, nb_flags: %x, type: %d, ttl: %lu, %d ips, fst: %s\n", e.name, e.nb_flags, e.type, e.ttl, e.ips.length, e.ips[0]);
-	}
-}
-
-function print_samba3_groupmappings(groupdb)
-{
-	print_header("Group Mappings");
+def print_samba3_groupmappings(groupdb):
+	print_header("Group Mappings")
 	
-	for (var i in groupdb.groupmappings) {
-		var g = groupdb.groupmappings[i];
-		printf("\t--- Group: %s ---\n", g.nt_name);
-		printf("\tComment: %s\n", g.comment);
-		printf("\tGID: %d\n", g.gid);
-		printf("\tSID Name Use: %d\n", g.sid_name_use);
-		printf("\tSID: %s\n\n", g.sid);
-	}
-}
+	for g in groupdb.groupmappings:
+		print "\t--- Group: %s ---\n" % g.nt_name
+		print "\tComment: %s\n" % g.comment
+		print "\tGID: %d\n" % g.gid
+		print "\tSID Name Use: %d\n" % g.sid_name_use
+		print "\tSID: %s\n\n" % g.sid
 
-function print_samba3_aliases(groupdb)
-{
-	var i, j;
-	for (i in groupdb.aliases) {
-		var a = groupdb.aliases[i];
-		printf("\t--- Alias: %s ---\n", a.sid);
-		for (j in a.members) {
-			printf("\t%s\n", a.members[j]);
-		}
-	}
-}
+def print_samba3_aliases(groupdb):
+	for a in groupdb.aliases:
+		print "\t--- Alias: %s ---\n" % a.sid
+		for j in a.members:
+			print "\t%s\n" % a.members[j]
 
-function print_samba3_idmapdb(idmapdb)
-{
-	var i;
-	print_header("Winbindd SID<->GID/UID mappings");
+def print_samba3_idmapdb(idmapdb):
+	print_header("Winbindd SID<->GID/UID mappings")
 
-	printf("User High Water Mark: %d\n", idmapdb.user_hwm);
-	printf("Group High Water Mark: %d\n\n", idmapdb.group_hwm);
+	print "User High Water Mark: %d\n" % idmapdb.user_hwm
+	print "Group High Water Mark: %d\n\n" % idmapdb.group_hwm
 
-	for (i in idmapdb.mappings) {
-		var e = idmapdb.mappings[i];
-		printf("%s -> ", e.sid);
+	for e in idmapdb.mappings:
+		print "%s -> " % e.sid
 
-		if (e.type == e.IDMAP_GROUP) { 
-			printf("GID %d\n", e.unix_id);
-		} else {
-			printf("UID %d\n", e.unix_id);
-		}
-	}
-}
+		if e.type == e.IDMAP_GROUP:
+			print "GID %d\n" % e.unix_id
+		else:
+			print "UID %d\n" % e.unix_id
 
-function print_samba3(samba3)
-{
-	print_samba3_sam(samba3);
-	print_samba3_policy(samba3.policy);
-	print_samba3_shares(samba3);
-	print_samba3_winsdb(samba3);
-	print_samba3_regdb(samba3.registry);
-	print_samba3_secrets(samba3.secrets);
-	print_samba3_groupmappings(samba3);
-	print_samba3_aliases(samba3);
-	print_samba3_idmapdb(samba3.idmapdb);
-}
+def print_samba3(samba3):
+	print_samba3_sam(samba3)
+	print_samba3_policy(samba3.policy)
+	print_samba3_shares(samba3)
+	print_samba3_winsdb(samba3)
+	print_samba3_regdb(samba3.registry)
+	print_samba3_secrets(samba3.secrets)
+	print_samba3_groupmappings(samba3)
+	print_samba3_aliases(samba3)
+	print_samba3_idmapdb(samba3.idmapdb)
 
-function print_samba3_summary(samba3)
-{
-	printf("WINS db entries: %d\n", samba3.winsentries.length);
-	printf("SAM Accounts: %d\n", samba3.samaccounts.length);
-	printf("Registry key count: %d\n", samba3.registry.keys.length);
-	printf("Shares (including [global]): %d\n", samba3.shares.length);
-	printf("Groupmap count: %d\n", samba3.groupmappings.length);
-	printf("Alias count: %d\n", samba3.aliases.length);
-	printf("Idmap count: %d\n", samba3.idmapdb.mappings.length);
-}
+def print_samba3_summary(samba3):
+	print "WINS db entries: %d\n" % samba3.winsentries.length
+	print "SAM Accounts: %d\n" % samba3.samaccounts.length
+	print "Registry key count: %d\n" % samba3.registry.keys.length
+	print "Shares (including [global]): %d\n" % samba3.shares.length
+	print "Groupmap count: %d\n" % samba3.groupmappings.length
+	print "Alias count: %d\n" % samba3.aliases.length
+	print "Idmap count: %d\n" %samba3.idmapdb.mappings.length
 
-samba3 = samba3_read(options.ARGV[0], options.ARGV[1]);
+samba3 = samba3_read(args[0], args[1])
 
-if (options.format == "summary") {
-	print_samba3_summary(samba3);
-} else if (options.format == "full") {
-	print_samba3(samba3);
-}
-
-return 0;
+if opts.format == "summary":
+	print_samba3_summary(samba3)
+elif opts.format == "full":
+	print_samba3(samba3)



More information about the samba-cvs mailing list