Index: boto/ec2/autoscale/policy.py |
diff --git a/boto/ec2/autoscale/policy.py b/boto/ec2/autoscale/policy.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..d9d1ac656703d3e77fe02d8645cdd9c559035df5 |
--- /dev/null |
+++ b/boto/ec2/autoscale/policy.py |
@@ -0,0 +1,155 @@ |
+# Copyright (c) 2009-2010 Reza Lotun http://reza.lotun.name/ |
+# Copyright (c) 2011 Jann Kleen |
+# |
+# 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.resultset import ResultSet |
+from boto.ec2.elb.listelement import ListElement |
+ |
+class Alarm(object): |
+ def __init__(self, connection=None): |
+ self.connection = connection |
+ self.name = None |
+ self.alarm_arn = None |
+ |
+ def __repr__(self): |
+ return 'Alarm:%s' % self.name |
+ |
+ def startElement(self, name, attrs, connection): |
+ return None |
+ |
+ def endElement(self, name, value, connection): |
+ if name == 'AlarmName': |
+ self.name = value |
+ elif name == 'AlarmARN': |
+ self.alarm_arn = value |
+ else: |
+ setattr(self, name, value) |
+ |
+ |
+class AdjustmentType(object): |
+ def __init__(self, connection=None): |
+ self.connection = connection |
+ self.adjustment_types = ListElement([]) |
+ |
+ def __repr__(self): |
+ return 'AdjustmentType:%s' % self.adjustment_types |
+ |
+ def startElement(self, name, attrs, connection): |
+ if name == 'AdjustmentType': |
+ return self.adjustment_types |
+ |
+ def endElement(self, name, value, connection): |
+ return |
+ |
+ |
+class MetricCollectionTypes(object): |
+ class BaseType(object): |
+ arg = '' |
+ def __init__(self, connection): |
+ self.connection = connection |
+ self.val = None |
+ def __repr__(self): |
+ return '%s:%s' % (self.arg, self.val) |
+ def startElement(self, name, attrs, connection): |
+ return |
+ def endElement(self, name, value, connection): |
+ if name == self.arg: |
+ self.val = value |
+ class Metric(BaseType): |
+ arg = 'Metric' |
+ class Granularity(BaseType): |
+ arg = 'Granularity' |
+ |
+ def __init__(self, connection=None): |
+ self.connection = connection |
+ self.metrics = [] |
+ self.granularities = [] |
+ |
+ def __repr__(self): |
+ return 'MetricCollectionTypes:<%s, %s>' % (self.metrics, self.granularities) |
+ |
+ def startElement(self, name, attrs, connection): |
+ if name == 'Granularities': |
+ self.granularities = ResultSet([('member', self.Granularity)]) |
+ return self.granularities |
+ elif name == 'Metrics': |
+ self.metrics = ResultSet([('member', self.Metric)]) |
+ return self.metrics |
+ |
+ def endElement(self, name, value, connection): |
+ return |
+ |
+ |
+class ScalingPolicy(object): |
+ def __init__(self, connection=None, **kwargs): |
+ """ |
+ Scaling Policy |
+ |
+ :type name: str |
+ :param name: Name of scaling policy. |
+ |
+ :type adjustment_type: str |
+ :param adjustment_type: Specifies the type of adjustment. Valid values are `ChangeInCapacity`, `ExactCapacity` and `PercentChangeInCapacity`. |
+ |
+ :type as_name: str or int |
+ :param as_name: Name or ARN of the Auto Scaling Group. |
+ |
+ :type scaling_adjustment: int |
+ :param scaling_adjustment: Value of adjustment (type specified in `adjustment_type`). |
+ |
+ :type cooldown: int |
+ :param cooldown: Time (in seconds) before Alarm related Scaling Activities can start after the previous Scaling Activity ends. |
+ |
+ """ |
+ self.name = kwargs.get('name', None) |
+ self.adjustment_type = kwargs.get('adjustment_type', None) |
+ self.as_name = kwargs.get('as_name', None) |
+ self.scaling_adjustment = kwargs.get('scaling_adjustment', None) |
+ self.cooldown = kwargs.get('cooldown', None) |
+ self.connection = connection |
+ |
+ def __repr__(self): |
+ return 'ScalingPolicy(%s group:%s adjustment:%s)' % (self.name, |
+ self.as_name, |
+ self.adjustment_type) |
+ |
+ def startElement(self, name, attrs, connection): |
+ if name == 'Alarms': |
+ self.alarms = ResultSet([('member', Alarm)]) |
+ return self.alarms |
+ |
+ def endElement(self, name, value, connection): |
+ if name == 'PolicyName': |
+ self.name = value |
+ elif name == 'AutoScalingGroupName': |
+ self.as_name = value |
+ elif name == 'PolicyARN': |
+ self.policy_arn = value |
+ elif name == 'ScalingAdjustment': |
+ self.scaling_adjustment = int(value) |
+ elif name == 'Cooldown': |
+ self.cooldown = int(value) |
+ elif name == 'AdjustmentType': |
+ self.adjustment_type = value |
+ |
+ def delete(self): |
+ return self.connection.delete_policy(self.name, self.as_name) |
+ |