UNPKG

elastic-builder

Version:

A JavaScript implementation of the elasticsearch Query DSL

94 lines (77 loc) 3.54 kB
'use strict'; var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var MetricsAggregationBase = require('./metrics-aggregation-base'); /** * A multi-value metrics aggregation that computes stats over numeric values * extracted from the aggregated documents. These values can be extracted either * from specific numeric fields in the documents, or be generated by a provided * script. * * [Elasticsearch reference](https://www.elastic.co/guide/en/elasticsearch/reference/current/search-aggregations-metrics-extendedstats-aggregation.html) * * Aggregation that computes extra stats over numeric values extracted from * the aggregated documents. * * @example * const agg = esb.extendedStatsAggregation('grades_stats', 'grade'); * * @example * // Compute the grade stats based on a script * const agg = esb.extendedStatsAggregation('grades_stats').script( * esb.script('inline', "doc['grade'].value").lang('painless') * ); * * @example * // Value script, apply grade correction * const agg = esb.extendedStatsAggregation('grades_stats', 'grade').script( * esb.script('inline', '_value * params.correction') * .lang('painless') * .params({ correction: 1.2 }) * ); * * @example * // Missing value * const agg = esb.extendedStatsAggregation('grades_stats', 'grade').missing(0); * * @param {string} name The name which will be used to refer to this aggregation. * @param {string=} field The field to aggregate on * * @extends MetricsAggregationBase */ var ExtendedStatsAggregation = function (_MetricsAggregationBa) { (0, _inherits3.default)(ExtendedStatsAggregation, _MetricsAggregationBa); // eslint-disable-next-line require-jsdoc function ExtendedStatsAggregation(name, field) { (0, _classCallCheck3.default)(this, ExtendedStatsAggregation); return (0, _possibleConstructorReturn3.default)(this, (ExtendedStatsAggregation.__proto__ || Object.getPrototypeOf(ExtendedStatsAggregation)).call(this, name, 'extended_stats', field)); } /** * Set sigma in the request for getting custom boundary. * sigma controls how many standard deviations +/- from the mean should be displayed * * @example * const agg = esb.extendedStatsAggregation('grades_stats', 'grade').sigma(3); * * @param {number} sigma sigma can be any non-negative double, * meaning you can request non-integer values such as 1.5. * A value of 0 is valid, but will simply return the average for both upper and lower bounds. * @returns {ExtendedStatsAggregation} returns `this` so that calls can be chained */ (0, _createClass3.default)(ExtendedStatsAggregation, [{ key: 'sigma', value: function sigma(_sigma) { this._aggsDef.sigma = _sigma; return this; } }]); return ExtendedStatsAggregation; }(MetricsAggregationBase); module.exports = ExtendedStatsAggregation;