Files
shields/lib/server-config.js
Marcin Mielnicki bc4bd79e90 Metrics with Prometheus (#2069)
* Basic process metrics

* Enable Prometheus by an environment variable

* Code formatting

* Documentation for Prometheus metrics

* Link from README to documentation of Prometheus

* Link from README to documentation of Prometheus

* Link from README to documentation of Prometheus

* Separate module for metrics + tests

* Metrics limited by IP

* Metrics are forbidded for all requets by default

* Code refactoring

* allowedIps passed as a string to PrometheusMetrics

* Handle missing config

* METRICS_PROMETHEUS_ALLOWED_IPS added to documentation

* Log info about enabled metrics

* Unused code removed

* package-lock.json updated

* prom-client updated to 11.1.2

* Code refactoring

* Do not read IP address from X-Forwarder-For header
2018-11-04 18:54:43 +01:00

88 lines
2.2 KiB
JavaScript

'use strict'
// This file should only be required by server.js. To simplify testing, config
// should be injected into other components needing it.
const url = require('url')
const envFlag = require('node-env-flag')
const defaults = require('./defaults')
function envArray(envVar, defaultValue, delimiter) {
delimiter = delimiter || ','
if (envVar) {
return envVar.split(delimiter)
} else {
return defaultValue
}
}
const isSecure = envFlag(process.env.HTTPS, false)
const port = +process.env.PORT || +process.argv[2] || (isSecure ? 443 : 80)
const address = process.env.BIND_ADDRESS || process.argv[3] || '::'
const baseUri = url.format({
protocol: isSecure ? 'https' : 'http',
hostname: address,
port,
pathname: '/',
})
// The base URI provides a suitable value for development. Production should
// configure this.
const allowedOrigin = envArray(
process.env.ALLOWED_ORIGIN,
baseUri.replace(/\/$/, ''),
','
)
const config = {
bind: {
port,
address,
},
metrics: {
prometheus: {
enabled: envFlag(process.env.METRICS_PROMETHEUS_ENABLED, false),
allowedIps: process.env.METRICS_PROMETHEUS_ALLOWED_IPS,
},
},
ssl: {
isSecure,
key: process.env.HTTPS_KEY,
cert: process.env.HTTPS_CRT,
},
baseUri,
redirectUri: process.env.REDIRECT_URI || process.env.INFOSITE,
cors: {
allowedOrigin,
},
persistence: {
dir: process.env.PERSISTENCE_DIR || './private',
redisUrl: process.env.REDIS_URL || process.env.REDISTOGO_URL,
},
services: {
github: {
baseUri: process.env.GITHUB_URL || 'https://api.github.com',
debug: {
enabled: envFlag(process.env.GITHUB_DEBUG_ENABLED, false),
intervalSeconds: process.env.GITHUB_DEBUG_INTERVAL_SECONDS || 300,
},
},
trace: envFlag(process.env.TRACE_SERVICES),
},
font: {
path: process.env.FONT_PATH || defaults.font.path,
fallbackPath: process.env.FALLBACK_FONT_PATH,
},
profiling: {
makeBadge: envFlag(process.env.PROFILE_MAKE_BADGE),
},
rateLimit: envFlag(process.env.RATE_LIMIT, true),
handleInternalErrors: envFlag(process.env.HANDLE_INTERNAL_ERRORS, true),
}
if (config.font.fallbackPath) {
console.log('FALLBACK_FONT_PATH is deprecated. Please use FONT_PATH.')
}
module.exports = config