Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Security Assistant] Adds new Knowledge Base Management Settings UI #192665

Merged
merged 43 commits into from
Sep 25, 2024
Merged
Show file tree
Hide file tree
Changes from 36 commits
Commits
Show all changes
43 commits
Select commit Hold shift + click to select a range
88ca1f5
Adds v2 knowledge base setting UI
spong Sep 12, 2024
f45073c
Merge branch 'main' of github.com:elastic/kibana into kb-settings-v2
spong Sep 12, 2024
484dddb
Merge branch 'main' of github.com:elastic/kibana into kb-settings-v2
spong Sep 13, 2024
433e3af
Support creating new entries via flyout, plumb space accessors, and m…
spong Sep 13, 2024
85b2519
Merge branch 'main' of github.com:elastic/kibana into kb-settings-v2
spong Sep 16, 2024
4c2ff08
Further remove reliance on esStore and better separates legacy KB act…
spong Sep 16, 2024
d4b6c57
Add support for creating IndexEntries, fix edit action on table, fix …
spong Sep 16, 2024
7e5dbdc
Merge branch 'main' of github.com:elastic/kibana into kb-settings-v2
spong Sep 16, 2024
a549876
Merge branch 'main' of github.com:elastic/kibana into kb-settings-v2
spong Sep 16, 2024
ffe96c0
[CI] Auto-commit changed files from 'node scripts/notice'
kibanamachine Sep 16, 2024
eafa7f0
Merge branch 'kb-settings-v2' of github.com:spong/kibana into kb-sett…
spong Sep 16, 2024
5f28dab
Remove spaces dependencies
spong Sep 16, 2024
b3346d8
i18n fix
spong Sep 16, 2024
bd4dac0
Adding setup and helpers for API integration tests using tiny_elser
spong Sep 17, 2024
d46d2da
Check types and test fixes
spong Sep 17, 2024
1a83aa7
Merge branch 'main' of github.com:elastic/kibana into kb-settings-v2
spong Sep 17, 2024
645b3b8
Fixes API integration tests by adding support for pt_tiny_elser, spec…
spong Sep 18, 2024
2d47574
Merge branch 'main' of github.com:elastic/kibana into kb-settings-v2
spong Sep 18, 2024
de89153
Merge branch 'main' of github.com:elastic/kibana into kb-settings-v2
spong Sep 18, 2024
0947e65
Fix kbDataClient mocks
spong Sep 18, 2024
2de9a1e
Fix build and start fleshing out entries API tests
spong Sep 18, 2024
cf73d4c
Remove suite on serverless and fix checktypes
spong Sep 19, 2024
dc26f10
Adds support for testing multiple spaces and users
spong Sep 19, 2024
1c5156f
Merge branch 'main' of github.com:elastic/kibana into kb-settings-v2
spong Sep 19, 2024
7ae6be1
Fix imports
spong Sep 20, 2024
9620065
Merge branch 'main' of github.com:elastic/kibana into kb-settings-v2
spong Sep 20, 2024
c81250b
Fixes from self-review
spong Sep 20, 2024
d566200
Removing unused file
spong Sep 20, 2024
8b111e3
Enable feature flag for ci:cloud-deploy testing
spong Sep 21, 2024
989b67c
Merge branch 'main' into kb-settings-v2
spong Sep 23, 2024
68757c9
Disable feature flag and remove V2 schema from ci:cloud testing
spong Sep 23, 2024
f160f26
Merge branch 'main' into kb-settings-v2
elasticmachine Sep 23, 2024
7447394
Add http client files for creating spaces roles users and data
spong Sep 24, 2024
2b82a8a
Merge branch 'main' of github.com:elastic/kibana into kb-settings-v2
spong Sep 24, 2024
830c455
Add back alert label
spong Sep 24, 2024
29decc2
Merge branch 'kb-settings-v2' of github.com:spong/kibana into kb-sett…
spong Sep 24, 2024
ac494d7
Fix alert count not saving, fix entries being queries on stack mgmt p…
spong Sep 24, 2024
4d151a5
Fix and tests for only viewing current users private entries and all …
spong Sep 25, 2024
988e9b1
Disable required entry checkbox
spong Sep 25, 2024
10ed936
Merge branch 'main' of github.com:elastic/kibana into kb-settings-v2
spong Sep 25, 2024
cdec104
Remove mappings code change in favor of FF
spong Sep 25, 2024
44be735
Fix test mocks
spong Sep 25, 2024
4b3d3dd
Sanitize function names
spong Sep 25, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,22 @@
"port": "5601",
"basePath": "",
"elasticApiVersion": "1",
"elasticsearch": {
"host": "localhost",
"port": "9200"
},
"auth": {
"username": "elastic",
"password": "changeme"
"admin": {
"username": "elastic",
"password": "changeme"
},
"assistant_system": {
spong marked this conversation as resolved.
Show resolved Hide resolved
"username": "assistant_system",
"password": "changeme"
}
},
"appContext": {
"management": "%7B%22type%22%3A%22application%22%2C%22name%22%3A%22management%22%2C%22url%22%3A%22%2Fkbn%2Fapp%2Fmanagement%22%2C%22page%22%3A%22%22%7D",
"security": "%7B%22type%22%3A%22application%22%2C%22name%22%3A%22securitySolutionUI%22%2C%22url%22%3A%22%2Fkbn%2Fapp%2Fsecurity%22%7D"
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,15 @@ export const KnowledgeBaseResponse = z.object({
success: z.boolean().optional(),
});

export type CreateKnowledgeBaseRequestQuery = z.infer<typeof CreateKnowledgeBaseRequestQuery>;
export const CreateKnowledgeBaseRequestQuery = z.object({
/**
* Optional ELSER modelId to use when setting up the Knowledge Base
*/
modelId: z.string().optional(),
});
export type CreateKnowledgeBaseRequestQueryInput = z.input<typeof CreateKnowledgeBaseRequestQuery>;

export type CreateKnowledgeBaseRequestParams = z.infer<typeof CreateKnowledgeBaseRequestParams>;
export const CreateKnowledgeBaseRequestParams = z.object({
/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,12 @@ paths:
description: The KnowledgeBase `resource` value.
schema:
type: string
- name: modelId
in: query
description: Optional ELSER modelId to use when setting up the Knowledge Base
required: false
schema:
type: string
responses:
200:
description: Indicates a successful call.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ POST http://{{host}}:{{port}}{{basePath}}/internal/elastic_assistant/knowledge_b
kbn-xsrf: "true"
Content-Type: application/json
Elastic-Api-Version: {{elasticApiVersion}}
Authorization: Basic {{auth.username}} {{auth.password}}
Authorization: Basic {{auth.admin.username}} {{auth.admin.password}}
X-Kbn-Context: {{appContext.security}}

{
Expand Down
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
### Create Document Entry
### Create Document Entry (Admin)
POST http://{{host}}:{{port}}{{basePath}}/internal/elastic_assistant/knowledge_base/entries
kbn-xsrf: "true"
Content-Type: application/json
Elastic-Api-Version: {{elasticApiVersion}}
Authorization: Basic {{auth.username}} {{auth.password}}
Authorization: Basic {{auth.admin.username}} {{auth.admin.password}}
X-Kbn-Context: {{appContext.security}}

{
Expand All @@ -15,31 +15,44 @@ X-Kbn-Context: {{appContext.security}}
"text": "My favorite food is Dan Bing"
}

### Create Index Entry
### Create Index Entry (Admin)
POST http://{{host}}:{{port}}{{basePath}}/internal/elastic_assistant/knowledge_base/entries
kbn-xsrf: "true"
Content-Type: application/json
Elastic-Api-Version: {{elasticApiVersion}}
Authorization: Basic {{auth.username}} {{auth.password}}
Authorization: Basic {{auth.admin.username}} {{auth.admin.password}}
X-Kbn-Context: {{appContext.security}}

{
"type": "index",
"name": "SpongBotSlackConnector",
"name": "SlackConnector (Admin)",
"namespace": "default",
"index": "spongbot-slack",
"index": "slackbot-test",
"field": "semantic_text",
"description": "Use this index to search for the user's Slack messages.",
"queryDescription":
"The free text search that the user wants to perform over this dataset. So if asking \"what are my slack messages from last week about failed tests\", the query would be \"A test has failed! failing test failed test\"",
"inputSchema": [
{
"fieldName": "author",
"fieldType": "string",
"description": "The author of the message. So if asking for recent messages from Stan, you would provide 'Stan' as the author."
}
],
"outputFields": ["author", "text", "timestamp"]
"outputFields": ["author", "text", "timestamp"]
}

### Create Index Entry (Assistant System)
POST http://{{host}}:{{port}}{{basePath}}/internal/elastic_assistant/knowledge_base/entries
kbn-xsrf: "true"
Content-Type: application/json
Elastic-Api-Version: {{elasticApiVersion}}
Authorization: Basic {{auth.assistant_system.username}} {{auth.assistant_system.password}}
X-Kbn-Context: {{appContext.security}}

{
"type": "index",
"name": "SlackConnector (Assistant System)",
"namespace": "default",
"index": "slackbot-test",
"field": "semantic_text",
"description": "Use this index to search for the user's Slack messages.",
"queryDescription":
"The free text search that the user wants to perform over this dataset. So if asking \"what are my slack messages from last week about failed tests\", the query would be \"A test has failed! failing test failed test\"",
"outputFields": ["author", "text", "timestamp"]
}


Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
### Find all knowledge base entries
GET http://{{host}}:{{port}}{{basePath}}/internal/elastic_assistant/knowledge_base/entries/_find
Elastic-Api-Version: {{elasticApiVersion}}
Authorization: Basic {{auth.username}} {{auth.password}}
Authorization: Basic {{auth.admin.username}} {{auth.admin.password}}
X-Kbn-Context: {{appContext.security}}

Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,4 @@ export const indexEntryMock: IndexEntryCreateFields = {
description: "Use this index to search for the user's Slack messages.",
queryDescription:
'The free text search that the user wants to perform over this dataset. So if asking "what are my slack messages from last week about failed tests", the query would be "A test has failed! failing test failed test".',
inputSchema: [
{
fieldName: 'author',
fieldType: 'string',
description:
"The author of the message. So if asking for recent messages from Stan, you would provide 'Stan' as the author.",
},
],
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,182 @@
### Create Space-X
POST http://{{host}}:{{port}}{{basePath}}/api/spaces/space
kbn-xsrf: "true"
Content-Type: application/json
Elastic-Api-Version: {{elasticApiVersion}}
Authorization: Basic {{auth.admin.username}} {{auth.admin.password}}

{
"name": "Space-X",
"id": "space-x",
"initials": "🚀",
"color": "#9170B8",
"disabledFeatures": [],
"imageUrl": ""
}

### Create Space-Y
POST http://{{host}}:{{port}}{{basePath}}/api/spaces/space
kbn-xsrf: "true"
Content-Type: application/json
Elastic-Api-Version: {{elasticApiVersion}}
Authorization: Basic {{auth.admin.username}} {{auth.admin.password}}

{
"name": "Space-Y",
"id": "space-y",
"initials": "🛰",
"color": "#DA8B45",
"disabledFeatures": [],
"imageUrl": ""
}

### Create assistant_admin Role - All Spaces, All Features
PUT http://{{host}}:{{port}}{{basePath}}/api/security/role/assistant_admin
kbn-xsrf: "true"
Content-Type: application/json
Elastic-Api-Version: {{elasticApiVersion}}
Authorization: Basic {{auth.admin.username}} {{auth.admin.password}}

{
"description": "Grants access to all Security Assistant features in all spaces",
"elasticsearch": {
"cluster": [
"all"
],
"indices": [
{
"names": [
"*"
],
"privileges": [
"all"
],
"field_security": {
"grant": [
"*"
],
"except": []
}
}
],
"run_as": []
},
"kibana": [
{
"spaces": [
"*"
],
"base": [],
"feature": {
"siem": [
"all"
],
"securitySolutionCases": [
"all"
],
"securitySolutionAssistant": [
"all"
],
"securitySolutionAttackDiscovery": [
"all"
],
"aiAssistantManagementSelection": [
"all"
],
"searchInferenceEndpoints": [
"all"
],
"dev_tools": [
"all"
],
"actions": [
"all"
],
"indexPatterns": [
"all"
]
}
}
]
}

### Create assistant_system User - All Spaces, All Features
POST http://{{host}}:{{port}}{{basePath}}/internal/security/users/assistant_system
kbn-xsrf: "true"
Content-Type: application/json
Elastic-Api-Version: {{elasticApiVersion}}
Authorization: Basic {{auth.admin.username}} {{auth.admin.password}}

{
"password": "{{auth.assistant_system.password}}",
"username": "{{auth.assistant_system.username}}",
"full_name": "Assistant System",
"email": "",
"roles": [
"assistant_admin"
]
}

### Create Inference Endpoint
PUT http://{{elasticsearch.host}}:{{elasticsearch.port}}/_inference/sparse_embedding/elser_model_2
Content-Type: application/json
Authorization: Basic {{auth.admin.username}} {{auth.admin.password}}

{
"service": "elser",
"service_settings": {
"num_allocations": 1,
"num_threads": 1
}
}

### Create Slackbot Mappings
PUT http://{{elasticsearch.host}}:{{elasticsearch.port}}/slackbot-test
Content-Type: application/json
Authorization: Basic {{auth.admin.username}} {{auth.admin.password}}

{
"settings": {
"number_of_shards": 1
},
"mappings": {
"dynamic": "true",
"properties": {
"semantic_text": {
"type": "semantic_text",
"inference_id": "elser_model_2",
"model_settings": {
"task_type": "sparse_embedding"
}
},
"text": {
"type": "text",
"copy_to": [
"semantic_text"
]
}
}
}
}

### Create Slackbot Document
POST http://{{elasticsearch.host}}:{{elasticsearch.port}}/slackbot-test/_doc
Content-Type: application/json
Authorization: Basic {{auth.admin.username}} {{auth.admin.password}}

{
"subtype": null,
"author": "spong",
"edited_ts": null,
"thread_ts": "1727113718.664029",
"channel": "dev-details",
"text": "The Dude: That rug really tied the room together.",
"id": "C0A6H3AA1BL-1727115800.120029",
"type": "message",
"reply_count": null,
"ts": "1727115800.120029",
"latest_reply": null
}



Original file line number Diff line number Diff line change
Expand Up @@ -5,19 +5,12 @@
* 2.0.
*/

import {
EuiFlexGroup,
EuiFlexItem,
EuiFormRow,
EuiRange,
EuiSpacer,
EuiText,
useGeneratedHtmlId,
} from '@elastic/eui';
import { EuiFlexGroup, EuiFormRow, EuiFlexItem, EuiSpacer, EuiText } from '@elastic/eui';
import { css } from '@emotion/react';
import React from 'react';

import { KnowledgeBaseConfig } from '../../assistant/types';
import { AlertsRange } from '../../knowledge_base/alerts_range';
import * as i18n from '../../knowledge_base/translations';

export const MIN_LATEST_ALERTS = 10;
Expand All @@ -32,8 +25,6 @@ interface Props {
}

const AlertsSettingsComponent = ({ knowledgeBase, setUpdatedKnowledgeBaseSettings }: Props) => {
const inputRangeSliderId = useGeneratedHtmlId({ prefix: 'inputRangeSlider' });

return (
<>
<EuiFormRow
Expand All @@ -58,22 +49,9 @@ const AlertsSettingsComponent = ({ knowledgeBase, setUpdatedKnowledgeBaseSetting
grow={false}
>
<EuiSpacer size="xs" />
<EuiRange
aria-label={i18n.ALERTS_RANGE}
compressed
data-test-subj="alertsRange"
id={inputRangeSliderId}
max={MAX_LATEST_ALERTS}
min={MIN_LATEST_ALERTS}
onChange={(e) =>
setUpdatedKnowledgeBaseSettings({
...knowledgeBase,
latestAlerts: Number(e.currentTarget.value),
})
}
showTicks
step={TICK_INTERVAL}
value={knowledgeBase.latestAlerts}
<AlertsRange
knowledgeBase={knowledgeBase}
setUpdatedKnowledgeBaseSettings={setUpdatedKnowledgeBaseSettings}
/>
<EuiSpacer size="s" />
</EuiFlexItem>
Expand Down
Loading