Class: Fog::Service

Inherits:
Object
  • Object
show all
Defined in:
lib/fog/core/service.rb

Direct Known Subclasses

AWS::AutoScaling, AWS::CloudFormation, AWS::CloudWatch, AWS::DataPipeline, AWS::DynamoDB, AWS::ELB, AWS::EMR, AWS::ElasticBeanstalk, AWS::Elasticache, AWS::Glacier, AWS::IAM, AWS::RDS, AWS::SES, AWS::SNS, AWS::SQS, AWS::STS, AWS::SimpleDB, Bluebox::BLB, CDN::AWS, CDN::HP, CDN::Rackspace, Compute::AWS, Compute::BareMetalCloud, Compute::Bluebox, Compute::Brightbox, Compute::Clodo, Compute::Cloudstack, Compute::Ecloud, Compute::Glesys, Compute::GoGrid, Compute::HP, Compute::IBM, Compute::Joyent, Compute::Libvirt, Compute::Linode, Compute::Ninefold, Compute::OpenStack, Compute::Ovirt, Compute::Rackspace, Compute::RackspaceV2, Compute::Serverlove, Compute::StormOnDemand, Compute::Vmfusion, Compute::Voxel, Compute::Vsphere, Compute::XenServer, DNS::AWS, DNS::Bluebox, DNS::DNSMadeEasy, DNS::DNSimple, DNS::Dreamhost, DNS::Dynect, DNS::Linode, DNS::Rackspace, DNS::Zerigo, HP::BlockStorage, Identity::OpenStack, Image::OpenStack, Network::OpenStack, Rackspace::BlockStorage, Rackspace::Databases, Rackspace::Identity, Rackspace::LoadBalancers, RiakCS::Provisioning, RiakCS::Usage, Fog::Storage::AWS, Fog::Storage::Atmos, Fog::Storage::Google, Fog::Storage::HP, Fog::Storage::IBM, Fog::Storage::InternetArchive, Fog::Storage::Local, Fog::Storage::OpenStack, Fog::Storage::Rackspace, Vcloud::Compute, Volume::OpenStack

Defined Under Namespace

Modules: Collections, NoLeakInspector Classes: Error, NotFound

Class Method Summary (collapse)

Class Method Details

+ (Object) coerce_options(options)



129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
# File 'lib/fog/core/service.rb', line 129

def coerce_options(options)
  options.each do |key, value|
    value_string = value.to_s.downcase
    if value.nil?
      options.delete(key)
    elsif value == value_string.to_i.to_s
      options[key] = value.to_i
    else
      options[key] = case value_string
      when 'false'
        false
      when 'true'
        true
      else
        value
      end
    end
  end
end

+ (Object) collection(new_collection)



121
122
123
# File 'lib/fog/core/service.rb', line 121

def collection(new_collection)
  collections << new_collection
end

+ (Object) collections



125
126
127
# File 'lib/fog/core/service.rb', line 125

def collections
  @collections ||= []
end

+ (Object) fetch_credentials(options)



72
73
74
75
76
77
78
79
80
# File 'lib/fog/core/service.rb', line 72

def fetch_credentials(options)
  # attempt to load credentials from config file
  begin
    default_credentials = Fog.credentials.reject {|key, value| !(recognized | requirements).include?(key)}
  rescue LoadError
    # if there are no configured credentials, do nothing
    {}
  end
end

+ (Object) inherited(child)



36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# File 'lib/fog/core/service.rb', line 36

def inherited(child)
  child.class_eval <<-EOS, __FILE__, __LINE__
    class Error < Fog::Service::Error; end
    class NotFound < Fog::Service::NotFound; end

    module Collections
      include Fog::Service::Collections

      def service
        #{child}
      end
    end

    def self.service
      #{child}
    end
  EOS
end

+ (Object) mocked_requests



149
150
151
# File 'lib/fog/core/service.rb', line 149

def mocked_requests
  @mocked_requests ||= []
end

+ (Object) model(new_model)



153
154
155
# File 'lib/fog/core/service.rb', line 153

def model(new_model)
  models << new_model
end

+ (Object) model_path(new_path)



117
118
119
# File 'lib/fog/core/service.rb', line 117

def model_path(new_path)
  @model_path = new_path
end

+ (Object) models



157
158
159
# File 'lib/fog/core/service.rb', line 157

def models
  @models ||= []
end

+ (Object) new(options = {})



55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
# File 'lib/fog/core/service.rb', line 55

def new(options={})
  options = Fog.symbolize_credentials(options)
  options = fetch_credentials(options).merge(options)
  validate_options(options)
  coerce_options(options)
  setup_requirements

  if Fog.mocking?
    service::Mock.send(:include, service::Collections)
    service::Mock.new(options)
  else
    service::Real.send(:include, service::Collections)
    service::Real.send(:include, service::NoLeakInspector)
    service::Real.new(options)
  end
end

+ (Object) recognized



195
196
197
# File 'lib/fog/core/service.rb', line 195

def recognized
  @recognized ||= [:connection_options]
end

+ (Object) recognizes(*args)



191
192
193
# File 'lib/fog/core/service.rb', line 191

def recognizes(*args)
  recognized.concat(args)
end

+ (Object) request(new_request)



165
166
167
# File 'lib/fog/core/service.rb', line 165

def request(new_request)
  requests << new_request
end

+ (Object) request_path(new_path)



161
162
163
# File 'lib/fog/core/service.rb', line 161

def request_path(new_path)
  @request_path = new_path
end

+ (Object) requests



169
170
171
# File 'lib/fog/core/service.rb', line 169

def requests
  @requests ||= []
end

+ (Object) requirements



187
188
189
# File 'lib/fog/core/service.rb', line 187

def requirements
  @requirements ||= []
end

+ (Object) requires(*args)



183
184
185
# File 'lib/fog/core/service.rb', line 183

def requires(*args)
  requirements.concat(args)
end

+ (Object) secrets(*args)



173
174
175
176
177
178
179
180
181
# File 'lib/fog/core/service.rb', line 173

def secrets(*args)
  if args.empty?
    @secrets ||= []
  else
    args.inject(secrets) do |secrets, secret|
      secrets << "@#{secret}".to_sym
    end
  end
end

+ (Object) setup_requirements



82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# File 'lib/fog/core/service.rb', line 82

def setup_requirements
  if superclass.respond_to?(:setup_requirements)
    superclass.setup_requirements
  end

  @required ||= false
  unless @required
    for collection in collections
      require [@model_path, collection].join('/')
      constant = collection.to_s.split('_').map {|characters| characters[0...1].upcase << characters[1..-1]}.join('')
      service::Collections.module_eval <<-EOS, __FILE__, __LINE__
        def #{collection}(attributes = {})
          #{service}::#{constant}.new({:service => self}.merge(attributes))
        end
      EOS
    end
    for model in models
      require [@model_path, model].join('/')
    end
    for request in requests
      require [@request_path, request].join('/')
      if service::Mock.method_defined?(request)
        mocked_requests << request
      else
        service::Mock.module_eval <<-EOS, __FILE__, __LINE__
          def #{request}(*args)
            Fog::Mock.not_implemented
          end
        EOS
      end
    end
    @required = true
  end
end

+ (Object) validate_options(options)



199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
# File 'lib/fog/core/service.rb', line 199

def validate_options(options)
  keys = []
  for key, value in options
    unless value.nil?
      keys << key
    end
  end
  missing = requirements - keys
  unless missing.empty?
    raise ArgumentError, "Missing required arguments: #{missing.join(', ')}"
  end

  unless recognizes.empty?
    unrecognized = options.keys - requirements - recognized
    unless unrecognized.empty?
      raise ArgumentError, "Unrecognized arguments: #{unrecognized.join(', ')}"
    end
  end
end