kibana/x-pack/plugins/monitoring/config.js

85 lines
3.3 KiB
JavaScript

/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License;
* you may not use this file except in compliance with the Elastic License.
*/
import { XPACK_INFO_API_DEFAULT_POLL_FREQUENCY_IN_MILLIS } from '../../server/lib/constants';
/**
* User-configurable settings for xpack.monitoring via configuration schema
* @param {Object} Joi - HapiJS Joi module that allows for schema validation
* @return {Object} config schema
*/
export const config = (Joi) => {
const { array, boolean, number, object, string } = Joi;
const DEFAULT_REQUEST_HEADERS = ['authorization'];
return object({
ccs: object({
enabled: boolean().default(true)
}).default(),
enabled: boolean().default(true),
ui: object({
enabled: boolean().default(true),
container: object({
elasticsearch: object({
enabled: boolean().default(false)
}).default(),
logstash: object({
enabled: boolean().default(false)
}).default()
}).default()
}).default(),
index_pattern: string().default('.monitoring-*-2-*,.monitoring-*-6-*'),
kibana: object({
index_pattern: string().default('.monitoring-kibana-2-*,.monitoring-kibana-6-*'),
collection: object({
enabled: boolean().default(true),
interval: number().default(10000) // op status metrics get buffered at `ops.interval` and flushed to the bulk endpoint at this interval
}).default()
}).default(),
logstash: object({
index_pattern: string().default('.monitoring-logstash-2-*,.monitoring-logstash-6-*')
}).default(),
beats: object({
index_pattern: string().default('.monitoring-beats-6-*')
}).default(),
cluster_alerts: object({
enabled: boolean().default(true),
index: string().default('.monitoring-alerts-6'),
email_notifications: object({
enabled: boolean().default(true),
email_address: string().email(),
}).default()
}).default(),
xpack_api_polling_frequency_millis: number().default(XPACK_INFO_API_DEFAULT_POLL_FREQUENCY_IN_MILLIS),
max_bucket_size: number().default(10000),
min_interval_seconds: number().default(10),
show_license_expiration: boolean().default(true),
report_stats: boolean().default(true),
agent: object({
interval: string().regex(/[\d\.]+[yMwdhms]/).default('10s')
}).default(),
elasticsearch: object({
customHeaders: object().default({}),
index_pattern: string().default('.monitoring-es-2-*,.monitoring-es-6-*'),
logQueries: boolean().default(false),
requestHeadersWhitelist: array().items().single().default(DEFAULT_REQUEST_HEADERS),
url: string().uri({ scheme: ['http', 'https'] }), // if empty, use Kibana's connection config
username: string(),
password: string(),
requestTimeout: number().default(30000),
pingTimeout: number().default(30000),
ssl: object({
verificationMode: string().valid('none', 'certificate', 'full').default('full'),
certificateAuthorities: array().single().items(string()),
certificate: string(),
key: string(),
keyPassphrase: string()
}).default(),
apiVersion: string().default('master')
}).default()
}).default();
};