kibana-riya
Version:
Kibana is an open source (Apache Licensed), browser based analytics and search dashboard for Elasticsearch. Kibana is a snap to setup and start using. Kibana strives to be easy to get started with, while also being flexible and powerful, just like Elastic
80 lines (64 loc) • 3.84 kB
JavaScript
;
var _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
var loadFunctions = require('../load_functions.js');
var fitFunctions = loadFunctions('fit_functions');
var TimelionFunction = require('./timelion_function');
var offsetTime = require('../offset_time');
var _ = require('lodash');
var moment = require('moment');
function offsetSeries(response, offset) {
if (offset) {
response = _.map(response, function (point) {
return [offsetTime(point[0], offset, true), point[1]];
});
}
return response;
}
module.exports = (function (_TimelionFunction) {
_inherits(Datasource, _TimelionFunction);
function Datasource(name, config) {
_classCallCheck(this, Datasource);
// Additional arguments that every dataSource take
config.args.push({
name: 'offset',
types: ['string', 'null'],
help: 'Offset the series retrieval by a date expression. Eg -1M to make events from one month ago appear as if they are happening now'
});
config.args.push({
name: 'fit',
types: ['string', 'null'],
help: 'Algorithm to use for fitting series to the target time span and interval. Available: ' + _.keys(fitFunctions).join(', ')
});
// Wrap the original function so we can modify inputs/outputs with offset & fit
var originalFunction = config.fn;
config.fn = function (args, tlConfig) {
var config = _.clone(tlConfig);
if (args.byName.offset) {
config.time = _.cloneDeep(tlConfig.time);
config.time.from = offsetTime(config.time.from, args.byName.offset);
config.time.to = offsetTime(config.time.to, args.byName.offset);
}
return Promise.resolve(originalFunction(args, config)).then(function (seriesList) {
seriesList.list = _.map(seriesList.list, function (series) {
if (series.data.length === 0) throw new Error(name + '() returned no results');
series.data = offsetSeries(series.data, args.byName.offset);
series.fit = args.byName.fit || series.fit || 'nearest';
return series;
});
return seriesList;
});
};
_get(Object.getPrototypeOf(Datasource.prototype), 'constructor', this).call(this, name, config);
// You need to call timelionFn if calling up a datasource from another datasource,
// otherwise teh series will end up being offset twice.
this.timelionFn = originalFunction;
this.datasource = true;
this.cacheKey = function (item) {
return item.text;
};
Object.freeze(this);
}
return Datasource;
})(TimelionFunction);