Class: Fog::Service

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

Defined Under Namespace

Modules: Collections Classes: Error, NotFound

Class Method Summary collapse

Class Method Details

.collection(new_collection) ⇒ Object



96
97
98
# File 'lib/fog/core/service.rb', line 96

def collection(new_collection)
  collections << new_collection
end

.collectionsObject



100
101
102
# File 'lib/fog/core/service.rb', line 100

def collections
  @collections ||= []
end

.inherited(child) ⇒ Object



21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
# File 'lib/fog/core/service.rb', line 21

def inherited(child)
  child.class_eval <<-EOS, __FILE__, __LINE__
    module Collections
      include Fog::Service::Collections

      def service
        #{child}
      end
    end

    def self.service
      #{child}
    end
  EOS
end

.model(new_model) ⇒ Object



104
105
106
# File 'lib/fog/core/service.rb', line 104

def model(new_model)
  models << new_model
end

.model_path(new_path) ⇒ Object



92
93
94
# File 'lib/fog/core/service.rb', line 92

def model_path(new_path)
  @model_path = new_path
end

.modelsObject



108
109
110
# File 'lib/fog/core/service.rb', line 108

def models
  @models ||= []
end

.new(options = {}) ⇒ Object



37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
# File 'lib/fog/core/service.rb', line 37

def new(options={})
  if Fog.bin
    default_credentials = Fog.credentials.reject {|key, value| !requirements.include?(key)}
    options = default_credentials.merge(options)
  end

  missing = []
  for requirement in requirements
    missing << requirement unless options[requirement]
  end
  unless missing.empty?
    if missing.length == 1
      raise(ArgumentError, [missing.first, "is required for this service"].join(' '))
    else
      raise(ArgumentError, [missing[0...-1].join(", "), 'and', missing[-1], 'are required for this service'].join(' '))
    end
  end

  setup_requirements

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

.request(new_request) ⇒ Object



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

def request(new_request)
  requests << new_request
end

.request_path(new_path) ⇒ Object



112
113
114
# File 'lib/fog/core/service.rb', line 112

def request_path(new_path)
  @request_path = new_path
end

.requestsObject



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

def requests
  @requests ||= []
end

.requirementsObject



128
129
130
# File 'lib/fog/core/service.rb', line 128

def requirements
  @requirements ||= []
end

.requires(*args) ⇒ Object



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

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

.reset_data(keys = Mock.data.keys) ⇒ Object



132
133
134
# File 'lib/fog/core/service.rb', line 132

def reset_data(keys=Mock.data.keys)
  Mock.reset_data(keys)
end

.setup_requirementsObject



66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
# File 'lib/fog/core/service.rb', line 66

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({:connection => 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('/')
    end
    @required = true
  end
end