diff options
author | Matthieu Patou <mat@matws.net> | 2011-11-02 13:32:33 +0100 |
---|---|---|
committer | Matthieu Patou <mat@samba.org> | 2011-11-02 15:14:31 +0100 |
commit | dfd341a2fdd017a0e3248327a129a2a5c41e2636 (patch) | |
tree | ba311daf65b9622c2f54d04a166ed9936a9a8a51 /source4/scripting/python/samba/netcmd/sites.py | |
parent | 37703892bd59637db129bf1342e34be83c77cebe (diff) | |
download | samba-dfd341a2fdd017a0e3248327a129a2a5c41e2636.tar.gz samba-dfd341a2fdd017a0e3248327a129a2a5c41e2636.tar.xz samba-dfd341a2fdd017a0e3248327a129a2a5c41e2636.zip |
samba-tool: add subcommand for sites manipulation
Autobuild-User: Matthieu Patou <mat@samba.org>
Autobuild-Date: Wed Nov 2 15:14:32 CET 2011 on sn-devel-104
Diffstat (limited to 'source4/scripting/python/samba/netcmd/sites.py')
-rw-r--r-- | source4/scripting/python/samba/netcmd/sites.py | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/source4/scripting/python/samba/netcmd/sites.py b/source4/scripting/python/samba/netcmd/sites.py new file mode 100644 index 00000000000..a63b52442e2 --- /dev/null +++ b/source4/scripting/python/samba/netcmd/sites.py @@ -0,0 +1,96 @@ + +#!/usr/bin/env python +# +# sites management +# +# Copyright Matthieu Patou <mat@matws.net> 2011 +# +# 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/>. +# + + + +import os +from samba import sites +from samba import Ldb +from samba.auth import system_session +from samba.netcmd import ( + Command, + CommandError, + SuperCommand + ) + + +class cmd_sites_create(Command): + """Create a new site""" + + synopsis = "%prog <site> [options]" + + takes_args = ["sitename"] + + def run(self, sitename, sambaopts=None, credopts=None, versionopts=None): + lp = sambaopts.get_loadparm() + creds = credopts.get_credentials(lp, fallback_machine=True) + name = "sam.ldb" + path = lp.get("private dir") + url = os.path.join(path, name) + if not os.path.exists(url): + raise CommandError("secret database not found at %s " % url) + samdb = Ldb(url=url, session_info=system_session(), + credentials=creds, lp=lp) + + samdb.transaction_start() + ok = sites.create_site(samdb, samdb.get_config_basedn(), sitename) + samdb.transaction_commit() + + if not ok: + raise CommandError("Error while creating site %s" % sitename) + + self.outf.write("Site %s created !\n" % sitename) + +class cmd_sites_delete(Command): + """Delete a new site""" + + synopsis = "%prog <site> [options]" + + takes_args = ["sitename"] + + def run(self, sitename, sambaopts=None, credopts=None, versionopts=None): + lp = sambaopts.get_loadparm() + creds = credopts.get_credentials(lp, fallback_machine=True) + name = "sam.ldb" + path = lp.get("private dir") + url = os.path.join(path, name) + if not os.path.exists(url): + raise CommandError("secret database not found at %s " % url) + samdb = Ldb(url=url, session_info=system_session(), + credentials=creds, lp=lp) + + samdb.transaction_start() + ok = sites.delete_site(samdb, samdb.get_config_basedn(), sitename) + samdb.transaction_commit() + + if not ok: + raise CommandError("Error while creating site %s" % sitename) + + self.outf.write("Site %s removed!\n" % sitename) + + + +class cmd_sites(SuperCommand): + """Sites management""" + + subcommands = {} + subcommands["create"] = cmd_sites_create() + subcommands["remove"] = cmd_sites_delete() |