Menu

Shinken Arbiter Configure

module.exports = (service) ->
  options = service.options
  # Auto-discovery of Modules
  options.modules ?= {}
  configmod = (name, mod) =>
    if mod.version?
      mod.type ?= name
      mod.archive ?= "mod-#{name}-#{mod.version}"
      mod.format ?= 'zip'
      mod.source ?= "https://github.com/shinken-monitoring/mod-#{name}/archive/#{mod.version}.#{mod.format}"
      mod.config_file ?= "#{name}.cfg"
    mod.modules ?= {}
    mod.config ?= {}
    mod.config.modules = [mod.config.modules] if typeof mod.config.modules is 'string'
    mod.config.modules ?= Object.keys mod.modules
    mod.python_modules ?= {}
    for pyname, pymod of mod.python_modules
      pymod.format ?= 'tar.gz'
      pymod.archive ?= "#{pyname}-#{pymod.version}"
      pymod.url ?= "https://pypi.python.org/simple/#{pyname}/#{pymod.archive}.#{pymod.format}"
    for subname, submod of mod.modules then configmod subname, submod
  for name, mod of options.modules then configmod name, mod
  options.broker_hosts ?= service.deps.broker.map( (srv) -> srv.node.fqdn )

Identities

  options.user ?= merge {}, service.deps.commons.options.user, options.user
  options.group ?= merge {}, service.deps.commons.options.group, options.user

Credentials

  options.credentials ?= service.deps.monitoring.options.credentials
  for key in ['hostgroups', 'contactgroups', 'commands', 'realms', 'dependencies', 
    'escalations', 'timeperiods','hosts', 'services', 'contacts'
  ]
    options[key] ?= service.deps.monitoring.options[key]

Build Dir

  options.build_dir = service.deps.commons.options.build_dir
  options.plugin_dir = service.deps.commons.options.plugin_dir

Config

This configuration is used by arbiter to send the configuration when arbiter synchronize configuration through network. The generated file must be on the arbiter host.

  options.config ?= {}
  options.config.host ?= '0.0.0.0'
  options.config.port ?= 7770
  options.config.spare ?= '0'
  options.config.modules = [options.config.modules] if typeof options.config.modules is 'string'
  options.config.modules ?= Object.keys options.modules if options.modules
  options.config.distributed ?= service.deps.arbiter.length > 1
  options.config.hostname ?= options.fqdn
  options.config.user = options.user.name
  options.config.group = options.group.name
  #Misc
  options.iptables ?= !!service.deps.iptables and service.deps.iptables?.options?.action is 'start'
  options.prepare ?= service.deps.arbiter[0].node.fqdn is service.node.fqdn
  options.fqdn ?= service.node.fqdn

SSL

  options.ssl = merge {}, service.deps.ssl?.options, options.ssl
  options.ssl.enabled ?= !!service.deps.ssl
  if options.ssl.enabled
    options.config['use_ssl'] ?= '1'
    options.config['hard_ssl_name_check'] ?= '1'
    throw Error 'Missing options.ssl.cacert' unless options.ssl.cacert
    throw Error 'Missing options.ssl.cert' unless options.ssl.cert
    throw Error 'Missing options.ssl.key' unless options.ssl.key
    options.config['ca_cert'] ?= '/etc/shinken/certs/ca.pem'
    options.config['server_cert'] ?= '/etc/shinken/certs/cert.pem'
    options.config['server_key'] ?= '/etc/shinken/certs/key.pem'
  else
    options.config['use_ssl'] ?= '0'
    options.config['hard_ssl_name_check'] ?= '0'

Shinken Modules Configuration

Gather all shinken's arbiter, scheduler, poller, broker modules to render

  options.arbiter_modules ?= options.modules if options.modules #to normalize config
  options.broker_modules ?= service.deps.broker[0].options.modules if service.deps.broker
  options.poller_modules ?= service.deps.poller[0].options.modules if service.deps.poller
  options.reactionner_modules ?= service.deps.reactionner[0].options.modules if service.deps.reactionner
  options.receiver_modules ?= service.deps.receiver[0].options.modules if service.deps.receiver
  options.scheduler_modules ?= service.deps.scheduler[0].options.modules if service.deps.scheduler

Shinken Daemons Configuration

Gather all shinken's arbiter, scheduler, poller, broker daemons config to render.

  #arbiter
  options.arbiter_daemons ?= service.deps.arbiter.map( (srv) ->
    fqdn: srv.node.fqdn
    shortname: srv.node.hostname
    port: srv.options.config.port or options.config.port
    spare: srv.options.config.spare or (if options.config.spare is '0' then '1' else '0')
    modules: Object.keys srv.options.modules or Object.keys options.arbiter_modules
    use_ssl: srv.options.config.use_ssl or options.config.use_ssl
    hard_ssl_name_check: srv.options.config.hard_ssl_name_check or options.config.hard_ssl_name_check
  )
  #broker
  options.broker_daemons ?= service.deps.broker.map( (srv) ->
    fqdn: srv.node.fqdn
    shortname: srv.node.hostname
    port: srv.options.config.port
    spare: srv.options.config.spare
    modules: Object.keys srv.options.modules
    use_ssl: srv.options.config.use_ssl
    hard_ssl_name_check: srv.options.config.hard_ssl_name_check
    manage_arbiters: srv.options.config.manage_arbiters
    realm: srv.options.config.realm
  )
  #poller
  options.poller_daemons ?= service.deps.poller.map( (srv) ->
    fqdn: srv.node.fqdn
    shortname: srv.node.hostname
    port: srv.options.config.port
    spare: srv.options.config.spare
    modules: Object.keys srv.options.config.modules
    tags: srv.options.config.tags
    use_ssl: srv.options.config.use_ssl
    hard_ssl_name_check: srv.options.config.hard_ssl_name_check
    realm: srv.options.config.realm
  )
  #reactionner
  options.reactionner_daemons ?= service.deps.reactionner.map( (srv) ->
    fqdn: srv.node.fqdn
    shortname: srv.node.hostname
    port: srv.options.config.port
    spare: srv.options.config.spare
    modules: Object.keys srv.options.config.modules
    tags: srv.options.config.tags
    use_ssl: srv.options.config.use_ssl
    hard_ssl_name_check: srv.options.config.hard_ssl_name_check
    realm: srv.options.config.realm
  )
  #receiver
  options.receiver_daemons ?= service.deps.receiver.map( (srv) ->
    fqdn: srv.node.fqdn
    shortname: srv.node.hostname
    port: srv.options.config.port
    spare: srv.options.config.spare
    modules: Object.keys srv.options.config.modules
    use_ssl: srv.options.config.use_ssl
    hard_ssl_name_check: srv.options.config.hard_ssl_name_check
    realm: srv.options.config.realm
  )
  #scheduler
  options.scheduler_daemons ?= service.deps.scheduler.map( (srv) ->
    fqdn: srv.node.fqdn
    shortname: srv.node.hostname
    port: srv.options.config.port
    spare: srv.options.config.spare
    modules: Object.keys srv.options.modules
    use_ssl: srv.options.config.use_ssl
    hard_ssl_name_check: srv.options.config.hard_ssl_name_check
    realm: srv.options.config.realm
  )

Wait

  options.wait ?= {}
  options.wait.tcp ?= for srv in service.deps.arbiter
    host: srv.node.fqdn
    port: srv.options.config.port or options.config.port

Dependencies

{merge} = require '@nikitajs/core/lib/misc'