Module: Legion::Data::Models

Defined in:
lib/legion/data/model.rb

Class Attribute Summary collapse

Class Method Summary collapse

Class Attribute Details

.loaded_modelsObject (readonly)

Returns the value of attribute loaded_models.



7
8
9
# File 'lib/legion/data/model.rb', line 7

def loaded_models
  @loaded_models
end

Class Method Details

.loadObject



14
15
16
17
18
19
# File 'lib/legion/data/model.rb', line 14

def load
  Legion::Logging.info 'Loading Legion::Data::Models'
  @loaded_models ||= []
  require_sequel_models(models)
  Legion::Settings[:data][:models][:loaded] = true
end

.load_sequel_model(model) ⇒ Object



26
27
28
29
30
31
32
33
34
35
# File 'lib/legion/data/model.rb', line 26

def load_sequel_model(model)
  Legion::Logging.debug("Trying to load #{model}.rb")
  require_relative "models/#{model}"
  @loaded_models << model
  Legion::Logging.debug("Successfully loaded #{model}")
  model
rescue LoadError => e
  Legion::Logging.fatal("Failed to load #{model}")
  raise e unless Legion::Settings[:data][:models][:continue_on_fail]
end

.modelsObject



9
10
11
12
# File 'lib/legion/data/model.rb', line 9

def models
  %w[extension function relationship task runner node setting digital_worker
     apollo_entry apollo_relation apollo_expertise apollo_access_log audit_log]
end

.require_sequel_models(files = models) ⇒ Object



21
22
23
24
# File 'lib/legion/data/model.rb', line 21

def require_sequel_models(files = models)
  # Dir["#{File.dirname(__FILE__)}models/*.rb"].each { |file| puts file }
  files.each { |file| load_sequel_model(file) }
end