Module: AcpcTableManager

Defined in:
lib/acpc_table_manager.rb,
lib/acpc_table_manager/match.rb,
lib/acpc_table_manager/match.rb,
lib/acpc_table_manager/proxy.rb,
lib/acpc_table_manager/utils.rb,
lib/acpc_table_manager/config.rb,
lib/acpc_table_manager/dealer.rb,
lib/acpc_table_manager/version.rb,
lib/acpc_table_manager/opponents.rb,
lib/acpc_table_manager/maintainer.rb,
lib/acpc_table_manager/match_view.rb,
lib/acpc_table_manager/match_slice.rb,
lib/acpc_table_manager/table_queue.rb,
lib/acpc_table_manager/monkey_patches.rb,
lib/acpc_table_manager/simple_logging.rb

Defined Under Namespace

Modules: Dealer, MonkeyPatches, Opponents, SimpleLogging, TimeRefinement Classes: Config, ExhibitionConfig, Maintainer, Match, MatchSlice, MatchView, Proxy, TableQueue, UninitializedError

Constant Summary collapse

VERSION =
"2.1.0"
@@config =
nil
@@exhibition_config =
nil
@@is_initialized =
false
@@redis_config_file =
nil
@@redis =
nil
@@config_file =
nil
@@notifier =
nil

Class Method Summary collapse

Class Method Details

.configObject



101
102
103
104
105
106
107
# File 'lib/acpc_table_manager/config.rb', line 101

def self.config
  if @@config
    @@config
  else
    raise_uninitialized
  end
end

.config_fileObject



127
# File 'lib/acpc_table_manager/config.rb', line 127

def self.config_file() @@config_file end

.each_key_value_pair(collection) ⇒ Object



4
5
6
7
8
9
10
11
12
# File 'lib/acpc_table_manager/utils.rb', line 4

def self.each_key_value_pair(collection)
  # @todo I can't believe this is necessary...
  if collection.is_a?(Array)
    collection.each_with_index { |v, k| yield k, v }
  else
    collection.each { |k, v| yield k, v }
  end
  collection
end

.exhibition_configObject



110
111
112
113
114
115
116
# File 'lib/acpc_table_manager/config.rb', line 110

def self.exhibition_config
  if @@exhibition_config
    @@exhibition_config
  else
    raise_uninitialized
  end
end

.initialized?Boolean

Returns:

  • (Boolean)


200
201
202
# File 'lib/acpc_table_manager/config.rb', line 200

def self.initialized?
  @@is_initialized
end

.interpolate_all_strings(value, interpolation_hash) ⇒ Object



23
24
25
26
27
28
29
30
31
32
33
# File 'lib/acpc_table_manager/utils.rb', line 23

def self.interpolate_all_strings(value, interpolation_hash)
  if value.is_a?(String)
    value % interpolation_hash
  elsif value.respond_to?(:each)
    each_key_value_pair(value) do |k, v|
      value[k] = interpolate_all_strings(v, interpolation_hash)
    end
  else
    value
  end
end

.load!(config_file_path) ⇒ Object



191
192
193
194
# File 'lib/acpc_table_manager/config.rb', line 191

def self.load!(config_file_path)
  @@config_file = config_file_path
  load_config! YAML.load_file(config_file_path), File.dirname(config_file_path)
end

.load_config!(config_data, yaml_directory = File.pwd) ⇒ Object



132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
# File 'lib/acpc_table_manager/config.rb', line 132

def self.load_config!(config_data, yaml_directory = File.pwd)
  interpolation_hash = {
    pwd: yaml_directory,
    home: Dir.home,
    :~ => Dir.home,
    dealer_directory: AcpcDealer::DEALER_DIRECTORY
  }
  config = interpolate_all_strings(config_data, interpolation_hash)

  @@config = Config.new(
    config['table_manager_constants'],
    config['log_directory'],
    config['match_log_directory'],
    config['proxy_pids_file'],
    interpolation_hash
  )
  @@exhibition_config = ExhibitionConfig.new(
    config['exhibition_constants'],
    interpolation_hash,
    Logger.from_file_name(File.join(@@config.my_log_directory, 'exhibition_config.log'))
  )

  # Moped.logger = Logger.from_file_name(File.join(@@config.log_directory, 'moped.log'))
  # Mongoid.logger = Logger.from_file_name(File.join(@@config.log_directory, 'mongoid.log'))
  # TODO: These should be set in configuration files
  Moped.logger.level = ::Logger::FATAL
  Mongoid.logger.level = ::Logger::FATAL
  Mongoid.load!(config['mongoid_config'], config['mongoid_env'].to_sym)

  if config['error_report']
    Rusen.settings.sender_address = config['error_report']['sender']
    Rusen.settings.exception_recipients = config['error_report']['recipients']

    Rusen.settings.outputs = config['error_report']['outputs'] || [:pony]
    Rusen.settings.sections = config['error_report']['sections'] || [:backtrace]
    Rusen.settings.email_prefix = config['error_report']['email_prefix'] || '[ERROR] '
    Rusen.settings.smtp_settings = config['error_report']['smtp']

    @@notifier = Rusen
  else
    @@config.log(__method__, {warning: "Email reporting disabled. Please set email configuration to enable this feature."}, Logger::Severity::WARN)
  end

  if config['redis_config_file']
    @@redis_config_file = config['redis_config_file']
    redis_config = YAML.load_file(@@redis_config_file).symbolize_keys
    dflt = redis_config[:default].symbolize_keys
    @@redis = Redis.new(
      if config['redis_environment_mode'] && redis_config[config['redis_environment_mode'].to_sym]
        dflt.merge(redis_config[config['redis_environment_mode'].to_sym].symbolize_keys)
      else
        dflt
      end
    )
  end

  @@is_initialized = true
end

.new_log(log_file_name) ⇒ Object



208
209
210
211
# File 'lib/acpc_table_manager/config.rb', line 208

def self.new_log(log_file_name)
  raise_if_uninitialized
  Logger.from_file_name(File.join(@@config.my_log_directory, log_file_name)).with_metadata!
end

.notifierObject



130
# File 'lib/acpc_table_manager/config.rb', line 130

def self.notifier() @@notifier end

.notify(exception) ⇒ Object



196
197
198
# File 'lib/acpc_table_manager/config.rb', line 196

def self.notify(exception)
  @@notifier.notify(exception) if @@notifier
end

.raise_if_uninitializedObject



204
205
206
# File 'lib/acpc_table_manager/config.rb', line 204

def self.raise_if_uninitialized
  raise_uninitialized unless initialized?
end

.raise_uninitializedObject

Raises:



93
94
95
96
97
# File 'lib/acpc_table_manager/config.rb', line 93

def self.raise_uninitialized
  raise UninitializedError.new(
    "Unable to complete with AcpcTableManager uninitialized. Please initialize AcpcTableManager with configuration settings by calling AcpcTableManager.load! with a (YAML) configuration file name."
  )
end

.redisObject



124
# File 'lib/acpc_table_manager/config.rb', line 124

def self.redis() @@redis end

.redis_config_fileObject



121
# File 'lib/acpc_table_manager/config.rb', line 121

def self.redis_config_file() @@redis_config_file end

.resolve_path(path, root = __FILE__) ⇒ Object



14
15
16
17
18
19
20
21
# File 'lib/acpc_table_manager/utils.rb', line 14

def self.resolve_path(path, root = __FILE__)
  path = Pathname.new(path)
  if path.exist?
    path.realpath.to_s
  else
    File.expand_path(path, root)
  end
end

.unload!Object



213
214
215
# File 'lib/acpc_table_manager/config.rb', line 213

def self.unload!
  @@is_initialized = false
end