nicer error messages for missing required params on models
This commit is contained in:
parent
9e87d99a17
commit
7636b845b6
|
@ -9,11 +9,15 @@ module Fog
|
||||||
attribute :instance_id, 'instanceId'
|
attribute :instance_id, 'instanceId'
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
|
requires :public_ip
|
||||||
|
|
||||||
connection.release_address(@public_ip)
|
connection.release_address(@public_ip)
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
def instance=(new_instance)
|
def instance=(new_instance)
|
||||||
|
requires :public_ip
|
||||||
|
|
||||||
if new_instance
|
if new_instance
|
||||||
associate(new_instance)
|
associate(new_instance)
|
||||||
else
|
else
|
||||||
|
|
|
@ -24,10 +24,14 @@ module Fog
|
||||||
attribute :user_data
|
attribute :user_data
|
||||||
|
|
||||||
def addresses
|
def addresses
|
||||||
|
requires :instance_id
|
||||||
|
|
||||||
connection.addresses(:instance => self)
|
connection.addresses(:instance => self)
|
||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
|
requires :instance_id
|
||||||
|
|
||||||
connection.terminate_instances(@instance_id)
|
connection.terminate_instances(@instance_id)
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
@ -41,6 +45,8 @@ module Fog
|
||||||
# end
|
# end
|
||||||
|
|
||||||
def key_pair
|
def key_pair
|
||||||
|
requires :key_name
|
||||||
|
|
||||||
connection.keypairs.all(@key_name).first
|
connection.keypairs.all(@key_name).first
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -65,11 +71,15 @@ module Fog
|
||||||
end
|
end
|
||||||
|
|
||||||
def reboot
|
def reboot
|
||||||
|
requires :instance_id
|
||||||
|
|
||||||
connection.reboot_instances(@instance_id)
|
connection.reboot_instances(@instance_id)
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
def save
|
def save
|
||||||
|
requires :image_id
|
||||||
|
|
||||||
options = {}
|
options = {}
|
||||||
if @availability_zone
|
if @availability_zone
|
||||||
options['Placement.AvailabilityZone'] = @availability_zone
|
options['Placement.AvailabilityZone'] = @availability_zone
|
||||||
|
@ -101,6 +111,8 @@ module Fog
|
||||||
end
|
end
|
||||||
|
|
||||||
def volumes
|
def volumes
|
||||||
|
requires :instance_id
|
||||||
|
|
||||||
connection.volumes(:instance => self)
|
connection.volumes(:instance => self)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -10,11 +10,15 @@ module Fog
|
||||||
attribute :material, 'keyMaterial'
|
attribute :material, 'keyMaterial'
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
|
requires :name
|
||||||
|
|
||||||
connection.delete_key_pair(@name)
|
connection.delete_key_pair(@name)
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
def save
|
def save
|
||||||
|
requires :name
|
||||||
|
|
||||||
data = connection.create_key_pair(@name).body
|
data = connection.create_key_pair(@name).body
|
||||||
new_attributes = data.reject {|key,value| !['keyFingerprint', 'keyMaterial', 'keyName'].include?(key)}
|
new_attributes = data.reject {|key,value| !['keyFingerprint', 'keyMaterial', 'keyName'].include?(key)}
|
||||||
merge_attributes(new_attributes)
|
merge_attributes(new_attributes)
|
||||||
|
|
|
@ -11,6 +11,8 @@ module Fog
|
||||||
attribute :owner_id, 'ownerId'
|
attribute :owner_id, 'ownerId'
|
||||||
|
|
||||||
def authorize_group_and_owner(group, owner)
|
def authorize_group_and_owner(group, owner)
|
||||||
|
requires :group_name
|
||||||
|
|
||||||
connection.authorize_security_group_ingress(
|
connection.authorize_security_group_ingress(
|
||||||
'GroupName' => @group_name,
|
'GroupName' => @group_name,
|
||||||
'SourceSecurityGroupName' => group,
|
'SourceSecurityGroupName' => group,
|
||||||
|
@ -19,6 +21,8 @@ module Fog
|
||||||
end
|
end
|
||||||
|
|
||||||
def authorize_port_range(range, options = {})
|
def authorize_port_range(range, options = {})
|
||||||
|
requires :group_name
|
||||||
|
|
||||||
connection.authorize_security_group_ingress(
|
connection.authorize_security_group_ingress(
|
||||||
'CidrIp' => options[:cidr_ip] || '0.0.0.0/0',
|
'CidrIp' => options[:cidr_ip] || '0.0.0.0/0',
|
||||||
'FromPort' => range.min,
|
'FromPort' => range.min,
|
||||||
|
@ -29,11 +33,15 @@ module Fog
|
||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
|
requires :group_name
|
||||||
|
|
||||||
connection.delete_security_group(@group_name)
|
connection.delete_security_group(@group_name)
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
def save
|
def save
|
||||||
|
requires :group_name
|
||||||
|
|
||||||
data = connection.create_security_group(@group_name, @group_description).body
|
data = connection.create_security_group(@group_name, @group_description).body
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
|
@ -12,18 +12,24 @@ module Fog
|
||||||
attribute :volume_id, 'volumeId'
|
attribute :volume_id, 'volumeId'
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
|
requires :snapshot_id
|
||||||
|
|
||||||
connection.delete_snapshot(@snapshot_id)
|
connection.delete_snapshot(@snapshot_id)
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
def save
|
def save
|
||||||
data = connection.create_snapshot(volume_id).body
|
requires :volume_id
|
||||||
|
|
||||||
|
data = connection.create_snapshot(@volume_id).body
|
||||||
new_attributes = data.reject {|key,value| key == 'requestId'}
|
new_attributes = data.reject {|key,value| key == 'requestId'}
|
||||||
merge_attributes(new_attributes)
|
merge_attributes(new_attributes)
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
def volume
|
def volume
|
||||||
|
requires :snapshot_id
|
||||||
|
|
||||||
connection.describe_volumes(@volume_id)
|
connection.describe_volumes(@volume_id)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -23,11 +23,15 @@ module Fog
|
||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
|
requires :volume_id
|
||||||
|
|
||||||
connection.delete_volume(@volume_id)
|
connection.delete_volume(@volume_id)
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
def instance=(new_instance)
|
def instance=(new_instance)
|
||||||
|
requires :volume_id
|
||||||
|
|
||||||
if new_instance
|
if new_instance
|
||||||
attach(new_instance)
|
attach(new_instance)
|
||||||
else
|
else
|
||||||
|
@ -36,6 +40,8 @@ module Fog
|
||||||
end
|
end
|
||||||
|
|
||||||
def save
|
def save
|
||||||
|
requires :availability_zone, :size, :snapshot_id
|
||||||
|
|
||||||
data = connection.create_volume(@availability_zone, @size, @snapshot_id).body
|
data = connection.create_volume(@availability_zone, @size, @snapshot_id).body
|
||||||
new_attributes = data.reject {|key,value| key == 'requestId'}
|
new_attributes = data.reject {|key,value| key == 'requestId'}
|
||||||
merge_attributes(new_attributes)
|
merge_attributes(new_attributes)
|
||||||
|
@ -46,7 +52,9 @@ module Fog
|
||||||
end
|
end
|
||||||
|
|
||||||
def snapshots
|
def snapshots
|
||||||
connection.snapshots(:volume_id => volume_id)
|
requires :volume_id
|
||||||
|
|
||||||
|
connection.snapshots(:volume_id => @volume_id)
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
|
@ -10,6 +10,8 @@ module Fog
|
||||||
attribute :owner
|
attribute :owner
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
|
requires :name
|
||||||
|
|
||||||
connection.delete_bucket(@name)
|
connection.delete_bucket(@name)
|
||||||
true
|
true
|
||||||
rescue Excon::Errors::NotFound
|
rescue Excon::Errors::NotFound
|
||||||
|
@ -17,6 +19,8 @@ module Fog
|
||||||
end
|
end
|
||||||
|
|
||||||
def location
|
def location
|
||||||
|
requires :name
|
||||||
|
|
||||||
data = connection.get_bucket_location(@name)
|
data = connection.get_bucket_location(@name)
|
||||||
data.body['LocationConstraint']
|
data.body['LocationConstraint']
|
||||||
end
|
end
|
||||||
|
@ -35,16 +39,22 @@ module Fog
|
||||||
end
|
end
|
||||||
|
|
||||||
def payer
|
def payer
|
||||||
|
requires :name
|
||||||
|
|
||||||
data = connection.get_request_payment(@name)
|
data = connection.get_request_payment(@name)
|
||||||
data.body['Payer']
|
data.body['Payer']
|
||||||
end
|
end
|
||||||
|
|
||||||
def payer=(new_payer)
|
def payer=(new_payer)
|
||||||
|
requires :name
|
||||||
|
|
||||||
connection.put_request_payment(@name, new_payer)
|
connection.put_request_payment(@name, new_payer)
|
||||||
@payer = new_payer
|
@payer = new_payer
|
||||||
end
|
end
|
||||||
|
|
||||||
def save
|
def save
|
||||||
|
requires :name
|
||||||
|
|
||||||
options = {}
|
options = {}
|
||||||
if @location
|
if @location
|
||||||
options['LocationConstraint'] = @location
|
options['LocationConstraint'] = @location
|
||||||
|
|
|
@ -20,6 +20,8 @@ module Fog
|
||||||
end
|
end
|
||||||
|
|
||||||
def copy(target_bucket_name, target_object_key)
|
def copy(target_bucket_name, target_object_key)
|
||||||
|
requires :bucket, :key
|
||||||
|
|
||||||
data = connection.copy_object(bucket.name, @key, target_bucket_name, target_object_key).body
|
data = connection.copy_object(bucket.name, @key, target_bucket_name, target_object_key).body
|
||||||
target_bucket = connection.buckets.new(:name => target_bucket_name)
|
target_bucket = connection.buckets.new(:name => target_bucket_name)
|
||||||
target_object = target_bucket.objects.new(attributes.merge!(:key => target_object_key))
|
target_object = target_bucket.objects.new(attributes.merge!(:key => target_object_key))
|
||||||
|
@ -34,11 +36,14 @@ module Fog
|
||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
|
requires :bucket, :key
|
||||||
|
|
||||||
connection.delete_object(bucket.name, @key)
|
connection.delete_object(bucket.name, @key)
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
def save(options = {})
|
def save(options = {})
|
||||||
|
requires :body, :bucket, :key
|
||||||
data = connection.put_object(bucket.name, @key, @body, options)
|
data = connection.put_object(bucket.name, @key, @body, options)
|
||||||
@etag = data.headers['ETag']
|
@etag = data.headers['ETag']
|
||||||
true
|
true
|
||||||
|
|
|
@ -89,6 +89,20 @@ module Fog
|
||||||
merge_attributes(new_attributes)
|
merge_attributes(new_attributes)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def requires(*args)
|
||||||
|
missing = []
|
||||||
|
for arg in [:connection] | args
|
||||||
|
missing << arg unless send("#{arg}")
|
||||||
|
end
|
||||||
|
unless missing.empty?
|
||||||
|
if missing.length == 1
|
||||||
|
raise(ArgumentError, "#{missing.first} is required for this operation")
|
||||||
|
else
|
||||||
|
raise(ArgumentError, "#{missing[0...-1].join(", ")} and #{missing[-1]} are required for this operation")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def collection=(new_collection)
|
def collection=(new_collection)
|
||||||
|
|
|
@ -13,15 +13,21 @@ module Fog
|
||||||
attribute :server_id, 'serverId'
|
attribute :server_id, 'serverId'
|
||||||
|
|
||||||
def server=(new_server)
|
def server=(new_server)
|
||||||
|
requires :id
|
||||||
|
|
||||||
@server_id = new_server.id
|
@server_id = new_server.id
|
||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
|
requires :id
|
||||||
|
|
||||||
connection.delete_image(@id)
|
connection.delete_image(@id)
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
def save
|
def save
|
||||||
|
requires :server_id
|
||||||
|
|
||||||
data = connection.create_server(@server_id)
|
data = connection.create_server(@server_id)
|
||||||
merge_attributes(data.body['image'])
|
merge_attributes(data.body['image'])
|
||||||
true
|
true
|
||||||
|
|
|
@ -18,20 +18,27 @@ module Fog
|
||||||
attribute :metadata
|
attribute :metadata
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
|
requires :id
|
||||||
|
|
||||||
connection.delete_server(@id)
|
connection.delete_server(@id)
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
def images
|
def images
|
||||||
|
requires :id
|
||||||
|
|
||||||
connection.images(:server => self)
|
connection.images(:server => self)
|
||||||
end
|
end
|
||||||
|
|
||||||
def reboot(type = 'SOFT')
|
def reboot(type = 'SOFT')
|
||||||
|
requires :id
|
||||||
|
|
||||||
connection.reboot_server(@id, type)
|
connection.reboot_server(@id, type)
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
def save
|
def save
|
||||||
|
requires :flavor_id, :image_id, :name
|
||||||
options = { 'metadata' => @metadata, 'personality' => @personality }
|
options = { 'metadata' => @metadata, 'personality' => @personality }
|
||||||
options = options.reject {|key, value| value.nil?}
|
options = options.reject {|key, value| value.nil?}
|
||||||
data = connection.create_server(@flavor_id, @image_id, @name, options)
|
data = connection.create_server(@flavor_id, @image_id, @name, options)
|
||||||
|
|
Loading…
Reference in New Issue