Add ability to create EBS volumes from snapshots. Closes #447.
This commit is contained in:
parent
d3e4c2c4b5
commit
cddf139bbc
3 changed files with 39 additions and 8 deletions
|
|
@ -1388,12 +1388,13 @@ class VolumeAttachment(object):
|
|||
|
||||
|
||||
class Volume(TaggedEC2Resource):
|
||||
def __init__(self, ec2_backend, volume_id, size, zone):
|
||||
def __init__(self, ec2_backend, volume_id, size, zone, snapshot_id=None):
|
||||
self.id = volume_id
|
||||
self.size = size
|
||||
self.zone = zone
|
||||
self.create_time = utc_date_and_time()
|
||||
self.attachment = None
|
||||
self.snapshot_id = snapshot_id
|
||||
self.ec2_backend = ec2_backend
|
||||
|
||||
@classmethod
|
||||
|
|
@ -1436,10 +1437,14 @@ class EBSBackend(object):
|
|||
self.snapshots = {}
|
||||
super(EBSBackend, self).__init__()
|
||||
|
||||
def create_volume(self, size, zone_name):
|
||||
def create_volume(self, size, zone_name, snapshot_id=None):
|
||||
volume_id = random_volume_id()
|
||||
zone = self.get_zone_by_name(zone_name)
|
||||
volume = Volume(self, volume_id, size, zone)
|
||||
if snapshot_id:
|
||||
snapshot = self.get_snapshot(snapshot_id)
|
||||
if size is None:
|
||||
size = snapshot.volume.size
|
||||
volume = Volume(self, volume_id, size, zone, snapshot_id)
|
||||
self.volumes[volume_id] = volume
|
||||
return volume
|
||||
|
||||
|
|
|
|||
|
|
@ -25,9 +25,10 @@ class ElasticBlockStore(BaseResponse):
|
|||
return template.render(snapshot=snapshot)
|
||||
|
||||
def create_volume(self):
|
||||
size = self.querystring.get('Size')[0]
|
||||
zone = self.querystring.get('AvailabilityZone')[0]
|
||||
volume = self.ec2_backend.create_volume(size, zone)
|
||||
size = self._get_param('Size')
|
||||
zone = self._get_param('AvailabilityZone')
|
||||
snapshot_id = self._get_param('SnapshotId')
|
||||
volume = self.ec2_backend.create_volume(size, zone, snapshot_id)
|
||||
template = self.response_template(CREATE_VOLUME_RESPONSE)
|
||||
return template.render(volume=volume)
|
||||
|
||||
|
|
@ -110,7 +111,11 @@ CREATE_VOLUME_RESPONSE = """<CreateVolumeResponse xmlns="http://ec2.amazonaws.co
|
|||
<requestId>59dbff89-35bd-4eac-99ed-be587EXAMPLE</requestId>
|
||||
<volumeId>{{ volume.id }}</volumeId>
|
||||
<size>{{ volume.size }}</size>
|
||||
<snapshotId/>
|
||||
{% if volume.snapshot_id %}
|
||||
<snapshotId>{{ volume.snapshot_id }}</snapshotId>
|
||||
{% else %}
|
||||
<snapshotId/>
|
||||
{% endif %}
|
||||
<availabilityZone>{{ volume.zone.name }}</availabilityZone>
|
||||
<status>creating</status>
|
||||
<createTime>{{ volume.create_time}}</createTime>
|
||||
|
|
@ -124,7 +129,11 @@ DESCRIBE_VOLUMES_RESPONSE = """<DescribeVolumesResponse xmlns="http://ec2.amazon
|
|||
<item>
|
||||
<volumeId>{{ volume.id }}</volumeId>
|
||||
<size>{{ volume.size }}</size>
|
||||
<snapshotId/>
|
||||
{% if volume.snapshot_id %}
|
||||
<snapshotId>{{ volume.snapshot_id }}</snapshotId>
|
||||
{% else %}
|
||||
<snapshotId/>
|
||||
{% endif %}
|
||||
<availabilityZone>{{ volume.zone.name }}</availabilityZone>
|
||||
<status>{{ volume.status }}</status>
|
||||
<createTime>{{ volume.create_time}}</createTime>
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue