Skip to content

Commit

Permalink
[8.x] [Cloud Posture] Adding CSP 3P support callout for Wiz integrati…
Browse files Browse the repository at this point in the history
…on (#196025) (#196274)

# Backport

This will backport the following commits from `main` to `8.x`:
- [[Cloud Posture] Adding CSP 3P support callout for Wiz integration
(#196025)](#196025)

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

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

<!--BACKPORT
[{"author":{"name":"Jordan","email":"[email protected]"},"sourceCommit":{"committedDate":"2024-10-14T12:35:25Z","message":"[Cloud
Posture] Adding CSP 3P support callout for Wiz integration
(#196025)","sha":"ebe16fa467d6e35e2398ad724780db05c27779cf","branchLabelMapping":{"^v9.0.0$":"main","^v8.16.0$":"8.x","^v(\\d+).(\\d+).\\d+$":"$1.$2"}},"sourcePullRequest":{"labels":["release_note:skip","Team:Fleet","v9.0.0","Team:Cloud
Security","backport:prev-minor"],"number":196025,"url":"https://github.com/elastic/kibana/pull/196025","mergeCommit":{"message":"[Cloud
Posture] Adding CSP 3P support callout for Wiz integration
(#196025)","sha":"ebe16fa467d6e35e2398ad724780db05c27779cf"}},"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/196025","number":196025,"mergeCommit":{"message":"[Cloud
Posture] Adding CSP 3P support callout for Wiz integration
(#196025)","sha":"ebe16fa467d6e35e2398ad724780db05c27779cf"}}]}]
BACKPORT-->

---------

Co-authored-by: kibanamachine <[email protected]>
  • Loading branch information
JordanSh and kibanamachine authored Oct 15, 2024
1 parent 85ab195 commit 60d3fef
Show file tree
Hide file tree
Showing 3 changed files with 93 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
/*
* 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; you may not use this file except in compliance with the Elastic License
* 2.0.
*/

import React from 'react';
import { render, screen } from '@testing-library/react';

import useLocalStorage from 'react-use/lib/useLocalStorage';

import type { PackageInfo } from '../../../../../../../../common';

import { CloudPostureThirdPartySupportCallout } from './cloud_posture_third_party_support_callout';

jest.mock('react-use/lib/useLocalStorage');

describe('CloudPostureThirdPartySupportCallout', () => {
const mockPackageInfo = { name: 'wiz' } as PackageInfo;

beforeEach(() => {
(useLocalStorage as jest.Mock).mockClear();
});

it('renders callout when package is wiz and callout is not dismissed', () => {
(useLocalStorage as jest.Mock).mockReturnValue([false, jest.fn()]);

render(<CloudPostureThirdPartySupportCallout packageInfo={mockPackageInfo} />);

expect(screen.getByText(/New! Starting from version 1.9/)).toBeInTheDocument();
});

it('does not render callout when package is not wiz', () => {
const nonWizPackageInfo = { name: 'other' } as PackageInfo;
render(<CloudPostureThirdPartySupportCallout packageInfo={nonWizPackageInfo} />);

expect(screen.queryByText(/New! Starting from version 1.9/)).not.toBeInTheDocument();
});

it('does not render callout when it has been dismissed', () => {
(useLocalStorage as jest.Mock).mockReturnValue([true, jest.fn()]);

render(<CloudPostureThirdPartySupportCallout packageInfo={mockPackageInfo} />);

expect(screen.queryByText(/New! Starting from version 1.9/)).not.toBeInTheDocument();
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
/*
* 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; you may not use this file except in compliance with the Elastic License
* 2.0.
*/

import React from 'react';
import useLocalStorage from 'react-use/lib/useLocalStorage';
import { EuiCallOut, EuiSpacer } from '@elastic/eui';
import { i18n } from '@kbn/i18n';

import type { PackageInfo } from '../../../../../../../../common';

const LS_CLOUD_POSTURE_3P_SUPPORT_WIZ_INTEGRATIONS_CALLOUT_KEY =
'fleet:cloudSecurityPosture:thirdPartySupport:wizIntegrationsCallout';

export const CloudPostureThirdPartySupportCallout = ({
packageInfo,
}: {
packageInfo: PackageInfo;
}) => {
const [userHasDismissedWizCallout, setUserHasDismissedWizCallout] = useLocalStorage(
LS_CLOUD_POSTURE_3P_SUPPORT_WIZ_INTEGRATIONS_CALLOUT_KEY
);

if (packageInfo.name !== 'wiz' || userHasDismissedWizCallout) return null;

return (
<>
<EuiCallOut
onDismiss={() => setUserHasDismissedWizCallout(true)}
iconType="cheer"
title={i18n.translate('xpack.fleet.epm.wizIntegration.newFeaturesCallout', {
defaultMessage:
'New! Starting from version 1.9, ingest vulnerability and misconfiguration findings from Wiz into Elastic. Leverage out-of-the-box contextual investigation and threat-hunting workflows.',
})}
/>
<EuiSpacer size="s" />
</>
);
};
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,8 @@ import { SideBarColumn } from '../../../components/side_bar_column';

import type { FleetStartServices } from '../../../../../../../plugin';

import { CloudPostureThirdPartySupportCallout } from '../components/cloud_posture_third_party_support_callout';

import { Screenshots } from './screenshots';
import { Readme } from './readme';
import { Details } from './details';
Expand Down Expand Up @@ -319,6 +321,7 @@ export const OverviewPage: React.FC<Props> = memo(
<EuiSpacer size="s" />
</>
)}
<CloudPostureThirdPartySupportCallout packageInfo={packageInfo} />
{isPrerelease && (
<PrereleaseCallout
packageName={packageInfo.name}
Expand Down

0 comments on commit 60d3fef

Please sign in to comment.