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

[Rules migration] Add Integrations column (#11387) #204639

Merged

Conversation

e40pud
Copy link
Contributor

@e40pud e40pud commented Dec 17, 2024

Summary

Internal link to the feature details

These changes add a functionality which enables related integrations functionality for migration rules:

  • related integration are shown in the migration rules table
  • user can navigate to the integration page to see instructions about installation process

Other tasks and fixes

  • Default sorting in the table (by Stats => by Author => by Severity => by Updated)

Note

This feature needs siemMigrationsEnabled experimental flag enabled to work.

Screen recording

Screenshot 2024-12-17 at 19 26 47

@e40pud e40pud added release_note:skip Skip the PR/issue when compiling release notes Team:Threat Hunting Security Solution Threat Hunting Team Team: SecuritySolution Security Solutions Team working on SIEM, Endpoint, Timeline, Resolver, etc. backport:prev-minor Backport to (8.x) the previous minor version (i.e. one version back from main) labels Dec 17, 2024
@e40pud e40pud requested a review from semd December 17, 2024 18:27
@e40pud e40pud self-assigned this Dec 17, 2024
@e40pud e40pud requested review from a team as code owners December 17, 2024 18:28
@elasticmachine
Copy link
Contributor

Pinging @elastic/security-solution (Team: SecuritySolution)

@elasticmachine
Copy link
Contributor

Pinging @elastic/security-threat-hunting (Team:Threat Hunting)

username: string,
esClient: ElasticsearchClient,
logger: Logger,
private packageService?: PackageService
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@semd I added a packageService?: PackageService here into RuleMigrationsDataIntegrationsClient. If I understood correctly, @P1llus will also need access to it at some point.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think it's the best approach to drill a hole through the ruleMigration classes whenever we need a new client/service from the context. But we can keep it this way until we implement a more generic way to get them.

@elastic-vault-github-plugin-prod elastic-vault-github-plugin-prod bot requested a review from a team as a code owner December 19, 2024 14:33
@semd semd removed the request for review from a team December 19, 2024 16:24
@@ -396,6 +396,26 @@ paths:
additionalProperties:
$ref: '../../rule_migration.schema.yaml#/components/schemas/PrebuiltRuleVersion'

/internal/siem_migrations/rules/{migration_id}/integrations:
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we have the {migration_id} in the path? I am confused

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This needs to be /internal/siem_migrations/rules/integrations

@@ -43,7 +44,7 @@ export interface PrebuiltRulesResults {
* @param rulesIds The list of IDs to filter requested prebuilt rules. If not specified, all available prebuilt rules will be returned.
* @returns
*/
export const getPrebuiltRules = async (
export const getPrebuiltRulesByIds = async (
Copy link
Contributor

@semd semd Dec 19, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not sure about this rename, ruleIds is an optional parameter

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

will switch it back 👍

@@ -31,7 +31,7 @@ export class SiemMigrationsService {
}

createRulesClient(params: SiemRuleMigrationsCreateClientParams): SiemRuleMigrationsClient {
return this.rules.createClient(params);
return this.rules.createClient({ ...params });
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this is leftover from my previous approach, where I. was passing packageService here.. will clean it up

Copy link
Contributor

@semd semd left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM!

@elasticmachine
Copy link
Contributor

💚 Build Succeeded

Metrics [docs]

Module Count

Fewer modules leads to a faster build time

id before after diff
securitySolution 6534 6536 +2

Async chunks

Total size of all lazy-loaded chunks that will be downloaded as the user navigates the app

id before after diff
securitySolution 22.2MB 22.2MB +2.1KB

History

cc @e40pud

@e40pud e40pud merged commit 019f0e8 into elastic:main Jan 8, 2025
8 checks passed
@kibanamachine
Copy link
Contributor

Starting backport for target branches: 8.x

https://github.com/elastic/kibana/actions/runs/12674245797

@kibanamachine
Copy link
Contributor

💔 All backports failed

Status Branch Result
8.x Backport failed because of merge conflicts

You might need to backport the following PRs to 8.x:
- [Rules migration] Retry failed translations (#11383) (#204619)

Manual backport

To create the backport manually run:

node scripts/backport --pr 204639

Questions ?

Please refer to the Backport tool documentation

@e40pud
Copy link
Contributor Author

e40pud commented Jan 9, 2025

💚 All backports created successfully

Status Branch Result
8.x

Note: Successful backport PRs will be merged automatically after passing CI.

Questions ?

Please refer to the Backport tool documentation

e40pud added a commit to e40pud/kibana that referenced this pull request Jan 9, 2025
…4639)

## Summary

[Internal link](elastic/security-team#10820)
to the feature details

These changes add a functionality which enables related integrations
functionality for migration rules:
* related integration are shown in the migration rules table
* user can navigate to the integration page to see instructions about
installation process

### Other tasks and fixes

* Default sorting in the table (by `Stats` => by `Author` => by
`Severity` => by `Updated`)

> [!NOTE]
> This feature needs `siemMigrationsEnabled` experimental flag enabled
to work.

## Screen recording

<img width="1838" alt="Screenshot 2024-12-17 at 19 26 47"
src="https://github.com/user-attachments/assets/c1ed9d5d-e237-4dfe-b144-a80adbf46cd3"
/>

---------

Co-authored-by: kibanamachine <[email protected]>
(cherry picked from commit 019f0e8)
e40pud added a commit that referenced this pull request Jan 9, 2025
…206005)

# Backport

This will backport the following commits from `main` to `8.x`:
- [[Rules migration] Add Integrations column (#11387)
(#204639)](#204639)

<!--- Backport version: 8.9.8 -->

### Questions ?
Please refer to the [Backport tool
documentation](https://github.com/sqren/backport)

<!--BACKPORT [{"author":{"name":"Ievgen
Sorokopud","email":"[email protected]"},"sourceCommit":{"committedDate":"2025-01-08T15:57:24Z","message":"[Rules
migration] Add Integrations column (#11387) (#204639)\n\n##
Summary\r\n\r\n[Internal
link](https://github.com/elastic/security-team/issues/10820)\r\nto the
feature details\r\n\r\nThese changes add a functionality which enables
related integrations\r\nfunctionality for migration rules:\r\n* related
integration are shown in the migration rules table\r\n* user can
navigate to the integration page to see instructions
about\r\ninstallation process\r\n\r\n### Other tasks and fixes\r\n\r\n*
Default sorting in the table (by `Stats` => by `Author` =>
by\r\n`Severity` => by `Updated`)\r\n\r\n> [!NOTE] \r\n> This feature
needs `siemMigrationsEnabled` experimental flag enabled\r\nto
work.\r\n\r\n## Screen recording\r\n\r\n<img width=\"1838\"
alt=\"Screenshot 2024-12-17 at 19 26
47\"\r\nsrc=\"https://github.com/user-attachments/assets/c1ed9d5d-e237-4dfe-b144-a80adbf46cd3\"\r\n/>\r\n\r\n---------\r\n\r\nCo-authored-by:
kibanamachine
<[email protected]>","sha":"019f0e84146e668376f923c0c77ef48f5c302e68","branchLabelMapping":{"^v9.0.0$":"main","^v8.18.0$":"8.x","^v(\\d+).(\\d+).\\d+$":"$1.$2"}},"sourcePullRequest":{"labels":["release_note:skip","v9.0.0","Team:Threat
Hunting","Team:
SecuritySolution","backport:prev-minor"],"number":204639,"url":"https://github.com/elastic/kibana/pull/204639","mergeCommit":{"message":"[Rules
migration] Add Integrations column (#11387) (#204639)\n\n##
Summary\r\n\r\n[Internal
link](https://github.com/elastic/security-team/issues/10820)\r\nto the
feature details\r\n\r\nThese changes add a functionality which enables
related integrations\r\nfunctionality for migration rules:\r\n* related
integration are shown in the migration rules table\r\n* user can
navigate to the integration page to see instructions
about\r\ninstallation process\r\n\r\n### Other tasks and fixes\r\n\r\n*
Default sorting in the table (by `Stats` => by `Author` =>
by\r\n`Severity` => by `Updated`)\r\n\r\n> [!NOTE] \r\n> This feature
needs `siemMigrationsEnabled` experimental flag enabled\r\nto
work.\r\n\r\n## Screen recording\r\n\r\n<img width=\"1838\"
alt=\"Screenshot 2024-12-17 at 19 26
47\"\r\nsrc=\"https://github.com/user-attachments/assets/c1ed9d5d-e237-4dfe-b144-a80adbf46cd3\"\r\n/>\r\n\r\n---------\r\n\r\nCo-authored-by:
kibanamachine
<[email protected]>","sha":"019f0e84146e668376f923c0c77ef48f5c302e68"}},"sourceBranch":"main","suggestedTargetBranches":[],"targetPullRequestStates":[{"branch":"main","label":"v9.0.0","labelRegex":"^v9.0.0$","isSourceBranch":true,"state":"MERGED","url":"https://github.com/elastic/kibana/pull/204639","number":204639,"mergeCommit":{"message":"[Rules
migration] Add Integrations column (#11387) (#204639)\n\n##
Summary\r\n\r\n[Internal
link](https://github.com/elastic/security-team/issues/10820)\r\nto the
feature details\r\n\r\nThese changes add a functionality which enables
related integrations\r\nfunctionality for migration rules:\r\n* related
integration are shown in the migration rules table\r\n* user can
navigate to the integration page to see instructions
about\r\ninstallation process\r\n\r\n### Other tasks and fixes\r\n\r\n*
Default sorting in the table (by `Stats` => by `Author` =>
by\r\n`Severity` => by `Updated`)\r\n\r\n> [!NOTE] \r\n> This feature
needs `siemMigrationsEnabled` experimental flag enabled\r\nto
work.\r\n\r\n## Screen recording\r\n\r\n<img width=\"1838\"
alt=\"Screenshot 2024-12-17 at 19 26
47\"\r\nsrc=\"https://github.com/user-attachments/assets/c1ed9d5d-e237-4dfe-b144-a80adbf46cd3\"\r\n/>\r\n\r\n---------\r\n\r\nCo-authored-by:
kibanamachine
<[email protected]>","sha":"019f0e84146e668376f923c0c77ef48f5c302e68"}}]}]
BACKPORT-->
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
backport:prev-minor Backport to (8.x) the previous minor version (i.e. one version back from main) release_note:skip Skip the PR/issue when compiling release notes Team: SecuritySolution Security Solutions Team working on SIEM, Endpoint, Timeline, Resolver, etc. Team:Threat Hunting Security Solution Threat Hunting Team v8.18.0 v9.0.0
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants