The `boto` library (long ago superseded by `boto3`) has not had an official release in over two years or even a commit in the last 18 months. Importing the package (or indirectly importing it by via `moto`) generates a deprecation warning. Additionally, an ever-increasing number of `moto` users who have left `boto` behind for `boto3` are still being forced to install `boto`. This commit vendors a very small subset of the `boto` library--only the code required by `moto` to run--into the /packages subdirectory. A README file is included explaining the origin of the files and a recommendation for how they can be removed entirely in a future release. NOTE: Users of `boto` will still be able to use `moto` after this is merged. closes #2978 closes #3013 closes #3170 closes #3418 relates to #2950
85 lines
3.8 KiB
Python
85 lines
3.8 KiB
Python
# Copyright (c) 2006-2010 Mitch Garnaat http://garnaat.org/
|
|
# Copyright (c) 2010, Eucalyptus Systems, Inc.
|
|
#
|
|
# 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.
|
|
|
|
"""
|
|
Represents an EC2 Spot Instance Request
|
|
"""
|
|
|
|
from moto.packages.boto.ec2.ec2object import TaggedEC2Object
|
|
|
|
|
|
class SpotInstanceRequest(TaggedEC2Object):
|
|
"""
|
|
|
|
:ivar id: The ID of the Spot Instance Request.
|
|
:ivar price: The maximum hourly price for any Spot Instance launched to
|
|
fulfill the request.
|
|
:ivar type: The Spot Instance request type.
|
|
:ivar state: The state of the Spot Instance request.
|
|
:ivar fault: The fault codes for the Spot Instance request, if any.
|
|
:ivar valid_from: The start date of the request. If this is a one-time
|
|
request, the request becomes active at this date and time and remains
|
|
active until all instances launch, the request expires, or the request is
|
|
canceled. If the request is persistent, the request becomes active at this
|
|
date and time and remains active until it expires or is canceled.
|
|
:ivar valid_until: The end date of the request. If this is a one-time
|
|
request, the request remains active until all instances launch, the request
|
|
is canceled, or this date is reached. If the request is persistent, it
|
|
remains active until it is canceled or this date is reached.
|
|
:ivar launch_group: The instance launch group. Launch groups are Spot
|
|
Instances that launch together and terminate together.
|
|
:ivar launched_availability_zone: foo
|
|
:ivar product_description: The Availability Zone in which the bid is
|
|
launched.
|
|
:ivar availability_zone_group: The Availability Zone group. If you specify
|
|
the same Availability Zone group for all Spot Instance requests, all Spot
|
|
Instances are launched in the same Availability Zone.
|
|
:ivar create_time: The time stamp when the Spot Instance request was
|
|
created.
|
|
:ivar launch_specification: Additional information for launching instances.
|
|
:ivar instance_id: The instance ID, if an instance has been launched to
|
|
fulfill the Spot Instance request.
|
|
:ivar status: The status code and status message describing the Spot
|
|
Instance request.
|
|
|
|
"""
|
|
|
|
def __init__(self, connection=None):
|
|
super(SpotInstanceRequest, self).__init__(connection)
|
|
self.id = None
|
|
self.price = None
|
|
self.type = None
|
|
self.state = None
|
|
self.fault = None
|
|
self.valid_from = None
|
|
self.valid_until = None
|
|
self.launch_group = None
|
|
self.launched_availability_zone = None
|
|
self.product_description = None
|
|
self.availability_zone_group = None
|
|
self.create_time = None
|
|
self.launch_specification = None
|
|
self.instance_id = None
|
|
self.status = None
|
|
|
|
def __repr__(self):
|
|
return "SpotInstanceRequest:%s" % self.id
|