3 # Copyright (c) 2011 Intel, Inc.
5 # This program is free software; you can redistribute it and/or modify it
6 # under the terms of the GNU General Public License as published by the Free
7 # Software Foundation; version 2 of the License
9 # This program is distributed in the hope that it will be useful, but
10 # WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
11 # or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 # You should have received a copy of the GNU General Public License along
15 # with this program; if not, write to the Free Software Foundation, Inc., 59
16 # Temple Place - Suite 330, Boston, MA 02111-1307, USA.
19 from optparse import SUPPRESS_HELP
21 from mic import configmgr, pluginmgr, msger
22 from mic.utils import cmdln, errors, rpmmisc
24 class Creator(cmdln.Cmdln):
25 """${name}: create an image
28 ${name} SUBCOMMAND [OPTS] [ARGS..]
34 name = 'mic create(cr)'
36 def __init__(self, *args, **kwargs):
37 cmdln.Cmdln.__init__(self, *args, **kwargs)
40 self.configmgr = configmgr.getConfigMgr()
43 self.pluginmgr = pluginmgr.PluginMgr()
44 self.plugincmds = self.pluginmgr.get_plugins('imager')
46 # mix-in do_subcmd interface
47 for subcmd, klass in self.plugincmds.iteritems():
48 if not hasattr(klass, 'do_create'):
49 msger.warning("Unsurpport subcmd: %s" % subcmd)
52 func = getattr(klass, 'do_create')
53 setattr(self.__class__, "do_"+subcmd, func)
55 def get_optparser(self):
56 optparser = cmdln.CmdlnOptionParser(self)
57 optparser.add_option('-d', '--debug', action='store_true', dest='debug', help=SUPPRESS_HELP)
58 optparser.add_option('-v', '--verbose', action='store_true', dest='verbose', help=SUPPRESS_HELP)
59 optparser.add_option('', '--logfile', type='string', dest='logfile', default=None, help='Path of logfile')
60 optparser.add_option('-c', '--config', type='string', dest='config', default=None, help='Specify config file for mic')
61 optparser.add_option('-k', '--cachedir', type='string', action='store', dest='cachedir', default=None, help='Cache directory to store the downloaded')
62 optparser.add_option('-o', '--outdir', type='string', action='store', dest='outdir', default=None, help='Output directory')
63 optparser.add_option('-A', '--arch', type='string', dest='arch', default=None, help='Specify repo architecture')
64 optparser.add_option('', '--release', type='string', dest='release', default=None, metavar='RID', help='Generate a release of RID with all neccessary files,when @BUILD_ID@ is contained in kickstart file, it will be replaced by RID')
65 optparser.add_option("", "--record-pkgs", type="string", dest="record_pkgs", default=None,
66 help='Record the info of installed packages, multiple values can be specified which joined by ",", valid values: "name", "content", "license"')
67 optparser.add_option('', '--pkgmgr', type='string', dest='pkgmgr', default=None, help='Specify backend package manager')
68 optparser.add_option('', '--local-pkgs-path', type='string', dest='local_pkgs_path', default=None, help='Path for local pkgs(rpms) to be installed')
71 def preoptparse(self, argv):
72 optparser = self.get_optparser()
79 if arg in ('-h', '--help'):
82 elif optparser.has_option(arg):
85 if optparser.get_option(arg).takes_value():
87 largs.append(argv.pop(0))
89 raise errors.Usage("%s option requires an argument" % arg)
92 if arg.startswith("--"):
94 opt = arg.split("=")[0]
97 elif arg.startswith("-") and len(arg) > 2:
102 if opt and optparser.has_option(opt):
109 def postoptparse(self):
110 if self.options.verbose:
111 msger.set_loglevel('verbose')
112 if self.options.debug:
113 msger.set_loglevel('debug')
115 if self.options.logfile:
116 msger.set_interactive(False)
117 msger.set_logfile(self.options.logfile)
119 if self.options.config:
120 self.configmgr.reset()
121 self.configmgr._siteconf = self.options.config
123 if self.options.outdir is not None:
124 self.configmgr.create['outdir'] = self.options.outdir
125 if self.options.cachedir is not None:
126 self.configmgr.create['cachedir'] = self.options.cachedir
127 if self.options.local_pkgs_path is not None:
128 self.configmgr.create['local_pkgs_path'] = self.options.local_pkgs_path
130 if self.options.release:
131 self.configmgr.create['release'] = self.options.release
133 if self.options.record_pkgs:
134 self.configmgr.create['record_pkgs'] = []
135 for infotype in self.options.record_pkgs.split(','):
136 if infotype not in ('name', 'content', 'license'):
137 raise errors.Usage('Invalid pkg recording: %s, valid ones: "name", "content", "license"' % infotype)
139 self.configmgr.create['record_pkgs'].append(infotype)
141 if self.options.arch is not None:
142 supported_arch = sorted(rpmmisc.archPolicies.keys(), reverse=True)
143 if self.options.arch in supported_arch:
144 self.configmgr.create['arch'] = self.options.arch
146 raise errors.Usage("Invalid architecture: %s.\nSupported architectures are: %s" % (self.options.arch, ','.join(supported_arch)))
148 if self.options.pkgmgr is not None:
149 self.configmgr.create['pkgmgr'] = self.options.pkgmgr
151 def main(self, argv=None):
155 argv = argv[:] # don't modify caller's list
157 self.optparser = self.get_optparser()
160 argv = self.preoptparse(argv)
161 self.options, args = self.optparser.parse_args(argv)
163 except cmdln.CmdlnUserError, ex:
164 msg = "%s: %s\nTry '%s help' for info.\n"\
165 % (self.name, ex, self.name)
168 except cmdln.StopOptionProcessing, ex:
171 # optparser=None means no process for opts
172 self.options, args = None, argv[1:]
177 return self.emptyline()
179 if os.geteuid() != 0:
180 msger.error('Root permission is required to continue, abort')
182 return self.cmd(args)