Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/master' into nls/create-alerts
Browse files Browse the repository at this point in the history
  • Loading branch information
smith committed Sep 28, 2021
2 parents f4461d8 + 39e0632 commit 88a8789
Show file tree
Hide file tree
Showing 212 changed files with 15,465 additions and 3,509 deletions.
27 changes: 27 additions & 0 deletions .eslintrc.js
Original file line number Diff line number Diff line change
Expand Up @@ -930,6 +930,15 @@ module.exports = {
'@typescript-eslint/no-explicit-any': 'error',
'@typescript-eslint/no-useless-constructor': 'error',
'@typescript-eslint/unified-signatures': 'error',
'no-restricted-imports': [
'error',
{
// prevents code from importing files that contain the name "legacy" within their name. This is a mechanism
// to help deprecation and prevent accidental re-use/continued use of code we plan on removing. If you are
// finding yourself turning this off a lot for "new code" consider renaming the file and functions if it is has valid uses.
patterns: ['*legacy*'],
},
],
},
},
{
Expand Down Expand Up @@ -1192,6 +1201,15 @@ module.exports = {
'no-template-curly-in-string': 'error',
'sort-keys': 'error',
'prefer-destructuring': 'error',
'no-restricted-imports': [
'error',
{
// prevents code from importing files that contain the name "legacy" within their name. This is a mechanism
// to help deprecation and prevent accidental re-use/continued use of code we plan on removing. If you are
// finding yourself turning this off a lot for "new code" consider renaming the file and functions if it has valid uses.
patterns: ['*legacy*'],
},
],
},
},
/**
Expand Down Expand Up @@ -1304,6 +1322,15 @@ module.exports = {
'no-template-curly-in-string': 'error',
'sort-keys': 'error',
'prefer-destructuring': 'error',
'no-restricted-imports': [
'error',
{
// prevents code from importing files that contain the name "legacy" within their name. This is a mechanism
// to help deprecation and prevent accidental re-use/continued use of code we plan on removing. If you are
// finding yourself turning this off a lot for "new code" consider renaming the file and functions if it has valid uses.
patterns: ['*legacy*'],
},
],
},
},
/**
Expand Down
1 change: 1 addition & 0 deletions .github/CODEOWNERS
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@
/examples/url_generators_examples/ @elastic/kibana-app-services
/examples/url_generators_explorer/ @elastic/kibana-app-services
/examples/field_formats_example/ @elastic/kibana-app-services
/examples/partial_results_example/ @elastic/kibana-app-services
/packages/elastic-datemath/ @elastic/kibana-app-services
/packages/kbn-interpreter/ @elastic/kibana-app-services
/src/plugins/bfetch/ @elastic/kibana-app-services
Expand Down
4 changes: 2 additions & 2 deletions docs/setup/secure-settings.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@ To create the `kibana.keystore`, use the `create` command:
bin/kibana-keystore create
----------------------------------------------------------------

The file `kibana.keystore` will be created in the directory defined by the
<<path-data, `path.data`>> configuration setting.
The file `kibana.keystore` will be created in the `config` directory defined by the
environment variable `KBN_PATH_CONF`.

[float]
[[list-settings]]
Expand Down
9 changes: 9 additions & 0 deletions examples/partial_results_example/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
## Partial Results Example

The partial results is a feature of the expressions plugin allowing to emit intermediate execution results over time.

This example plugin demonstrates:

1. An expression function emitting a datatable with intermediate results (`getEvents`).
2. An expression function emitting an infinite number of results (`countEvent`).
3. A combination of those two functions using the `mapColumn` function that continuously updates the resulting table.
12 changes: 12 additions & 0 deletions examples/partial_results_example/kibana.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
{
"id": "paertialResultsExample",
"version": "0.1.0",
"kibanaVersion": "kibana",
"ui": true,
"owner": {
"name": "App Services",
"githubTeam": "kibana-app-services"
},
"description": "A plugin demonstrating partial results in the expressions plugin",
"requiredPlugins": ["developerExamples", "expressions"]
}
90 changes: 90 additions & 0 deletions examples/partial_results_example/public/app/app.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
/*
* 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.
*/

import React, { useContext, useEffect, useState } from 'react';
import { pluck } from 'rxjs/operators';
import {
EuiBasicTable,
EuiCallOut,
EuiCodeBlock,
EuiPage,
EuiPageBody,
EuiPageContent,
EuiPageContentBody,
EuiPageHeader,
EuiPageHeaderSection,
EuiSpacer,
EuiText,
EuiTitle,
} from '@elastic/eui';
import type { Datatable } from 'src/plugins/expressions';
import { ExpressionsContext } from './expressions_context';

const expression = `getEvents
| mapColumn name="Count" expression={
countEvent {pluck "event"}
}
`;

export function App() {
const expressions = useContext(ExpressionsContext);
const [datatable, setDatatable] = useState<Datatable>();

useEffect(() => {
const subscription = expressions
?.execute<null, Datatable>(expression, null)
.getData()
.pipe(pluck('result'))
.subscribe((value) => setDatatable(value as Datatable));

return () => subscription?.unsubscribe();
}, [expressions]);

return (
<EuiPage>
<EuiPageBody style={{ maxWidth: 1200, margin: '0 auto' }}>
<EuiPageHeader>
<EuiPageHeaderSection>
<EuiTitle size="l">
<h1>Partial Results Demo</h1>
</EuiTitle>
</EuiPageHeaderSection>
</EuiPageHeader>
<EuiPageContent>
<EuiPageContentBody style={{ maxWidth: 800, margin: '0 auto' }}>
<EuiText data-test-subj="example-help">
<p>
This example listens for the window events and adds them to the table along with a
trigger counter.
</p>
</EuiText>
<EuiSpacer size={'m'} />
<EuiCodeBlock>{expression}</EuiCodeBlock>
<EuiSpacer size={'m'} />
{datatable ? (
<EuiBasicTable
textOnly={true}
data-test-subj={'example-table'}
columns={datatable.columns?.map(({ id: field, name }) => ({
field,
name,
'data-test-subj': `example-column-${field.toLowerCase()}`,
}))}
items={datatable.rows ?? []}
/>
) : (
<EuiCallOut color="success">
<p>Click or press any key.</p>
</EuiCallOut>
)}
</EuiPageContentBody>
</EuiPageContent>
</EuiPageBody>
</EuiPage>
);
}
12 changes: 12 additions & 0 deletions examples/partial_results_example/public/app/expressions_context.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
/*
* 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.
*/

import { createContext } from 'react';
import type { ExpressionsServiceStart } from 'src/plugins/expressions';

export const ExpressionsContext = createContext<ExpressionsServiceStart | undefined>(undefined);
10 changes: 10 additions & 0 deletions examples/partial_results_example/public/app/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
/*
* 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.
*/

export * from './app';
export * from './expressions_context';
40 changes: 40 additions & 0 deletions examples/partial_results_example/public/functions/count_event.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
/*
* 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.
*/

import { Observable, fromEvent } from 'rxjs';
import { scan, startWith } from 'rxjs/operators';
import type { ExpressionFunctionDefinition } from 'src/plugins/expressions';

export interface CountEventArguments {
event: string;
}

export const countEvent: ExpressionFunctionDefinition<
'countEvent',
null,
CountEventArguments,
Observable<number>
> = {
name: 'countEvent',
type: 'number',
help: 'Subscribes for an event and counts a number of triggers.',
args: {
event: {
aliases: ['_'],
types: ['string'],
help: 'The event name.',
required: true,
},
},
fn(input, { event }) {
return fromEvent(window, event).pipe(
scan((count) => count + 1, 1),
startWith(1)
);
},
};
51 changes: 51 additions & 0 deletions examples/partial_results_example/public/functions/get_events.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
/*
* 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.
*/

import { Observable, fromEvent, merge } from 'rxjs';
import { distinct, map, pluck, scan, take } from 'rxjs/operators';
import type { Datatable, ExpressionFunctionDefinition } from 'src/plugins/expressions';

const EVENTS: Array<keyof WindowEventMap> = [
'mousedown',
'mouseup',
'click',
'keydown',
'keyup',
'keypress',
];

export const getEvents: ExpressionFunctionDefinition<
'getEvents',
null,
{},
Observable<Datatable>
> = {
name: 'getEvents',
type: 'datatable',
help: 'Listens for the window events and returns a table with the triggered ones.',
args: {},
fn() {
return merge(...EVENTS.map((event) => fromEvent(window, event))).pipe(
pluck('type'),
distinct(),
take(EVENTS.length),
scan((events, event) => [...events, event], [] as string[]),
map((events) => ({
type: 'datatable',
columns: [
{
id: 'event',
meta: { type: 'string' },
name: 'Event',
},
],
rows: Array.from(events).map((event) => ({ event })),
}))
);
},
};
11 changes: 11 additions & 0 deletions examples/partial_results_example/public/functions/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
/*
* 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.
*/

export * from './count_event';
export * from './get_events';
export * from './pluck';
32 changes: 32 additions & 0 deletions examples/partial_results_example/public/functions/pluck.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
/*
* 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.
*/

import type { Datatable, ExpressionFunctionDefinition } from 'src/plugins/expressions';

export interface PluckArguments {
key: string;
}

export const pluck: ExpressionFunctionDefinition<'pluck', Datatable, PluckArguments, unknown> = {
name: 'pluck',
inputTypes: ['datatable'],
help: 'Takes a cell from the first table row.',
args: {
key: {
aliases: ['_'],
types: ['string'],
help: 'The column id.',
required: true,
},
},
fn({ rows }, { key }) {
const [{ [key]: value }] = rows;

return value;
},
};
12 changes: 12 additions & 0 deletions examples/partial_results_example/public/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
/*
* 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.
*/
import { PartialResultsExamplePlugin } from './plugin';

export function plugin() {
return new PartialResultsExamplePlugin();
}
Loading

0 comments on commit 88a8789

Please sign in to comment.