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

[fog] Cleanup: Use the service registry for requiring libs where possible

This commit is contained in:
Anshul Khandelwal 2013-02-16 16:58:38 +05:30
parent 9dc15001ce
commit eb0545b724
8 changed files with 42 additions and 153 deletions

View file

@ -7,19 +7,12 @@ module Fog
def self.new(attributes)
attributes = attributes.dup # prevent delete from having side effects
case provider = attributes.delete(:provider).to_s.downcase.to_sym
when :aws
require 'fog/aws/cdn'
Fog::CDN::AWS.new(attributes)
when :hp
require 'fog/hp/cdn'
Fog::CDN::HP.new(attributes)
when :rackspace
require 'fog/rackspace/cdn'
Fog::CDN::Rackspace.new(attributes)
else
raise ArgumentError.new("#{provider} is not a recognized cdn provider")
provider = attributes.delete(:provider).to_s.downcase.to_sym
if self.providers.include?(provider)
require "fog/#{provider}/cdn"
return Fog::CDN.const_get(Fog.providers[provider]).new(attributes)
end
raise ArgumentError.new("#{provider} is not a recognized cdn provider")
end
def self.providers

View file

@ -9,46 +9,11 @@ module Fog
attributes = attributes.dup # prevent delete from having side effects
provider = attributes.delete(:provider).to_s.downcase.to_sym
case provider
when :aws
require 'fog/aws/compute'
Fog::Compute::AWS.new(attributes)
when :bluebox
require 'fog/bluebox/compute'
Fog::Compute::Bluebox.new(attributes)
when :brightbox
require 'fog/brightbox/compute'
Fog::Compute::Brightbox.new(attributes)
when :cloudstack
require 'fog/cloudstack/compute'
Fog::Compute::Cloudstack.new(attributes)
when :clodo
require 'fog/clodo/compute'
Fog::Compute::Clodo.new(attributes)
when :ecloud
require 'fog/ecloud/compute'
Fog::Compute::Ecloud.new(attributes)
when :glesys
require 'fog/glesys/compute'
Fog::Compute::Glesys.new(attributes)
when :gogrid
require 'fog/go_grid/compute'
Fog::Compute::GoGrid.new(attributes)
when :hp
require 'fog/hp/compute'
Fog::Compute::HP.new(attributes)
when :ibm
require 'fog/ibm/compute'
Fog::Compute::IBM.new(attributes)
when :joyent
require 'fog/joyent/compute'
Fog::Compute::Joyent.new(attributes)
when :libvirt
require 'fog/libvirt/compute'
Fog::Compute::Libvirt.new(attributes)
when :linode
require 'fog/linode/compute'
Fog::Compute::Linode.new(attributes)
when :new_servers
require 'fog/bare_metal_cloud/compute'
Fog::Logger.deprecation "`new_servers` is deprecated. Please use `bare_metal_cloud` instead."
@ -56,15 +21,6 @@ module Fog
when :baremetalcloud
require 'fog/bare_metal_cloud/compute'
Fog::Compute::BareMetalCloud.new(attributes)
when :ninefold
require 'fog/ninefold/compute'
Fog::Compute::Ninefold.new(attributes)
when :openstack
require 'fog/openstack/compute'
Fog::Compute::OpenStack.new(attributes)
when :ovirt
require 'fog/ovirt/compute'
Fog::Compute::Ovirt.new(attributes)
when :rackspace
version = attributes.delete(:version)
version = version.to_s.downcase.to_sym unless version.nil?
@ -76,31 +32,17 @@ module Fog
require 'fog/rackspace/compute'
Fog::Compute::Rackspace.new(attributes)
end
when :serverlove
require 'fog/serverlove/compute'
Fog::Compute::Serverlove.new(attributes)
when :stormondemand
require 'fog/storm_on_demand/compute'
Fog::Compute::StormOnDemand.new(attributes)
when :vcloud
require 'fog/vcloud/compute'
Fog::Vcloud::Compute.new(attributes)
when :virtualbox
require 'fog/virtual_box/compute'
Fog::Compute::VirtualBox.new(attributes)
when :vmfusion
require 'fog/vmfusion/compute'
Fog::Compute::Vmfusion.new(attributes)
when :voxel
require 'fog/voxel/compute'
Fog::Compute::Voxel.new(attributes)
when :vsphere
require 'fog/vsphere/compute'
Fog::Compute::Vsphere.new(attributes)
when :xenserver
require 'fog/xenserver/compute'
Fog::Compute::XenServer.new(attributes)
else
if self.providers.include?(provider)
require "fog/#{provider}/compute"
return Fog::Compute.const_get(Fog.providers[provider]).new(attributes)
end
raise ArgumentError.new("#{provider} is not a recognized compute provider")
end
end

View file

@ -7,37 +7,14 @@ module Fog
def self.new(attributes)
attributes = attributes.dup # prevent delete from having side effects
case provider = attributes.delete(:provider).to_s.downcase.to_sym
when :aws
require 'fog/aws/dns'
Fog::DNS::AWS.new(attributes)
when :bluebox
require 'fog/bluebox/dns'
Fog::DNS::Bluebox.new(attributes)
when :dnsimple
require 'fog/dnsimple/dns'
Fog::DNS::DNSimple.new(attributes)
when :dnsmadeeasy
require 'fog/dnsmadeeasy/dns'
Fog::DNS::DNSMadeEasy.new(attributes)
when :dreamhost
require 'fog/dreamhost/dns'
Fog::DNS::Dreamhost.new(attributes)
when :dynect
require 'fog/dynect/dns'
Fog::DNS::Dynect.new(attributes)
when :linode
require 'fog/linode/dns'
Fog::DNS::Linode.new(attributes)
when :zerigo
require 'fog/zerigo/dns'
Fog::DNS::Zerigo.new(attributes)
when :rackspace
require 'fog/rackspace/dns'
Fog::DNS::Rackspace.new(attributes)
else
raise ArgumentError.new("#{provider} is not a recognized dns provider")
provider = attributes.delete(:provider).to_s.downcase.to_sym
if self.providers.include?(provider)
require "fog/#{provider}/dns"
return Fog::DNS.const_get(Fog.providers[provider]).new(attributes)
end
raise ArgumentError.new("#{provider} is not a recognized dns provider")
end
def self.providers

View file

@ -11,10 +11,11 @@ module Fog
when :rackspace
require 'fog/rackspace/identity'
Fog::Rackspace::Identity.new(attributes)
when :openstack
require 'fog/openstack/identity'
Fog::Identity::OpenStack.new(attributes)
else
if self.providers.include?(provider)
require "fog/#{provider}/identity"
return Fog::Identity.const_get(Fog.providers[provider]).new(attributes)
end
raise ArgumentError.new("#{provider} has no identity service")
end
end

View file

@ -7,13 +7,12 @@ module Fog
def self.new(attributes)
attributes = attributes.dup # Prevent delete from having side effects
case provider = attributes.delete(:provider).to_s.downcase.to_sym
when :openstack
require 'fog/openstack/image'
Fog::Image::OpenStack.new(attributes)
else
raise ArgumentError.new("#{provider} has no identity service")
provider = attributes.delete(:provider).to_s.downcase.to_sym
if self.providers.include?(provider)
require "fog/#{provider}/image"
return Fog::Image.const_get(Fog.providers[provider]).new(attributes)
end
raise ArgumentError.new("#{provider} has no identity service")
end
def self.providers

View file

@ -9,13 +9,12 @@ module Fog
attributes = attributes.dup # Prevent delete from having side effects
provider = attributes.delete(:provider).to_s.downcase.to_sym
case provider
when :openstack
require 'fog/openstack/network'
Fog::Network::OpenStack.new(attributes)
else
raise ArgumentError.new("#{provider} has no network service")
if self.providers.include?(provider)
require "fog/#{provider}/network"
return Fog::Network.const_get(Fog.providers[provider]).new(attributes)
end
raise ArgumentError.new("#{provider} has no network service")
end
def self.providers

View file

@ -8,37 +8,15 @@ module Fog
def self.new(attributes)
attributes = attributes.dup # prevent delete from having side effects
case provider = attributes.delete(:provider).to_s.downcase.to_sym
when :atmos
require 'fog/atmos/storage'
Fog::Storage::Atmos.new(attributes)
when :aws
require 'fog/aws/storage'
Fog::Storage::AWS.new(attributes)
when :google
require 'fog/google/storage'
Fog::Storage::Google.new(attributes)
when :hp
require 'fog/hp/storage'
Fog::Storage::HP.new(attributes)
when :ibm
require 'fog/ibm/storage'
Fog::Storage::IBM.new(attributes)
when :internetarchive
require 'fog/internet_archive/storage'
Fog::Storage::InternetArchive.new(attributes)
when :local
require 'fog/local/storage'
Fog::Storage::Local.new(attributes)
when :ninefold
require 'fog/ninefold/storage'
Fog::Storage::Ninefold.new(attributes)
when :rackspace
require 'fog/rackspace/storage'
Fog::Storage::Rackspace.new(attributes)
when :openstack
require 'fog/openstack/storage'
Fog::Storage::OpenStack.new(attributes)
else
if self.providers.include?(provider)
require "fog/#{provider}/storage"
return Fog::Storage.const_get(Fog.providers[provider]).new(attributes)
end
raise ArgumentError.new("#{provider} is not a recognized storage provider")
end
end

View file

@ -7,13 +7,13 @@ module Fog
def self.new(attributes)
attributes = attributes.dup # Prevent delete from having side effects
case provider = attributes.delete(:provider).to_s.downcase.to_sym
when :openstack
require 'fog/openstack/volume'
Fog::Volume::OpenStack.new(attributes)
else
raise ArgumentError.new("#{provider} has no identity service")
provider = attributes.delete(:provider).to_s.downcase.to_sym
if self.providers.include?(provider)
require "fog/#{provider}/volume"
return Fog::Volume.const_get(Fog.providers[provider]).new(attributes)
end
raise ArgumentError.new("#{provider} has no identity service")
end
def self.providers