Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(201)

Unified Diff: third_party/gsutil/boto/boto/s3/cors.py

Issue 12317103: Added gsutil to depot tools (Closed) Base URL: https://chromium.googlesource.com/chromium/tools/depot_tools.git@master
Patch Set: Created 7 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « third_party/gsutil/boto/boto/s3/connection.py ('k') | third_party/gsutil/boto/boto/s3/deletemarker.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: third_party/gsutil/boto/boto/s3/cors.py
diff --git a/third_party/gsutil/boto/boto/s3/cors.py b/third_party/gsutil/boto/boto/s3/cors.py
new file mode 100644
index 0000000000000000000000000000000000000000..d97ee890aabe0701a387d54c161943b947f40b77
--- /dev/null
+++ b/third_party/gsutil/boto/boto/s3/cors.py
@@ -0,0 +1,210 @@
+# Copyright (c) 2012 Mitch Garnaat http://garnaat.org/
+# Copyright (c) 2012 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 CORSRule(object):
+ """
+ CORS rule for a bucket.
+
+ :ivar id: A unique identifier for the rule. The ID value can be
+ up to 255 characters long. The IDs help you find a rule in
+ the configuration.
+
+ :ivar allowed_methods: An HTTP method that you want to allow the
+ origin to execute. Each CORSRule must identify at least one
+ origin and one method. Valid values are:
+ GET|PUT|HEAD|POST|DELETE
+
+ :ivar allowed_origin: An origin that you want to allow cross-domain
+ requests from. This can contain at most one * wild character.
+ Each CORSRule must identify at least one origin and one method.
+ The origin value can include at most one '*' wild character.
+ For example, "http://*.example.com". You can also specify
+ only * as the origin value allowing all origins cross-domain access.
+
+ :ivar allowed_header: Specifies which headers are allowed in a
+ pre-flight OPTIONS request via the
+ Access-Control-Request-Headers header. Each header name
+ specified in the Access-Control-Request-Headers header must
+ have a corresponding entry in the rule. Amazon S3 will send
+ only the allowed headers in a response that were requested.
+ This can contain at most one * wild character.
+
+ :ivar max_age_seconds: The time in seconds that your browser is to
+ cache the preflight response for the specified resource.
+
+ :ivar expose_header: One or more headers in the response that you
+ want customers to be able to access from their applications
+ (for example, from a JavaScript XMLHttpRequest object). You
+ add one ExposeHeader element in the rule for each header.
+ """
+
+ def __init__(self, allowed_method=None, allowed_origin=None,
+ id=None, allowed_header=None, max_age_seconds=None,
+ expose_header=None):
+ if allowed_method is None:
+ allowed_method = []
+ self.allowed_method = allowed_method
+ if allowed_origin is None:
+ allowed_origin = []
+ self.allowed_origin = allowed_origin
+ self.id = id
+ if allowed_header is None:
+ allowed_header = []
+ self.allowed_header = allowed_header
+ self.max_age_seconds = max_age_seconds
+ if expose_header is None:
+ expose_header = []
+ self.expose_header = expose_header
+
+ def __repr__(self):
+ return '<Rule: %s>' % self.id
+
+ def startElement(self, name, attrs, connection):
+ return None
+
+ def endElement(self, name, value, connection):
+ if name == 'ID':
+ self.id = value
+ elif name == 'AllowedMethod':
+ self.allowed_method.append(value)
+ elif name == 'AllowedOrigin':
+ self.allowed_origin.append(value)
+ elif name == 'AllowedHeader':
+ self.allowed_header.append(value)
+ elif name == 'MaxAgeSeconds':
+ self.max_age_seconds = int(value)
+ elif name == 'ExposeHeader':
+ self.expose_header.append(value)
+ else:
+ setattr(self, name, value)
+
+ def to_xml(self):
+ s = '<CORSRule>'
+ for allowed_method in self.allowed_method:
+ s += '<AllowedMethod>%s</AllowedMethod>' % allowed_method
+ for allowed_origin in self.allowed_origin:
+ s += '<AllowedOrigin>%s</AllowedOrigin>' % allowed_origin
+ for allowed_header in self.allowed_header:
+ s += '<AllowedHeader>%s</AllowedHeader>' % allowed_header
+ for expose_header in self.expose_header:
+ s += '<ExposeHeader>%s</ExposeHeader>' % expose_header
+ if self.max_age_seconds:
+ s += '<MaxAgeSeconds>%d</MaxAgeSeconds>' % self.max_age_seconds
+ if self.id:
+ s += '<ID>%s</ID>' % self.id
+ s += '</CORSRule>'
+ return s
+
+
+class CORSConfiguration(list):
+ """
+ A container for the rules associated with a CORS configuration.
+ """
+
+ def startElement(self, name, attrs, connection):
+ if name == 'CORSRule':
+ rule = CORSRule()
+ self.append(rule)
+ return rule
+ return None
+
+ def endElement(self, name, value, connection):
+ setattr(self, name, value)
+
+ def to_xml(self):
+ """
+ Returns a string containing the XML version of the Lifecycle
+ configuration as defined by S3.
+ """
+ s = '<CORSConfiguration>'
+ for rule in self:
+ s += rule.to_xml()
+ s += '</CORSConfiguration>'
+ return s
+
+ def add_rule(self, allowed_method, allowed_origin,
+ id=None, allowed_header=None, max_age_seconds=None,
+ expose_header=None):
+ """
+ Add a rule to this CORS configuration. This only adds
+ the rule to the local copy. To install the new rule(s) on
+ the bucket, you need to pass this CORS config object
+ to the set_cors method of the Bucket object.
+
+ :type allowed_methods: list of str
+ :param allowed_methods: An HTTP method that you want to allow the
+ origin to execute. Each CORSRule must identify at least one
+ origin and one method. Valid values are:
+ GET|PUT|HEAD|POST|DELETE
+
+ :type allowed_origin: list of str
+ :param allowed_origin: An origin that you want to allow cross-domain
+ requests from. This can contain at most one * wild character.
+ Each CORSRule must identify at least one origin and one method.
+ The origin value can include at most one '*' wild character.
+ For example, "http://*.example.com". You can also specify
+ only * as the origin value allowing all origins
+ cross-domain access.
+
+ :type id: str
+ :param id: A unique identifier for the rule. The ID value can be
+ up to 255 characters long. The IDs help you find a rule in
+ the configuration.
+
+ :type allowed_header: list of str
+ :param allowed_header: Specifies which headers are allowed in a
+ pre-flight OPTIONS request via the
+ Access-Control-Request-Headers header. Each header name
+ specified in the Access-Control-Request-Headers header must
+ have a corresponding entry in the rule. Amazon S3 will send
+ only the allowed headers in a response that were requested.
+ This can contain at most one * wild character.
+
+ :type max_age_seconds: int
+ :param max_age_seconds: The time in seconds that your browser is to
+ cache the preflight response for the specified resource.
+
+ :type expose_header: list of str
+ :param expose_header: One or more headers in the response that you
+ want customers to be able to access from their applications
+ (for example, from a JavaScript XMLHttpRequest object). You
+ add one ExposeHeader element in the rule for each header.
+ """
+ if not isinstance(allowed_method, (list, tuple)):
+ allowed_method = [allowed_method]
+ if not isinstance(allowed_origin, (list, tuple)):
+ allowed_origin = [allowed_origin]
+ if not isinstance(allowed_origin, (list, tuple)):
+ if allowed_origin is None:
+ allowed_origin = []
+ else:
+ allowed_origin = [allowed_origin]
+ if not isinstance(expose_header, (list, tuple)):
+ if expose_header is None:
+ expose_header = []
+ else:
+ expose_header = [expose_header]
+ rule = CORSRule(allowed_method, allowed_origin, id, allowed_header,
+ max_age_seconds, expose_header)
+ self.append(rule)
« no previous file with comments | « third_party/gsutil/boto/boto/s3/connection.py ('k') | third_party/gsutil/boto/boto/s3/deletemarker.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698