Add new RHEL7 logvol objects to master
[pykickstart.git] / pykickstart / commands / rootpw.py
blob6ad139f7439f8f2ed1ebf2585f5b5a9d369a353d
2 # Chris Lumens <clumens@redhat.com>
4 # Copyright 2005, 2006, 2007 Red Hat, Inc.
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.
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.
20 from pykickstart.base import KickstartCommand
21 from pykickstart.errors import KickstartValueError, formatErrorMsg
22 from pykickstart.options import KSOptionParser
24 import gettext
25 _ = lambda x: gettext.ldgettext("pykickstart", x)
27 class FC3_RootPw(KickstartCommand):
28 removedKeywords = KickstartCommand.removedKeywords
29 removedAttrs = KickstartCommand.removedAttrs
31 def __init__(self, writePriority=0, *args, **kwargs):
32 KickstartCommand.__init__(self, writePriority, *args, **kwargs)
33 self.op = self._getParser()
35 self.isCrypted = kwargs.get("isCrypted", False)
36 self.password = kwargs.get("password", "")
38 def _getArgsAsStr(self):
39 retval = ""
41 if self.isCrypted:
42 retval += " --iscrypted"
44 return retval
46 def __str__(self):
47 retval = KickstartCommand.__str__(self)
49 if self.password != "":
50 retval += "# Root password\nrootpw%s %s\n" % (self._getArgsAsStr(), self.password)
52 return retval
54 def _getParser(self):
55 op = KSOptionParser()
56 op.add_option("--iscrypted", dest="isCrypted", action="store_true",
57 default=False)
58 return op
60 def parse(self, args):
61 (opts, extra) = self.op.parse_args(args=args, lineno=self.lineno)
62 self._setToSelf(self.op, opts)
64 if len(extra) != 1:
65 raise KickstartValueError(formatErrorMsg(self.lineno, msg=_("A single argument is expected for the %s command") % "rootpw"))
67 self.password = extra[0]
68 return self
70 class F8_RootPw(FC3_RootPw):
71 removedKeywords = FC3_RootPw.removedKeywords
72 removedAttrs = FC3_RootPw.removedAttrs
74 def __init__(self, writePriority=0, *args, **kwargs):
75 FC3_RootPw.__init__(self, writePriority, *args, **kwargs)
76 self.lock = kwargs.get("lock", False)
78 def _getArgsAsStr(self):
79 retval = FC3_RootPw._getArgsAsStr(self)
81 if self.lock:
82 retval += " --lock"
84 if not self.isCrypted:
85 retval += " --plaintext"
87 return retval
89 def _getParser(self):
90 op = FC3_RootPw._getParser(self)
91 op.add_option("--lock", dest="lock", action="store_true", default=False)
92 op.add_option("--plaintext", dest="isCrypted", action="store_false")
93 return op
95 class F18_RootPw(F8_RootPw):
96 removedKeywords = F8_RootPw.removedKeywords
97 removedAttrs = F8_RootPw.removedAttrs
99 def __str__(self):
100 retval = F8_RootPw.__str__(self)
102 if not retval and self.lock:
103 retval = "#Root password\nrootpw --lock\n"
105 return retval
107 def parse(self, args):
108 (opts, extra) = self.op.parse_args(args=args, lineno=self.lineno)
109 self._setToSelf(self.op, opts)
111 if len(extra) != 1 and not self.lock:
112 raise KickstartValueError(formatErrorMsg(self.lineno, msg=_("A single argument is expected for the %s command") % "rootpw"))
114 if len(extra) == 1:
115 self.password = extra[0]
117 return self