Class: Fog::Image::OpenStack::V2::Image
Instance Attribute Summary
#project
Instance Method Summary
collapse
#initialize, #save
Instance Method Details
#add_member(member_id) ⇒ Object
100
101
102
103
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 100
def add_member(member_id)
requires :id
service.add_member_to_image(self.id, member_id)
end
|
#add_tag(tag) ⇒ Object
130
131
132
133
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 130
def add_tag(tag)
requires :id
service.add_tag_to_image(self.id, tag)
end
|
125
126
127
128
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 125
def add_tags(tags)
requires :id
tags.each {|tag| add_tag tag}
end
|
#create ⇒ Object
43
44
45
46
47
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 43
def create
requires :name
merge_attributes(service.create_image(self.attributes).body)
self
end
|
#deactivate ⇒ Object
95
96
97
98
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 95
def deactivate
requires :id
service.deactivate_image(self.id)
end
|
#destroy ⇒ Object
70
71
72
73
74
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 70
def destroy
requires :id
service.delete_image(self.id)
true
end
|
#download_data(params = {}) ⇒ Object
85
86
87
88
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 85
def download_data(params={})
requires :id
service.download_image(self.id, content_range=params[:content_range], params)
end
|
#identity ⇒ Object
This overrides the behaviour of Fog::OpenStack::Model::save() which tries to be clever and
assumes save=update if an ID is present - but Image V2 allows ID to specified on creation
51
52
53
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 51
def identity
nil
end
|
#member(member_id) ⇒ Object
120
121
122
123
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 120
def member(member_id)
requires :id
service.get_member_details(self.id, member_id)
end
|
#members ⇒ Object
115
116
117
118
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 115
def members
requires :id
service.get_image_members(self.id).body['members']
end
|
#reactivate ⇒ Object
90
91
92
93
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 90
def reactivate
requires :id
service.reactivate_image(self.id)
end
|
#remove_member(member_id) ⇒ Object
105
106
107
108
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 105
def remove_member(member_id)
requires :id
service.remove_member_from_image(self.id, member_id)
end
|
#remove_tag(tag) ⇒ Object
140
141
142
143
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 140
def remove_tag(tag)
requires :id
service.remove_tag_from_image(self.id, tag)
end
|
135
136
137
138
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 135
def remove_tags(tags)
requires :id
tags.each {|tag| remove_tag tag}
end
|
#update(attr = {}) ⇒ Object
Hash of attributes to update is passed in. Setting value to nil will delete that attribute.
Here we convert that hash into a form suitable for Glance's usage of JSON Patch (RFC6902)
57
58
59
60
61
62
63
64
65
66
67
68
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 57
def update(attr = {})
requires :id
json_patch = []
attr.each do |key, value|
op = (@attributes.keys.include? key) ? 'replace' : 'add'
op = 'remove' if value.nil?
json_patch << {:op => op, :path => "/#{key}", :value => value }
end
merge_attributes(
service.update_image(self.id, json_patch).body)
self
end
|
#update_member(member) ⇒ Object
110
111
112
113
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 110
def update_member(member)
requires :id
service.update_image_member(self.id, member)
end
|
#upload_data(io_obj) ⇒ Object
76
77
78
79
80
81
82
83
|
# File 'lib/fog/openstack/models/image_v2/image.rb', line 76
def upload_data(io_obj)
requires :id
if io_obj.is_a? Hash
service.upload_image(self.id, nil, io_obj)
else
service.upload_image(self.id, io_obj)
end
end
|