summaryrefslogtreecommitdiffstats
path: root/scripts/lib/mic/3rdparty/pykickstart/commands/sshpw.py
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/lib/mic/3rdparty/pykickstart/commands/sshpw.py')
-rw-r--r--scripts/lib/mic/3rdparty/pykickstart/commands/sshpw.py105
1 files changed, 105 insertions, 0 deletions
diff --git a/scripts/lib/mic/3rdparty/pykickstart/commands/sshpw.py b/scripts/lib/mic/3rdparty/pykickstart/commands/sshpw.py
new file mode 100644
index 0000000000..e7867ebfb2
--- /dev/null
+++ b/scripts/lib/mic/3rdparty/pykickstart/commands/sshpw.py
@@ -0,0 +1,105 @@
1#
2# Peter Jones <pjones@redhat.com>
3#
4# Copyright 2009 Red Hat, Inc.
5#
6# This copyrighted material is made available to anyone wishing to use, modify,
7# copy, or redistribute it subject to the terms and conditions of the GNU
8# General Public License v.2. This program is distributed in the hope that it
9# will be useful, but WITHOUT ANY WARRANTY expressed or implied, including the
10# implied warranties of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
11# See the GNU General Public License for more details.
12#
13# You should have received a copy of the GNU General Public License along with
14# this program; if not, write to the Free Software Foundation, Inc., 51
15# Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. Any Red Hat
16# trademarks that are incorporated in the source code or documentation are not
17# subject to the GNU General Public License and may only be used or replicated
18# with the express permission of Red Hat, Inc.
19#
20from pykickstart.base import *
21from pykickstart.errors import *
22from pykickstart.options import *
23
24import gettext
25_ = lambda x: gettext.ldgettext("pykickstart", x)
26
27class F13_SshPwData(BaseData):
28 removedKeywords = BaseData.removedKeywords
29 removedAttrs = BaseData.removedAttrs
30
31 def __init__(self, *args, **kwargs):
32 BaseData.__init__(self, *args, **kwargs)
33 self.username = kwargs.get("username", None)
34 self.isCrypted = kwargs.get("isCrypted", False)
35 self.password = kwargs.get("password", "")
36 self.lock = kwargs.get("lock", False)
37
38 def __eq__(self, y):
39 return self.username == y.username
40
41 def __str__(self):
42 retval = BaseData.__str__(self)
43
44 retval += "sshpw"
45 retval += self._getArgsAsStr() + '\n'
46
47 return retval
48
49 def _getArgsAsStr(self):
50 retval = ""
51
52 retval += " --username=%s" % self.username
53 if self.lock:
54 retval += " --lock"
55 if self.isCrypted:
56 retval += " --iscrypted"
57 else:
58 retval += " --plaintext"
59
60 retval += " %s" % self.password
61 return retval
62
63class F13_SshPw(KickstartCommand):
64 removedKeywords = KickstartCommand.removedKeywords
65 removedAttrs = KickstartCommand.removedAttrs
66
67 def __init__(self, writePriority=0, *args, **kwargs):
68 KickstartCommand.__init__(self, writePriority, *args, **kwargs)
69 self.op = self._getParser()
70
71 self.sshUserList = kwargs.get("sshUserList", [])
72
73 def __str__(self):
74 retval = ""
75 for user in self.sshUserList:
76 retval += user.__str__()
77
78 return retval
79
80 def _getParser(self):
81 op = KSOptionParser()
82 op.add_option("--username", dest="username", required=True)
83 op.add_option("--iscrypted", dest="isCrypted", action="store_true",
84 default=False)
85 op.add_option("--plaintext", dest="isCrypted", action="store_false")
86 op.add_option("--lock", dest="lock", action="store_true", default=False)
87 return op
88
89 def parse(self, args):
90 ud = self.handler.SshPwData()
91 (opts, extra) = self.op.parse_args(args=args, lineno=self.lineno)
92 self._setToObj(self.op, opts, ud)
93 ud.lineno = self.lineno
94
95 if len(extra) != 1:
96 raise KickstartValueError, formatErrorMsg(self.lineno, msg=_("A single argument is expected for the %s command") % "sshpw")
97 ud.password = extra[0]
98
99 if ud in self.dataList():
100 warnings.warn(_("An ssh user with the name %s has already been defined.") % ud.name)
101
102 return ud
103
104 def dataList(self):
105 return self.sshUserList