"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.getEsaggs = getEsaggs; exports.getFunctionDefinition = getFunctionDefinition; var _lodash = require("lodash"); var _rxjs = require("rxjs"); var _operators = require("rxjs/operators"); var _i18n = require("@kbn/i18n"); var _expressions = require("../../../common/search/expressions"); /* * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one * or more contributor license agreements. Licensed under the Elastic License * 2.0 and the Server Side Public License, v 1; you may not use this file except * in compliance with, at your election, the Elastic License 2.0 or the Server * Side Public License, v 1. */ /** * Returns the expression function definition. Any stateful dependencies are accessed * at runtime via the `getStartDependencies` param, which provides the specific services * needed for this function to run. * * This function is an implementation detail of this module, and is exported separately * only for testing purposes. * * @param getStartDependencies - async function that resolves with EsaggsStartDependencies * * @internal */ function getFunctionDefinition({ getStartDependencies }) { return () => ({ ...(0, _expressions.getEsaggsMeta)(), fn(input, args, { inspectorAdapters, abortSignal, getSearchSessionId, getKibanaRequest }) { return (0, _rxjs.defer)(async () => { var _args$aggs$map, _args$aggs; const kibanaRequest = getKibanaRequest ? getKibanaRequest() : null; if (!kibanaRequest) { throw new Error(_i18n.i18n.translate('data.search.esaggs.error.kibanaRequest', { defaultMessage: 'A KibanaRequest is required to execute this search on the server. ' + 'Please provide a request object to the expression execution params.' })); } const { aggs, indexPatterns, searchSource } = await getStartDependencies(kibanaRequest); const indexPattern = await indexPatterns.create(args.index.value, true); const aggConfigs = aggs.createAggConfigs(indexPattern, (_args$aggs$map = (_args$aggs = args.aggs) === null || _args$aggs === void 0 ? void 0 : _args$aggs.map(agg => agg.value)) !== null && _args$aggs$map !== void 0 ? _args$aggs$map : [], { hierarchical: args.metricsAtAllLevels, partialRows: args.partialRows }); return { aggConfigs, indexPattern, searchSource }; }).pipe((0, _operators.switchMap)(({ aggConfigs, indexPattern, searchSource }) => (0, _expressions.handleEsaggsRequest)({ abortSignal, aggs: aggConfigs, filters: (0, _lodash.get)(input, 'filters', undefined), indexPattern, inspectorAdapters, query: (0, _lodash.get)(input, 'query', undefined), searchSessionId: getSearchSessionId(), searchSourceService: searchSource, disableShardWarnings: false, timeFields: args.timeFields, timeRange: (0, _lodash.get)(input, 'timeRange', undefined) }))); } }); } /** * This is some glue code that takes in `core.getStartServices`, extracts the dependencies * needed for this function, and wraps them behind a `getStartDependencies` function that * is then called at runtime. * * We do this so that we can be explicit about exactly which dependencies the function * requires, without cluttering up the top-level `plugin.ts` with this logic. It also * makes testing the expression function a bit easier since `getStartDependencies` is * the only thing you should need to mock. * * @param getStartServices - core's StartServicesAccessor for this plugin * * @internal */ function getEsaggs({ getStartServices }) { return getFunctionDefinition({ getStartDependencies: async request => { const [{ elasticsearch, savedObjects },, self] = await getStartServices(); const { indexPatterns, search } = self; const esClient = elasticsearch.client.asScoped(request); const savedObjectsClient = savedObjects.getScopedClient(request); return { aggs: await search.aggs.asScopedToClient(savedObjectsClient, esClient.asCurrentUser), indexPatterns: await indexPatterns.dataViewsServiceFactory(savedObjectsClient, esClient.asCurrentUser), searchSource: await search.searchSource.asScoped(request) }; } }); }