Class: ServiceStore

Inherits:
Object
  • Object
show all
Defined in:
app/models/service_store.rb

Overview

A ServiceStore is a collection of umlaut service definitions, with identifiers.

There is one default global one that is typically used; originally this was all neccesarily global state, but we refactored to be an actual object, although there’s still a default global one used, with class methods that delegate to it, for backwards compat and convenience.

By default, a ServiceStore loads service definitions from Rails.root/config/umlaut_services.yml . Although in testing, or for future architectural expansion, services can be manually supplied instead.

A ServiceStore instantiates services from definitions, by id, ServiceStore.instantiate_service!(“our_sfx”)

A ServiceStore’s cached service definitions can be reset, useful in testing: ServiceStore.reset!

They’ll then be lazily reloaded on next access, unless manually set.

Defined Under Namespace

Classes: NoSuchService

Constant Summary collapse

@@global_service_store =
ServiceStore.new

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.global_service_storeObject



22
23
24
# File 'app/models/service_store.rb', line 22

def self.global_service_store
  @@global_service_store
end

Instance Method Details

#configObject

Returns complete hash loaded from config/umlaut_services.yml Passes through ERB first, allowing ERB in umlaut_services.yml



38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# File 'app/models/service_store.rb', line 38

def config
  # cache hash loaded from YAML, ensure it has the keys we expect.
  unless defined? @services_config_list
    yaml_path = File.expand_path("config/umlaut_services.yml", Rails.root)

    @services_config_list = if File.exists? yaml_path 
      YAML::load(ERB.new(File.open(yaml_path).read).result)
    else
      {}
    end

    @services_config_list["default"] ||= {}
    @services_config_list["default"]["services"] ||= {}
  end
  return @services_config_list
end

#config=(hash) ⇒ Object

Manually set a config hash, as would normally be found serialized in config/umlaut_services.yml. Useful in testing. All keys should be strings!!

Needs to have the somewhat cumbersome expected structure:

“default”][“services”

> { “service_id” => definition_hash }



61
62
63
64
# File 'app/models/service_store.rb', line 61

def config=(hash)
  reset!
  @services_config_list = hash
end

#determine_services(specified_groups = []) ⇒ Object

pass in array of service group ids. eg. [“group1”, “-group2”]

Returns a list of service definition hashes.

Start with default group(s). Remove any that are mentioned with “-group_id” in the group list, add in any that are mentioned with “group_id”



107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
# File 'app/models/service_store.rb', line 107

def determine_services(specified_groups = [])    
  services = {}

  activated_service_groups = self.config.select do |group_id, group_definition|
    ((group_id == "default" || group_definition["default"] == true)  ||
    specified_groups.include?(group_id)) &&
    ! specified_groups.include?("-#{group_id}")
  end

  activated_service_groups.each_pair do |group_id, group_definition|
    services.merge! (group_definition["services"] || {})
  end

  # Remove any disabled services
  services.reject! {|service_id, hash| hash && hash["disabled"] == true}

  return services
end

#instantiate_service!(service, request) ⇒ Object

pass in string unique key OR a service definition hash, and a current UmlautRequest. get back instantiated Service object.

If string service_id is passed in, but is not defined in application services, a ServiceStore::NoSuchService exception will be raised.

Raises:



133
134
135
136
137
138
139
140
141
# File 'app/models/service_store.rb', line 133

def instantiate_service!(service, request)
  definition = service.kind_of?(Hash) ? service : service_definition_for(service.to_s)
  raise NoSuchService.new("Service '#{service}'' does not exist in umlaut-services.yml") if definition.nil?
  className = definition["type"] || definition["service_id"]
  classConst = Kernel.const_get(className)
  service = classConst.new(definition)
  service.request = request
  return service
end

#reset!Object

Reset cached service definitions. They’ll be lazily loaded when asked for, typically by being looked up from disk again. Typically used for testing.



92
93
94
95
# File 'app/models/service_store.rb', line 92

def reset!
  remove_instance_variable "@service_definitions"   if defined? @service_definitions
  remove_instance_variable "@services_config_list"  if defined? @services_config_list
end

#service_definition_for(service_id) ⇒ Object



97
98
99
# File 'app/models/service_store.rb', line 97

def service_definition_for(service_id)
  return service_definitions[service_id]
end

#service_definitionsObject

Returns hash keyed by unique service name, value service definition hash.



68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
# File 'app/models/service_store.rb', line 68

def service_definitions
  unless defined? @service_definitions
    @service_definitions = {}
    config.each_pair do |group_name, group|
      if group["services"]
        # Add the group name to each service
        # in the group
        group["services"].each_pair do |service_id, service|
          service["group"] = group_name
        end
        # Merge the group's services into the service definitions.
        @service_definitions.merge!(  group["services"]  )
      end
    end
    # set service_id key in each based on hash key
    @service_definitions.each_pair do |key, hash|
      hash["service_id"] =  key
    end
  end
  return @service_definitions
end