[pkg-eucalyptus-commits] [SCM] managing cloud instances for Eucalyptus branch, master, updated. 3.0.0-alpha3-257-g1da8e3a
Garrett Holmstrom
gholms at fedoraproject.org
Sun Jun 16 02:29:52 UTC 2013
The following commit has been merged in the master branch:
commit 0f9cf1ccd61e048493d48d2d9227eeb92db485b4
Author: Garrett Holmstrom <gholms at fedoraproject.org>
Date: Wed May 2 23:17:50 2012 -0700
Rewrite CreateImage
diff --git a/bin/euca-create-image b/bin/euca-create-image
index 815d312..47eef6c 100755
--- a/bin/euca-create-image
+++ b/bin/euca-create-image
@@ -1,42 +1,6 @@
-#!/usr/bin/python
-# -*- coding: utf-8 -*-
-
-# Software License Agreement (BSD License)
-#
-# Copyright (c) 2009-2011, Eucalyptus Systems, Inc.
-# All rights reserved.
-#
-# Redistribution and use of this software in source and binary forms, with or
-# without modification, are permitted provided that the following conditions
-# are met:
-#
-# Redistributions of source code must retain the above
-# copyright notice, this list of conditions and the
-# following disclaimer.
-#
-# Redistributions in binary form must reproduce the above
-# copyright notice, this list of conditions and the
-# following disclaimer in the documentation and/or other
-# materials provided with the distribution.
-#
-# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
-# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
-# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
-# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
-# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
-# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
-# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
-# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
-# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
-# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
-# POSSIBILITY OF SUCH DAMAGE.
-#
-# Author: Neil Soman neil at eucalyptus.com
-# Mitch Garnaat mgarnaat at eucalyptus.com
+#!/usr/bin/python -tt
import euca2ools.commands.euca.createimage
if __name__ == '__main__':
- cmd = euca2ools.commands.euca.createimage.CreateImage()
- cmd.main_cli()
-
+ euca2ools.commands.euca.createimage.CreateImage().do_cli()
diff --git a/euca2ools/commands/euca/createimage.py b/euca2ools/commands/euca/createimage.py
index 6142403..01b2276 100644
--- a/euca2ools/commands/euca/createimage.py
+++ b/euca2ools/commands/euca/createimage.py
@@ -1,6 +1,6 @@
# Software License Agreement (BSD License)
#
-# Copyright (c) 2009-2011, Eucalyptus Systems, Inc.
+# Copyright (c) 2009-2012, Eucalyptus Systems, Inc.
# All rights reserved.
#
# Redistribution and use of this software in source and binary forms, with or
@@ -27,43 +27,22 @@
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
# POSSIBILITY OF SUCH DAMAGE.
-#
-# Author: Neil Soman neil at eucalyptus.com
-# Mitch Garnaat mgarnaat at eucalyptus.com
-
-import euca2ools.commands.eucacommand
-from boto.roboto.param import Param
-
-class CreateImage(euca2ools.commands.eucacommand.EucaCommand):
-
- Description = 'Creates an AMI from an EBS-based instance'
- Options = [Param(name='name', short_name='n', long_name='name',
- optional=False, ptype='string',
- doc='Name for the new image you are creating'),
- Param(name='description',
- short_name='d', long_name='description',
- optional=True, ptype='string',
- doc='A description of the new image'),
- Param(name='no_reboot', long_name='no-reboot',
- optional=True, ptype='boolean', default=False,
- doc="""When set to true, the instance is not shut
- down before creating the image. When this
- option is used, file system integrity on
- the created image cannot be guaranteed""")]
- Args = [Param(name='instance_id', ptype='string',
- optional=False,
- doc='ID of the instance')]
- def main(self):
- conn = self.make_connection_cli()
- return self.make_request_cli(conn, 'create_image',
- instance_id=self.instance_id,
- name=self.name,
- description=self.description,
- no_reboot=self.no_reboot)
+from requestbuilder import Arg
+from . import EucalyptusRequest
- def main_cli(self):
- image_id = self.main()
- if image_id:
- print 'IMAGE\t%s' % image_id
+class CreateImage(EucalyptusRequest):
+ Description = 'Create an EBS image from a running or stopped EBS instance'
+ Args = [Arg('InstanceId', metavar='INSTANCE',
+ help='instance from which to create the image'),
+ Arg('-n', '--name', dest='Name', required=True,
+ help='name for the new image (required)'),
+ Arg('-d', '--description', dest='Description', metavar='DESC',
+ help='description for the new image'),
+ Arg('--no-reboot', dest='NoReboot', action='store_const',
+ const='true',
+ help='''do not shut down the instance before creating the
+ image. Image integrity may be affected.''')]
+ def print_result(self, result):
+ print self.tabify(('IMAGE', result.get('imageId')))
--
managing cloud instances for Eucalyptus
More information about the pkg-eucalyptus-commits
mailing list