Skip to content

Commit

Permalink
netcmd: domain: move keytab command to domain/keytab.py
Browse files Browse the repository at this point in the history
Signed-off-by: Rob van der Linde <[email protected]>
Reviewed-by: Douglas Bagnall <[email protected]>
Reviewed-by: Andrew Bartlett <[email protected]>
  • Loading branch information
robvdl authored and abartlet committed Mar 31, 2023
1 parent 8001e07 commit 12d5ea7
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 29 deletions.
30 changes: 1 addition & 29 deletions python/samba/netcmd/domain/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,6 @@
from samba import werror
from getpass import getpass
from samba.net import Net, LIBNET_JOIN_AUTOMATIC
from samba import enable_net_export_keytab
import samba.ntacls
from samba.auth import system_session
from samba.samdb import SamDB, get_default_backend_store
Expand Down Expand Up @@ -106,6 +105,7 @@
from .functional_prep import cmd_domain_functional_prep
from .info import cmd_domain_info
from .join import cmd_domain_join
from .keytab import cmd_domain_export_keytab


def level_to_string(level):
Expand All @@ -126,34 +126,6 @@ def level_to_string(level):
return strings.get(level, "higher than 2016")


try:
enable_net_export_keytab()
except ImportError:
cmd_domain_export_keytab = None
else:
class cmd_domain_export_keytab(Command):
"""Dump Kerberos keys of the domain into a keytab."""

synopsis = "%prog <keytab> [options]"

takes_optiongroups = {
"sambaopts": options.SambaOptions,
"credopts": options.CredentialsOptions,
"versionopts": options.VersionOptions,
}

takes_options = [
Option("--principal", help="extract only this principal", type=str),
]

takes_args = ["keytab"]

def run(self, keytab, credopts=None, sambaopts=None, versionopts=None, principal=None):
lp = sambaopts.get_loadparm()
net = Net(None, lp)
net.export_keytab(keytab=keytab, principal=principal)


class cmd_domain_provision(Command):
"""Provision a domain."""

Expand Down
55 changes: 55 additions & 0 deletions python/samba/netcmd/domain/keytab.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
# domain management - domain keytab
#
# Copyright Matthias Dieter Wallnoefer 2009
# Copyright Andrew Kroeger 2009
# Copyright Jelmer Vernooij 2007-2012
# Copyright Giampaolo Lauria 2011
# Copyright Matthieu Patou <[email protected]> 2011
# Copyright Andrew Bartlett 2008-2015
# Copyright Stefan Metzmacher 2012
#
# 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 samba.getopt as options
from samba import enable_net_export_keytab
from samba.net import Net
from samba.netcmd import Command, Option

try:
enable_net_export_keytab()
except ImportError:
cmd_domain_export_keytab = None
else:
class cmd_domain_export_keytab(Command):
"""Dump Kerberos keys of the domain into a keytab."""

synopsis = "%prog <keytab> [options]"

takes_optiongroups = {
"sambaopts": options.SambaOptions,
"credopts": options.CredentialsOptions,
"versionopts": options.VersionOptions,
}

takes_options = [
Option("--principal", help="extract only this principal", type=str),
]

takes_args = ["keytab"]

def run(self, keytab, credopts=None, sambaopts=None, versionopts=None, principal=None):
lp = sambaopts.get_loadparm()
net = Net(None, lp)
net.export_keytab(keytab=keytab, principal=principal)

0 comments on commit 12d5ea7

Please sign in to comment.