* Update code generation (#969) * Updated code generation scripts to use the new spec * API generation * Fix bad link * Updated API reference doc (#945) * Updated API reference doc * Updated docs script * Fix issue; node roles are defaulting to true when undefined (fal… (#967) * Fix issue; nodeFilter was unable to filter because master, data, and ingest role were true if even they were false on the node. * Test nodesToHost of BaseConnectionPool correctly maps node roles * API generation * Docker: use 7.4-SNAPSHOT * API generation * Use 7.4 stable
102 lines
2.8 KiB
JavaScript
102 lines
2.8 KiB
JavaScript
// Licensed to Elasticsearch B.V under one or more agreements.
|
|
// Elasticsearch B.V licenses this file to you under the Apache 2.0 License.
|
|
// See the LICENSE file in the project root for more information
|
|
|
|
'use strict'
|
|
|
|
/* eslint camelcase: 0 */
|
|
/* eslint no-unused-vars: 0 */
|
|
|
|
function buildClusterHealth (opts) {
|
|
// eslint-disable-next-line no-unused-vars
|
|
const { makeRequest, ConfigurationError, handleError, snakeCaseKeys } = opts
|
|
|
|
const acceptedQuerystring = [
|
|
'expand_wildcards',
|
|
'level',
|
|
'local',
|
|
'master_timeout',
|
|
'timeout',
|
|
'wait_for_active_shards',
|
|
'wait_for_nodes',
|
|
'wait_for_events',
|
|
'wait_for_no_relocating_shards',
|
|
'wait_for_no_initializing_shards',
|
|
'wait_for_status',
|
|
'pretty',
|
|
'human',
|
|
'error_trace',
|
|
'source',
|
|
'filter_path'
|
|
]
|
|
|
|
const snakeCase = {
|
|
expandWildcards: 'expand_wildcards',
|
|
masterTimeout: 'master_timeout',
|
|
waitForActiveShards: 'wait_for_active_shards',
|
|
waitForNodes: 'wait_for_nodes',
|
|
waitForEvents: 'wait_for_events',
|
|
waitForNoRelocatingShards: 'wait_for_no_relocating_shards',
|
|
waitForNoInitializingShards: 'wait_for_no_initializing_shards',
|
|
waitForStatus: 'wait_for_status',
|
|
errorTrace: 'error_trace',
|
|
filterPath: 'filter_path'
|
|
}
|
|
|
|
/**
|
|
* Perform a cluster.health request
|
|
* Returns basic information about the health of the cluster.
|
|
* https://www.elastic.co/guide/en/elasticsearch/reference/master/cluster-health.html
|
|
*/
|
|
return function clusterHealth (params, options, callback) {
|
|
options = options || {}
|
|
if (typeof options === 'function') {
|
|
callback = options
|
|
options = {}
|
|
}
|
|
if (typeof params === 'function' || params == null) {
|
|
callback = params
|
|
params = {}
|
|
options = {}
|
|
}
|
|
|
|
// validate headers object
|
|
if (options.headers != null && typeof options.headers !== 'object') {
|
|
const err = new ConfigurationError(`Headers should be an object, instead got: ${typeof options.headers}`)
|
|
return handleError(err, callback)
|
|
}
|
|
|
|
var warnings = []
|
|
var { method, body, index, ...querystring } = params
|
|
querystring = snakeCaseKeys(acceptedQuerystring, snakeCase, querystring, warnings)
|
|
|
|
var ignore = options.ignore
|
|
if (typeof ignore === 'number') {
|
|
options.ignore = [ignore]
|
|
}
|
|
|
|
var path = ''
|
|
|
|
if ((index) != null) {
|
|
if (method == null) method = 'GET'
|
|
path = '/' + '_cluster' + '/' + 'health' + '/' + encodeURIComponent(index)
|
|
} else {
|
|
if (method == null) method = 'GET'
|
|
path = '/' + '_cluster' + '/' + 'health'
|
|
}
|
|
|
|
// build request object
|
|
const request = {
|
|
method,
|
|
path,
|
|
body: null,
|
|
querystring
|
|
}
|
|
|
|
options.warnings = warnings.length === 0 ? null : warnings
|
|
return makeRequest(request, options, callback)
|
|
}
|
|
}
|
|
|
|
module.exports = buildClusterHealth
|