e6cf4b36d3
* Ensure we use existing Elasticsearch config * Use separate type for this to ensure custom properties work * PR suggestions * PR feedback * PR feedback * Fix type issues * PR feedback
96 lines
3.3 KiB
TypeScript
96 lines
3.3 KiB
TypeScript
/*
|
|
* 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 { schema, TypeOf } from '@kbn/config-schema';
|
|
import {
|
|
config as ElasticsearchBaseConfig,
|
|
ElasticsearchConfig,
|
|
} from '../../../../src/core/server/';
|
|
|
|
const hostURISchema = schema.uri({ scheme: ['http', 'https'] });
|
|
|
|
const elasticsearchConfigSchema = ElasticsearchBaseConfig.elasticsearch.schema;
|
|
type ElasticsearchConfigType = TypeOf<typeof elasticsearchConfigSchema>;
|
|
|
|
export const monitoringElasticsearchConfigSchema = elasticsearchConfigSchema.extends({
|
|
logFetchCount: schema.number({ defaultValue: 10 }),
|
|
hosts: schema.maybe(schema.oneOf([hostURISchema, schema.arrayOf(hostURISchema, { minSize: 1 })])),
|
|
});
|
|
|
|
export const configSchema = schema.object({
|
|
enabled: schema.boolean({ defaultValue: true }),
|
|
elasticsearch: monitoringElasticsearchConfigSchema,
|
|
ui: schema.object({
|
|
enabled: schema.boolean({ defaultValue: true }),
|
|
ccs: schema.object({
|
|
enabled: schema.boolean({ defaultValue: true }),
|
|
}),
|
|
logs: schema.object({
|
|
index: schema.string({ defaultValue: 'filebeat-*' }),
|
|
}),
|
|
max_bucket_size: schema.number({ defaultValue: 10000 }),
|
|
elasticsearch: monitoringElasticsearchConfigSchema,
|
|
container: schema.object({
|
|
elasticsearch: schema.object({
|
|
enabled: schema.boolean({ defaultValue: false }),
|
|
}),
|
|
logstash: schema.object({
|
|
enabled: schema.boolean({ defaultValue: false }),
|
|
}),
|
|
}),
|
|
min_interval_seconds: schema.number({ defaultValue: 10 }),
|
|
show_license_expiration: schema.boolean({ defaultValue: true }),
|
|
}),
|
|
kibana: schema.object({
|
|
collection: schema.object({
|
|
enabled: schema.boolean({ defaultValue: true }),
|
|
interval: schema.number({ defaultValue: 10000 }), // op status metrics get buffered at `ops.interval` and flushed to the bulk endpoint at this interval
|
|
}),
|
|
}),
|
|
cluster_alerts: schema.object({
|
|
enabled: schema.boolean({ defaultValue: true }),
|
|
email_notifications: schema.object({
|
|
enabled: schema.boolean({ defaultValue: true }),
|
|
email_address: schema.string({ defaultValue: '' }),
|
|
}),
|
|
}),
|
|
licensing: schema.object({
|
|
api_polling_frequency: schema.duration({
|
|
defaultValue: '30s',
|
|
}),
|
|
}),
|
|
agent: schema.object({
|
|
interval: schema.string({ defaultValue: '10s' }),
|
|
// TOOD: NP
|
|
// .regex(/[\d\.]+[yMwdhms]/)
|
|
}),
|
|
tests: schema.object({
|
|
cloud_detector: schema.object({
|
|
enabled: schema.boolean({ defaultValue: true }),
|
|
}),
|
|
}),
|
|
});
|
|
|
|
export class MonitoringElasticsearchConfig extends ElasticsearchConfig {
|
|
public readonly logFetchCount?: number;
|
|
|
|
constructor(rawConfig: TypeOf<typeof monitoringElasticsearchConfigSchema>) {
|
|
super(rawConfig as ElasticsearchConfigType);
|
|
this.logFetchCount = rawConfig.logFetchCount;
|
|
}
|
|
}
|
|
|
|
export type MonitoringConfig = ReturnType<typeof createConfig>;
|
|
export function createConfig(config: TypeOf<typeof configSchema>) {
|
|
return {
|
|
...config,
|
|
elasticsearch: new ElasticsearchConfig(config.elasticsearch as ElasticsearchConfigType),
|
|
ui: {
|
|
...config.ui,
|
|
elasticsearch: new MonitoringElasticsearchConfig(config.ui.elasticsearch),
|
|
},
|
|
};
|
|
}
|