[pkg-eucalyptus-commits] [euca2ools] 10/41: Implement ModifySnapshotAttribute

Charles Plessy plessy at alioth.debian.org
Sat Oct 12 03:24:12 UTC 2013


This is an automated email from the git hooks/post-receive script.

plessy pushed a commit to branch master
in repository euca2ools.

commit beaef04b4f4118eb788788fa6cc6b30cde1e296f
Author: Garrett Holmstrom <gholms at fedoraproject.org>
Date:   Tue Jul 9 16:38:46 2013 -0700

    Implement ModifySnapshotAttribute
    
    Fixes TOOLS-179
---
 bin/euca-modify-snapshot-attribute                 |    6 ++
 euca2ools/commands/euca/modifysnapshotattribute.py |   83 ++++++++++++++++++++
 man/euca-modify-snapshot-attribute.1               |   54 +++++++++++++
 3 files changed, 143 insertions(+)

diff --git a/bin/euca-modify-snapshot-attribute b/bin/euca-modify-snapshot-attribute
new file mode 100755
index 0000000..b61063a
--- /dev/null
+++ b/bin/euca-modify-snapshot-attribute
@@ -0,0 +1,6 @@
+#!/usr/bin/python -tt
+
+import euca2ools.commands.euca.modifysnapshotattribute
+
+if __name__ == '__main__':
+    euca2ools.commands.euca.modifysnapshotattribute.ModifySnapshotAttribute.run()
diff --git a/euca2ools/commands/euca/modifysnapshotattribute.py b/euca2ools/commands/euca/modifysnapshotattribute.py
new file mode 100644
index 0000000..1d30e72
--- /dev/null
+++ b/euca2ools/commands/euca/modifysnapshotattribute.py
@@ -0,0 +1,83 @@
+# Copyright 2013 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 euca2ools.commands.euca import EucalyptusRequest
+from requestbuilder import Arg
+from requestbuilder.exceptions import ArgumentError
+
+
+class ModifySnapshotAttribute(EucalyptusRequest):
+    DESCRIPTION = 'Modify an attribute of a snapshot'
+    ARGS = [Arg('SnapshotId', metavar='SNAPSHOT',
+                help='ID of the snapshot to modify'),
+            Arg('-c', '--create-volume-permission', action='store_true',
+                required=True,
+                help='grant/revoke volume creation permission with -a/-r'),
+            Arg('-a', '--add', metavar='ENTITY', action='append', default=[],
+                route_to=None,
+                help='account to grant permission, or "all" for all accounts'),
+            Arg('-r', '--remove', metavar='ENTITY', action='append',
+                default=[], route_to=None, help='''account to remove permission
+                from, or "all" for all accounts''')]
+
+    def preprocess(self):
+        if self.args.get('create_volume_permission'):
+            cvperm = {}
+            for entity in self.args.get('add', []):
+                cvperm.setdefault('Add', [])
+                if entity == 'all':
+                    cvperm['Add'].append({'Group':  entity})
+                else:
+                    cvperm['Add'].append({'UserId': entity})
+            for entity in self.args.get('remove', []):
+                cvperm.setdefault('Remove', [])
+                if entity == 'all':
+                    cvperm['Remove'].append({'Group':  entity})
+                else:
+                    cvperm['Remove'].append({'UserId': entity})
+            if not cvperm:
+                raise ArgumentError('at least one entity must be specified '
+                                    'with -a/--add or -r/--remove')
+            self.params['CreateVolumePermission'] = cvperm
+        else:
+            if self.args.get('add'):
+                raise ArgumentError('argument -a/--add may only be used '
+                                    'with -c/--create-volume-permission')
+            if self.args.get('remove'):
+                raise ArgumentError('argument -r/--remove may only be used '
+                                    'with -c/--create-volume-permission')
+
+    def print_result(self, result):
+        if self.args.get('create_volume_permission'):
+            for add in self.params['CreateVolumePermission'].get('Add', []):
+                for (entity_type, entity_name) in add.items():
+                    print self.tabify(('createVolumePermission',
+                                       self.args['SnapshotId'], 'ADD',
+                                       entity_type, entity_name))
+            for add in self.params['CreateVolumePermission'].get('Remove', []):
+                for (entity_type, entity_name) in add.items():
+                    print self.tabify(('createVolumePermission',
+                                       self.args['SnapshotId'], 'REMOVE',
+                                       entity_type, entity_name))
diff --git a/man/euca-modify-snapshot-attribute.1 b/man/euca-modify-snapshot-attribute.1
new file mode 100644
index 0000000..b28cce1
--- /dev/null
+++ b/man/euca-modify-snapshot-attribute.1
@@ -0,0 +1,54 @@
+.\" DO NOT MODIFY THIS FILE!  It was generated by help2man 1.41.2.
+.TH EUCA-MODIFY-SNAPSHOT-ATTRIBUTE "1" "July 2013" "euca2ools 3.0.0" "User Commands"
+.SH NAME
+euca-modify-snapshot-attribute \- Modify an attribute of a snapshot
+.SH SYNOPSIS
+euca\-modify\-snapshot\-attribute \fB\-c\fR [\-a ENTITY] [\-r ENTITY]
+[\-\-show\-empty\-fields]
+[\-\-region USER at REGION | \fB\-U\fR URL]
+[\-I KEY_ID] [\-S KEY] [\-\-debug]
+[\-\-debugger] [\-\-version] [\-h]
+SNAPSHOT
+.SH DESCRIPTION
+Modify an attribute of a snapshot
+.SS "positional arguments:"
+.TP
+SNAPSHOT
+ID of the snapshot to modify
+.SS "optional arguments:"
+.TP
+\fB\-c\fR, \fB\-\-create\-volume\-permission\fR
+grant/revoke volume creation permission with \fB\-a\fR/\-r
+.TP
+\fB\-a\fR ENTITY, \fB\-\-add\fR ENTITY
+account to grant permission, or "all" for all accounts
+.TP
+\fB\-r\fR ENTITY, \fB\-\-remove\fR ENTITY
+account to remove permission from, or "all" for all
+accounts
+.TP
+\fB\-\-show\-empty\-fields\fR
+show empty values as "(nil)"
+.TP
+\fB\-\-region\fR USER at REGION
+name of the region and/or user in config files to use
+to connect to the service
+.TP
+\fB\-U\fR URL, \fB\-\-url\fR URL
+compute service endpoint URL
+.HP
+\fB\-I\fR KEY_ID, \fB\-\-access\-key\-id\fR KEY_ID
+.HP
+\fB\-S\fR KEY, \fB\-\-secret\-key\fR KEY
+.TP
+\fB\-\-debug\fR
+show debugging output
+.TP
+\fB\-\-debugger\fR
+launch interactive debugger on error
+.TP
+\fB\-\-version\fR
+show the program's version and exit
+.TP
+\fB\-h\fR, \fB\-\-help\fR
+show this help message and exit

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-eucalyptus/euca2ools.git



More information about the pkg-eucalyptus-commits mailing list