Index: third_party/gsutil/third_party/boto/boto/s3/__init__.py |
diff --git a/third_party/gsutil/third_party/boto/boto/s3/__init__.py b/third_party/gsutil/third_party/boto/boto/s3/__init__.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..b1994b9de122bece5e54b9e85fda8c5ae5bf5627 |
--- /dev/null |
+++ b/third_party/gsutil/third_party/boto/boto/s3/__init__.py |
@@ -0,0 +1,74 @@ |
+# Copyright (c) 2006-2012 Mitch Garnaat http://garnaat.org/ |
+# Copyright (c) 2010, Eucalyptus Systems, Inc. |
+# Copyright (c) 2014, Steven Richards <sbrichards@mit.edu> |
+# 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. |
+# |
+ |
+from boto.regioninfo import RegionInfo, get_regions |
+ |
+ |
+class S3RegionInfo(RegionInfo): |
+ |
+ def connect(self, **kw_params): |
+ """ |
+ Connect to this Region's endpoint. Returns an connection |
+ object pointing to the endpoint associated with this region. |
+ You may pass any of the arguments accepted by the connection |
+ class's constructor as keyword arguments and they will be |
+ passed along to the connection object. |
+ |
+ :rtype: Connection object |
+ :return: The connection to this regions endpoint |
+ """ |
+ if self.connection_cls: |
+ return self.connection_cls(host=self.endpoint, **kw_params) |
+ |
+ |
+def regions(): |
+ """ |
+ Get all available regions for the Amazon S3 service. |
+ |
+ :rtype: list |
+ :return: A list of :class:`boto.regioninfo.RegionInfo` |
+ """ |
+ from boto.s3.connection import S3Connection |
+ return get_regions( |
+ 's3', |
+ region_cls=S3RegionInfo, |
+ connection_cls=S3Connection |
+ ) |
+ |
+ |
+def connect_to_region(region_name, **kw_params): |
+ for region in regions(): |
+ if 'host' in kw_params.keys(): |
+ # Make sure the host specified is not nothing |
+ if kw_params['host'] not in ['', None]: |
+ region.endpoint = kw_params['host'] |
+ del kw_params['host'] |
+ return region.connect(**kw_params) |
+ # If it is nothing then remove it from kw_params and proceed with default |
+ else: |
+ del kw_params['host'] |
+ if region.name == region_name: |
+ return region.connect(**kw_params) |
+ return None |