Index: third_party/gsutil/boto/dynamodb/schema.py |
diff --git a/third_party/gsutil/boto/dynamodb/schema.py b/third_party/gsutil/boto/dynamodb/schema.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..34ff212a1cc7db598663ed8a18d683a4d8a0d803 |
--- /dev/null |
+++ b/third_party/gsutil/boto/dynamodb/schema.py |
@@ -0,0 +1,74 @@ |
+# Copyright (c) 2011 Mitch Garnaat http://garnaat.org/ |
+# Copyright (c) 2011 Amazon.com, Inc. or its affiliates. All Rights Reserved |
+# |
+# Permission is hereby granted, free of charge, to any person obtaining a |
+# copy of this software and associated documentation files (the |
+# "Software"), to deal in the Software without restriction, including |
+# without limitation the rights to use, copy, modify, merge, publish, dis- |
+# tribute, sublicense, and/or sell copies of the Software, and to permit |
+# persons to whom the Software is furnished to do so, subject to the fol- |
+# lowing conditions: |
+# |
+# The above copyright notice and this permission notice shall be included |
+# in all copies or substantial portions of the Software. |
+# |
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
+# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL- |
+# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT |
+# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, |
+# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS |
+# IN THE SOFTWARE. |
+# |
+ |
+ |
+class Schema(object): |
+ """ |
+ Represents a DynamoDB schema. |
+ |
+ :ivar hash_key_name: The name of the hash key of the schema. |
+ :ivar hash_key_type: The DynamoDB type specification for the |
+ hash key of the schema. |
+ :ivar range_key_name: The name of the range key of the schema |
+ or None if no range key is defined. |
+ :ivar range_key_type: The DynamoDB type specification for the |
+ range key of the schema or None if no range key is defined. |
+ :ivar dict: The underlying Python dictionary that needs to be |
+ passed to Layer1 methods. |
+ """ |
+ |
+ def __init__(self, schema_dict): |
+ self._dict = schema_dict |
+ |
+ def __repr__(self): |
+ if self.range_key_name: |
+ s = 'Schema(%s:%s)' % (self.hash_key_name, self.range_key_name) |
+ else: |
+ s = 'Schema(%s)' % self.hash_key_name |
+ return s |
+ |
+ @property |
+ def dict(self): |
+ return self._dict |
+ |
+ @property |
+ def hash_key_name(self): |
+ return self._dict['HashKeyElement']['AttributeName'] |
+ |
+ @property |
+ def hash_key_type(self): |
+ return self._dict['HashKeyElement']['AttributeType'] |
+ |
+ @property |
+ def range_key_name(self): |
+ name = None |
+ if 'RangeKeyElement' in self._dict: |
+ name = self._dict['RangeKeyElement']['AttributeName'] |
+ return name |
+ |
+ @property |
+ def range_key_type(self): |
+ type = None |
+ if 'RangeKeyElement' in self._dict: |
+ type = self._dict['RangeKeyElement']['AttributeType'] |
+ return type |