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

Add Config attributes, and the "get" method for Configs to get detail of a specific config object

This commit is contained in:
Eric Wong 2013-05-21 17:35:57 +08:00
parent e3b5730768
commit 8015dec890
5 changed files with 43 additions and 9 deletions

View file

@ -5,7 +5,8 @@ module Fog
module Compute
class StormOnDemand < Fog::Service
API_URL = 'https://api.stormondemand.com/v1'
API_URL = 'https://api.stormondemand.com'
API_VERSION = 'v1'
requires :storm_on_demand_username, :storm_on_demand_password
recognizes :storm_on_demand_auth_url
@ -38,6 +39,7 @@ module Fog
request :add_balancer_node
request :list_balancers
request :list_configs
request :get_config_details
request :list_templates
request :list_images
request :get_stats
@ -109,7 +111,7 @@ module Fog
'Authorization' => 'Basic ' << Base64.encode64("#{@storm_on_demand_username}:#{@storm_on_demand_password}").chomp
}.merge!(params[:headers] || {}),
:host => @host,
:path => "#{@path}/#{params[:path]}",
:path => "#{@path}/#{API_VERSION}#{params[:path]}",
:expects => 200,
:method => :post
}))

View file

@ -10,18 +10,30 @@ module Fog
attribute :active
attribute :available
attribute :category
attribute :cpu_cores
attribute :cpu_count
attribute :cpu_hyperthreading
attribute :cpu_model
attribute :cpu_speed
attribute :description
attribute :disk
attribute :disk_count
attribute :disk_total
attribute :disk_type
attribute :featured
attribute :memory
attribute :raid_level
attribute :ram_available
attribute :ram_total
attribute :price
attribute :vcpu
end
attribute :zone_availability
def initialize(attributes={})
super
end
def initialize(attributes={})
super
end
end
end
end
end

View file

@ -9,11 +9,15 @@ module Fog
model Fog::Compute::StormOnDemand::Config
def all
data = service.list_configs.body['items']
def all(options={})
data = service.list_configs(options).body['items']
load(data)
end
def get(config_id)
data = service.get_config_details(:id => config_id).body
new(data)
end
end

View file

@ -0,0 +1,16 @@
module Fog
module Compute
class StormOnDemand
class Real
def get_config_details(options={})
request(
:path => '/Storm/Config/details',
:body => Fog::JSON.encode({ :params => options })
)
end
end
end
end
end

View file

@ -6,7 +6,7 @@ module Fog
def list_configs(options = {})
request(
:path => "/storm/config/list",
:body => Fog::JSON.encode(options)
:body => Fog::JSON.encode(:params => options)
)
end