# Copyright 2009-2014 Eucalyptus Systems, Inc. # # 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. from requestbuilder import Arg, MutuallyExclusiveArgList from requestbuilder.exceptions import ArgumentError from euca2ools.commands.ec2 import EC2Request class ModifyImageAttribute(EC2Request): DESCRIPTION = 'Modify an attribute of an image' ARGS = [Arg('ImageId', metavar='IMAGE', help='image to modify'), MutuallyExclusiveArgList( Arg('--description', dest='Description.Value', metavar='DESC', help="change the image's description"), Arg('-p', '--product-code', dest='ProductCode', metavar='CODE', action='append', help='''product code to add to the given instance-store image'''), Arg('-l', '--launch-permission', action='store_true', route_to=None, help='grant/revoke launch permissions with -a/-r')) .required(), Arg('-a', '--add', metavar='ENTITY', action='append', default=[], route_to=None, help='''account to grant launch permission, or "all" for all accounts'''), Arg('-r', '--remove', metavar='ENTITY', action='append', default=[], route_to=None, help='''account to remove launch permission from, or "all" for all accounts''')] # noinspection PyExceptionInherit def preprocess(self): if self.args.get('launch_permission'): lperm = {} for entity in self.args.get('add', []): lperm.setdefault('Add', []) if entity == 'all': lperm['Add'].append({'Group': entity}) else: lperm['Add'].append({'UserId': entity}) for entity in self.args.get('remove', []): lperm.setdefault('Remove', []) if entity == 'all': lperm['Remove'].append({'Group': entity}) else: lperm['Remove'].append({'UserId': entity}) if not lperm: raise ArgumentError('at least one entity must be specified ' 'with -a/--add or -r/--remove') self.params['LaunchPermission'] = lperm else: if self.args.get('add'): raise ArgumentError('argument -a/--add may only be used ' 'with -l/--launch-permission') if self.args.get('remove'): raise ArgumentError('argument -r/--remove may only be used ' 'with -l/--launch-permission') def print_result(self, _): if self.args.get('Description.Value'): print self.tabify(('description', self.args['ImageId'], None, self.args['Description.Value'])) if self.args.get('ProductCode'): for code in self.args['ProductCode']: print self.tabify(('productcodes', self.args['ImageId'], 'productCode', code)) if self.args.get('launch_permission'): for add in self.params['LaunchPermission'].get('Add', []): for (entity_type, entity_name) in add.items(): print self.tabify(('launchPermission', self.args['ImageId'], 'ADD', entity_type, entity_name)) for add in self.params['LaunchPermission'].get('Remove', []): for (entity_type, entity_name) in add.items(): print self.tabify(('launchPermission', self.args['ImageId'], 'REMOVE', entity_type, entity_name))