Index: third_party/gsutil/boto/boto/ec2/elb/healthcheck.py |
diff --git a/third_party/gsutil/boto/boto/ec2/elb/healthcheck.py b/third_party/gsutil/boto/boto/ec2/elb/healthcheck.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..040f9623004fa25e5578cef298c338e52feb1389 |
--- /dev/null |
+++ b/third_party/gsutil/boto/boto/ec2/elb/healthcheck.py |
@@ -0,0 +1,89 @@ |
+# Copyright (c) 2006-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 HealthCheck(object): |
+ """ |
+ Represents an EC2 Access Point Health Check. See |
+ :ref:`elb-configuring-a-health-check` for a walkthrough on configuring |
+ load balancer health checks. |
+ """ |
+ def __init__(self, access_point=None, interval=30, target=None, |
+ healthy_threshold=3, timeout=5, unhealthy_threshold=5): |
+ """ |
+ :ivar str access_point: The name of the load balancer this |
+ health check is associated with. |
+ :ivar int interval: Specifies how many seconds there are between |
+ health checks. |
+ :ivar str target: Determines what to check on an instance. See the |
+ Amazon HealthCheck_ documentation for possible Target values. |
+ |
+ .. _HealthCheck: http://docs.amazonwebservices.com/ElasticLoadBalancing/latest/APIReference/API_HealthCheck.html |
+ """ |
+ self.access_point = access_point |
+ self.interval = interval |
+ self.target = target |
+ self.healthy_threshold = healthy_threshold |
+ self.timeout = timeout |
+ self.unhealthy_threshold = unhealthy_threshold |
+ |
+ def __repr__(self): |
+ return 'HealthCheck:%s' % self.target |
+ |
+ def startElement(self, name, attrs, connection): |
+ return None |
+ |
+ def endElement(self, name, value, connection): |
+ if name == 'Interval': |
+ self.interval = int(value) |
+ elif name == 'Target': |
+ self.target = value |
+ elif name == 'HealthyThreshold': |
+ self.healthy_threshold = int(value) |
+ elif name == 'Timeout': |
+ self.timeout = int(value) |
+ elif name == 'UnhealthyThreshold': |
+ self.unhealthy_threshold = int(value) |
+ else: |
+ setattr(self, name, value) |
+ |
+ def update(self): |
+ """ |
+ In the case where you have accessed an existing health check on a |
+ load balancer, this method applies this instance's health check |
+ values to the load balancer it is attached to. |
+ |
+ .. note:: This method will not do anything if the :py:attr:`access_point` |
+ attribute isn't set, as is the case with a newly instantiated |
+ HealthCheck instance. |
+ """ |
+ if not self.access_point: |
+ return |
+ |
+ new_hc = self.connection.configure_health_check(self.access_point, |
+ self) |
+ self.interval = new_hc.interval |
+ self.target = new_hc.target |
+ self.healthy_threshold = new_hc.healthy_threshold |
+ self.unhealthy_threshold = new_hc.unhealthy_threshold |
+ self.timeout = new_hc.timeout |