mirror of
https://github.com/fog/fog.git
synced 2022-11-09 13:51:43 -05:00
827c029a99
- Added google_storage_* keys - Fixed indentations. - Factored out requires and recognizes method implementation (now relies on the requires and recognizes clause from the NamedParameters module) - Added dependency to named-parameters gem. - Added recognizes declaration to classes for all supported services to enforce parameter name checks - - passing an unrecognized key when instantiating a service object will now cause an ArgumentError to be raised. - Added NOTE - comment added - check/filter-out keys from credentials that are not required by the class being instantiated - [local|storage] properly write out file contents - Added google_storage_* keys - Fixed indentations. - added put_object_acl request (ref: https://github.com/geemus/fog/issues#issue/74) - Release 0.3.24 - remove tracker reference from README - issues is now the goto for bugs/todo - notify and gracefully skip credential-less testsa - [rackspace|storage] fixes for directory/files - [local|storage] CGI.escape file names - Release 0.3.25 - updated deps; recognized_parameters -> declared_parameters; restored options filtering if Fog.bin - Added requires/recognizes to Fog::Terremark::Ecloud - Updted to use latest named-parameters gem. - Filter out unwanted parameters when Fog.bin - Updated to latest named-parameters gem - commented out unnecessary code - fix missing "volume" parameter error when setting Fog::AWS::Volume#server to nil (in order to detach it) - documentation update for key_pairs and helper - [aws|compute] commented/documented flavors/volumes - Fixes for issue 38 and 39 Closes #96
81 lines
2 KiB
Ruby
81 lines
2 KiB
Ruby
module Fog
|
|
module Linode
|
|
class Compute < Fog::Service
|
|
|
|
requires :linode_api_key
|
|
recognizes :port, :scheme, :persistent
|
|
|
|
model_path 'fog/linode/models/compute'
|
|
|
|
request_path 'fog/linode/requests/compute'
|
|
request :avail_datacenters
|
|
request :avail_distributions
|
|
request :avail_kernels
|
|
request :avail_linodeplans
|
|
request :avail_stackscripts
|
|
request :linode_create
|
|
request :linode_delete
|
|
request :linode_list
|
|
request :linode_reboot
|
|
|
|
class Mock
|
|
|
|
def self.data
|
|
@data ||= Hash.new do |hash, key|
|
|
hash[key] = {}
|
|
end
|
|
end
|
|
|
|
def self.reset_data(keys=data.keys)
|
|
for key in [*keys]
|
|
data.delete(key)
|
|
end
|
|
end
|
|
|
|
def initialize(options={})
|
|
@linode_api_key = options[:linode_api_key]
|
|
@data = self.class.data[@linode_api_key]
|
|
end
|
|
|
|
end
|
|
|
|
class Real
|
|
|
|
def initialize(options={})
|
|
require 'json'
|
|
@linode_api_key = options[:linode_api_key]
|
|
@host = options[:host] || "api.linode.com"
|
|
@port = options[:port] || 443
|
|
@scheme = options[:scheme] || 'https'
|
|
@connection = Fog::Connection.new("#{@scheme}://#{@host}:#{@port}", options[:persistent])
|
|
end
|
|
|
|
def reload
|
|
@connection.reset
|
|
end
|
|
|
|
def request(params)
|
|
params[:query] ||= {}
|
|
params[:query].merge!(:api_key => @linode_api_key)
|
|
|
|
response = @connection.request(params.merge!({:host => @host}))
|
|
|
|
unless response.body.empty?
|
|
response.body = JSON.parse(response.body)
|
|
if data = response.body['ERRORARRAY'].first
|
|
error = case data['ERRORCODE']
|
|
when 5
|
|
Fog::Linode::Compute::NotFound
|
|
else
|
|
Fog::Linode::Compute::Error
|
|
end
|
|
raise error.new(data['ERRORMESSAGE'])
|
|
end
|
|
end
|
|
response
|
|
end
|
|
|
|
end
|
|
end
|
|
end
|
|
end
|