1
0
Fork 0
mirror of https://github.com/fog/fog.git synced 2022-11-09 13:51:43 -05:00

Merge branch 'images_parsing_fix'

This commit is contained in:
geemus 2010-12-21 11:35:44 -08:00
commit 63ac4159d9
2 changed files with 35 additions and 34 deletions

View file

@ -23,6 +23,7 @@ module Fog
attribute :root_device_type, :aliases => 'rootDeviceType'
attribute :root_device_name, :aliases => 'rootDeviceName'
attribute :tags, :aliases => 'tagSet'
attribute :name
def deregister(delete_snapshot = false)
connection.deregister_image(id)

View file

@ -15,8 +15,6 @@ module Fog
def start_element(name, attrs = [])
super
case name
when 'productCodes'
@in_product_codes = true
when 'blockDeviceMapping'
@in_block_device_mapping = true
when 'tagSet'
@ -25,13 +23,32 @@ module Fog
end
def end_element(name)
if @in_tag_set
case name
when 'item'
@image['tagSet'][@tag['key']] = @tag['value']
@tag = {}
when 'key', 'value'
@tag[name] = @value
when 'tagSet'
@in_tag_set = false
end
elsif @in_block_device_mapping
case name
when 'architecture', 'description', 'imageId', 'imageLocation', 'imageOwnerId', 'imageState', 'imageType', 'kernelId', 'platform', 'ramdiskId', 'rootDeviceType','rootDeviceName'
@image[name] = @value
when 'blockDeviceMapping'
@in_block_device_mapping = false
when 'deviceName', 'virtualName', 'snapshotId', 'deleteOnTermination'
@block_device_mapping[name] = @value
when 'volumeSize'
@block_device_mapping[name] = @value.to_i
when 'item'
@image['blockDeviceMapping'] << @block_device_mapping
@block_device_mapping = {}
end
else
case name
when 'name','requestId','architecture', 'description', 'imageId', 'imageLocation', 'imageOwnerId', 'imageState', 'imageType', 'kernelId', 'platform', 'ramdiskId', 'rootDeviceType','rootDeviceName','virtualizationType'
@image[name] = @value
when 'isPublic'
if @value == 'true'
@image[name] = true
@ -39,31 +56,14 @@ module Fog
@image[name] = false
end
when 'item'
if @in_block_device_mapping
@image['blockDeviceMapping'] << @block_device_mapping
@block_device_mapping = {}
elsif @in_tag_set
@image['tagSet'][@tag['key']] = @tag['value']
@tag = {}
elsif !@in_product_codes
@response['imagesSet'] << @image
@image = { 'blockDeviceMapping' => [], 'productCodes' => [], 'tagSet' => {} }
end
when 'key', 'value'
@tag[name] = @value
when 'productCode'
@image['productCodes'] << @value
when 'productCodes'
@in_product_codes = false
when 'requestId'
@response[name] = @value
when 'volumeSize'
@block_device_mapping[name] = @value.to_i
end
end
end
end
end
end
end