summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJelmer Vernooij <jelmer@samba.org>2008-08-01 21:12:37 +0200
committerJelmer Vernooij <jelmer@samba.org>2008-08-01 21:12:37 +0200
commit47124efe420f4f4f08494cbb2255eacdc9625c8d (patch)
tree9c7a83f327fbe2815803e67a50f48fa08eed6011
parent1c94f3e95da5b520ee631670a30f96e487f12ac8 (diff)
downloadsamba-47124efe420f4f4f08494cbb2255eacdc9625c8d.tar.gz
samba-47124efe420f4f4f08494cbb2255eacdc9625c8d.tar.bz2
samba-47124efe420f4f4f08494cbb2255eacdc9625c8d.zip
Add helper object Hostconfig to make it easier to get to e.g. the
SAM database. (This used to be commit be75b2a36ee49f66ada3ec3ababa82d74085d559)
-rw-r--r--source4/scripting/python/samba/getopt.py4
-rw-r--r--source4/scripting/python/samba/hostconfig.py33
-rwxr-xr-xsource4/setup/newuser5
3 files changed, 39 insertions, 3 deletions
diff --git a/source4/scripting/python/samba/getopt.py b/source4/scripting/python/samba/getopt.py
index 9ecb66e21c..c12245f6c5 100644
--- a/source4/scripting/python/samba/getopt.py
+++ b/source4/scripting/python/samba/getopt.py
@@ -21,6 +21,7 @@
import optparse
from credentials import Credentials, AUTO_USE_KERBEROS, DONT_USE_KERBEROS, MUST_USE_KERBEROS
+from hostconfig import Hostconfig
__docformat__ = "restructuredText"
@@ -52,6 +53,9 @@ class SambaOptions(optparse.OptionGroup):
lp.load_default()
return lp
+ def get_hostconfig(self):
+ return Hostconfig(self.get_loadparm())
+
class VersionOptions(optparse.OptionGroup):
"""Command line option for printing Samba version."""
diff --git a/source4/scripting/python/samba/hostconfig.py b/source4/scripting/python/samba/hostconfig.py
new file mode 100644
index 0000000000..313e3420b0
--- /dev/null
+++ b/source4/scripting/python/samba/hostconfig.py
@@ -0,0 +1,33 @@
+#!/usr/bin/python
+
+# Unix SMB/CIFS implementation.
+# Copyright (C) Jelmer Vernooij <jelmer@samba.org> 2008
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+from samdb import SamDB
+
+class Hostconfig(object):
+ """Aggregate object that contains all information about the configuration
+ of a Samba host."""
+
+ def __init__(self, lp):
+ self.lp = lp
+
+ def get_samdb(self, session_info, credentials):
+ return SamDB(url=self.lp.get("sam database"),
+ session_info=session_info, credentials=credentials,
+ lp=self.lp)
+
diff --git a/source4/setup/newuser b/source4/setup/newuser
index e6ab4eda2b..5b677af142 100755
--- a/source4/setup/newuser
+++ b/source4/setup/newuser
@@ -15,7 +15,6 @@ import samba.getopt as options
import optparse
from getpass import getpass
from samba.auth import system_session
-from samba.samdb import SamDB
parser = optparse.OptionParser("newuser [options] <username> [<password>]")
sambaopts = options.SambaOptions(parser)
@@ -44,6 +43,6 @@ if opts.unixname is None:
lp = sambaopts.get_loadparm()
creds = credopts.get_credentials(lp)
-samdb = SamDB(url=lp.get("sam database"), session_info=system_session(),
- credentials=creds, lp=lp)
+samdb = sambaopts.get_hostconfig().get_samdb(session_info=system_session(),
+ credentials=creds)
samdb.newuser(username, opts.unixname, password)