Skip to content

Commit

Permalink
[8.15] [Stream] Fix callout privileges (#198030) (#198278)
Browse files Browse the repository at this point in the history
# Backport

This will backport the following commits from `main` to `8.15`:
- [[Stream] Fix callout privileges
(#198030)](#198030)

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

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

<!--BACKPORT
[{"author":{"name":"mohamedhamed-ahmed","email":"[email protected]"},"sourceCommit":{"committedDate":"2024-10-30T08:43:35Z","message":"[Stream]
Fix callout privileges (#198030)\n\ncloses
https://github.com/elastic/kibana/issues/197044\r\ncloses
https://github.com/elastic/kibana/issues/197988\r\n\r\n## 📝
Summary\r\n\r\nThe PR targets fixing 3 bugs:\r\n\r\n1. The callout
shouldn't be shown if `Logs Explorer` isn't available,\r\notherwise the
link displayed in the callout will cause a problem.
[Fix\r\nhere](https://github.com/elastic/kibana/pull/198030/files#diff-8c5f793d1bf0d933c73047f31ded8a5a65f91e4f8d5230fc4e40dfb9b245fec1R66)\r\n2.
The callout shouldn't be shown if `Logs Explorer` is available
but\r\nthe user doesn't have privilege to access it, otherwise we end up
in\r\n`Application Not Found` page.
[Fix\r\nhere](https://github.com/elastic/kibana/pull/198030/files#diff-8c5f793d1bf0d933c73047f31ded8a5a65f91e4f8d5230fc4e40dfb9b245fec1R66)\r\n3.
The side nav entry for `Logs Explorer` should be hidden if
`Logs\r\nExplorer` is disabled.
[Fix\r\nhere](https://github.com/elastic/kibana/pull/198030/files#diff-ad4e42fbe4d2a7a99ec5d52fbf127ded12f0efe02a10e3afa0409b40be1f4bcfR397)","sha":"5576316abadc4115020f2e22bd823b413c8e98a2","branchLabelMapping":{"^v9.0.0$":"main","^v8.17.0$":"8.x","^v(\\d+).(\\d+).\\d+$":"$1.$2"}},"sourcePullRequest":{"labels":["bug","release_note:skip","v9.0.0","ci:project-deploy-observability","Team:obs-ux-logs","Team:obs-ux-infra_services","v8.15.0","v8.16.0","backport:version","v8.17.0"],"number":198030,"url":"https://github.com/elastic/kibana/pull/198030","mergeCommit":{"message":"[Stream]
Fix callout privileges (#198030)\n\ncloses
https://github.com/elastic/kibana/issues/197044\r\ncloses
https://github.com/elastic/kibana/issues/197988\r\n\r\n## 📝
Summary\r\n\r\nThe PR targets fixing 3 bugs:\r\n\r\n1. The callout
shouldn't be shown if `Logs Explorer` isn't available,\r\notherwise the
link displayed in the callout will cause a problem.
[Fix\r\nhere](https://github.com/elastic/kibana/pull/198030/files#diff-8c5f793d1bf0d933c73047f31ded8a5a65f91e4f8d5230fc4e40dfb9b245fec1R66)\r\n2.
The callout shouldn't be shown if `Logs Explorer` is available
but\r\nthe user doesn't have privilege to access it, otherwise we end up
in\r\n`Application Not Found` page.
[Fix\r\nhere](https://github.com/elastic/kibana/pull/198030/files#diff-8c5f793d1bf0d933c73047f31ded8a5a65f91e4f8d5230fc4e40dfb9b245fec1R66)\r\n3.
The side nav entry for `Logs Explorer` should be hidden if
`Logs\r\nExplorer` is disabled.
[Fix\r\nhere](https://github.com/elastic/kibana/pull/198030/files#diff-ad4e42fbe4d2a7a99ec5d52fbf127ded12f0efe02a10e3afa0409b40be1f4bcfR397)","sha":"5576316abadc4115020f2e22bd823b413c8e98a2"}},"sourceBranch":"main","suggestedTargetBranches":["8.15","8.16","8.x"],"targetPullRequestStates":[{"branch":"main","label":"v9.0.0","labelRegex":"^v9.0.0$","isSourceBranch":true,"state":"MERGED","url":"https://github.com/elastic/kibana/pull/198030","number":198030,"mergeCommit":{"message":"[Stream]
Fix callout privileges (#198030)\n\ncloses
https://github.com/elastic/kibana/issues/197044\r\ncloses
https://github.com/elastic/kibana/issues/197988\r\n\r\n## 📝
Summary\r\n\r\nThe PR targets fixing 3 bugs:\r\n\r\n1. The callout
shouldn't be shown if `Logs Explorer` isn't available,\r\notherwise the
link displayed in the callout will cause a problem.
[Fix\r\nhere](https://github.com/elastic/kibana/pull/198030/files#diff-8c5f793d1bf0d933c73047f31ded8a5a65f91e4f8d5230fc4e40dfb9b245fec1R66)\r\n2.
The callout shouldn't be shown if `Logs Explorer` is available
but\r\nthe user doesn't have privilege to access it, otherwise we end up
in\r\n`Application Not Found` page.
[Fix\r\nhere](https://github.com/elastic/kibana/pull/198030/files#diff-8c5f793d1bf0d933c73047f31ded8a5a65f91e4f8d5230fc4e40dfb9b245fec1R66)\r\n3.
The side nav entry for `Logs Explorer` should be hidden if
`Logs\r\nExplorer` is disabled.
[Fix\r\nhere](https://github.com/elastic/kibana/pull/198030/files#diff-ad4e42fbe4d2a7a99ec5d52fbf127ded12f0efe02a10e3afa0409b40be1f4bcfR397)","sha":"5576316abadc4115020f2e22bd823b413c8e98a2"}},{"branch":"8.15","label":"v8.15.0","labelRegex":"^v(\\d+).(\\d+).\\d+$","isSourceBranch":false,"state":"NOT_CREATED"},{"branch":"8.16","label":"v8.16.0","labelRegex":"^v(\\d+).(\\d+).\\d+$","isSourceBranch":false,"state":"NOT_CREATED"},{"branch":"8.x","label":"v8.17.0","labelRegex":"^v8.17.0$","isSourceBranch":false,"state":"NOT_CREATED"}]}]
BACKPORT-->

---------

Co-authored-by: kibanamachine <[email protected]>
  • Loading branch information
mohamedhamed-ahmed and kibanamachine authored Oct 31, 2024
1 parent 0dfe553 commit 3883400
Show file tree
Hide file tree
Showing 3 changed files with 158 additions and 89 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,19 @@
*/

import { History } from 'history';
import { CoreStart } from '@kbn/core/public';
import React from 'react';
import React, { useMemo } from 'react';
import ReactDOM from 'react-dom';
import useObservable from 'react-use/lib/useObservable';
import { map } from 'rxjs';
import { CoreStart } from '@kbn/core/public';
import { Router, Routes, Route } from '@kbn/shared-ux-router';
import { AppMountParameters } from '@kbn/core/public';
import { AppMountParameters, AppStatus } from '@kbn/core/public';
import { Storage } from '@kbn/kibana-utils-plugin/public';
import { AllDatasetsLocatorParams, ALL_DATASETS_LOCATOR_ID } from '@kbn/deeplinks-observability';
import {
AllDatasetsLocatorParams,
ALL_DATASETS_LOCATOR_ID,
OBSERVABILITY_LOGS_EXPLORER_APP_ID,
} from '@kbn/deeplinks-observability';
import { LinkToLogsPage } from '../pages/link_to/link_to_logs';
import { LogsPage } from '../pages/logs';
import { InfraClientStartDeps, InfraClientStartExports } from '../types';
Expand Down Expand Up @@ -57,7 +63,25 @@ const LogsApp: React.FC<{
storage: Storage;
theme$: AppMountParameters['theme$'];
}> = ({ core, history, pluginStart, plugins, setHeaderActionMenu, storage, theme$ }) => {
const { logs, discover, fleet } = core.application.capabilities;
const {
capabilities: { logs },
applications$,
} = core.application;

const isLogsExplorerAppAccessible = useObservable(
useMemo(
() =>
applications$.pipe(
map(
(apps) =>
(apps.get(OBSERVABILITY_LOGS_EXPLORER_APP_ID)?.status ?? AppStatus.inaccessible) ===
AppStatus.accessible
)
),
[applications$]
),
false
);

return (
<CoreProviders core={core} pluginStart={pluginStart} plugins={plugins} theme$={theme$}>
Expand All @@ -74,7 +98,7 @@ const LogsApp: React.FC<{
toastsService={core.notifications.toasts}
>
<Routes>
{Boolean(discover?.show && fleet?.read) && (
{isLogsExplorerAppAccessible && (
<Route
path="/"
exact
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,32 +5,57 @@
* 2.0.
*/

import React, { useMemo } from 'react';
import useObservable from 'react-use/lib/useObservable';
import { map } from 'rxjs';
import { EuiCallOut } from '@elastic/eui';
import React from 'react';
import { i18n } from '@kbn/i18n';
import { EuiButton } from '@elastic/eui';
import { AllDatasetsLocatorParams, ALL_DATASETS_LOCATOR_ID } from '@kbn/deeplinks-observability';
import {
AllDatasetsLocatorParams,
ALL_DATASETS_LOCATOR_ID,
DatasetLocatorParams,
OBSERVABILITY_LOGS_EXPLORER_APP_ID,
} from '@kbn/deeplinks-observability';
import { getRouterLinkProps } from '@kbn/router-utils';
import useLocalStorage from 'react-use/lib/useLocalStorage';

import { AppStatus } from '@kbn/core/public';
import { euiThemeVars } from '@kbn/ui-theme';
import { css } from '@emotion/css';
import { SharePublicStart } from '@kbn/share-plugin/public/plugin';
import { LocatorPublic } from '@kbn/share-plugin/common';
import { useKibanaContextForPlugin } from '../hooks/use_kibana';

const DISMISSAL_STORAGE_KEY = 'log_stream_deprecation_callout_dismissed';

export const LogsDeprecationCallout = () => {
const {
services: { share },
services: { share, application },
} = useKibanaContextForPlugin();

const [isDismissed, setDismissed] = useLocalStorage(DISMISSAL_STORAGE_KEY, false);

if (isDismissed) {
const isLogsExplorerAppAccessible = useObservable(
useMemo(
() =>
application.applications$.pipe(
map(
(apps) =>
(apps.get(OBSERVABILITY_LOGS_EXPLORER_APP_ID)?.status ?? AppStatus.inaccessible) ===
AppStatus.accessible
)
),
[application.applications$]
),
false
);

if (isDismissed || !isLogsExplorerAppAccessible) {
return null;
}

const allDatasetLocator =
share.url.locators.get<AllDatasetsLocatorParams>(ALL_DATASETS_LOCATOR_ID);

return (
<EuiCallOut
title={i18n.translate('xpack.infra.logsDeprecationCallout.euiCallOut.discoverANewLogLabel', {
Expand All @@ -52,7 +77,7 @@ export const LogsDeprecationCallout = () => {
fill
data-test-subj="infraLogsDeprecationCalloutTryLogsExplorerButton"
color="warning"
{...getLogsExplorerLinkProps(share)}
{...getLogsExplorerLinkProps(allDatasetLocator!)}
>
{i18n.translate('xpack.infra.logsDeprecationCallout.tryLogsExplorerButtonLabel', {
defaultMessage: 'Try Logs Explorer',
Expand All @@ -62,9 +87,7 @@ export const LogsDeprecationCallout = () => {
);
};

const getLogsExplorerLinkProps = (share: SharePublicStart) => {
const locator = share.url.locators.get<AllDatasetsLocatorParams>(ALL_DATASETS_LOCATOR_ID)!;

const getLogsExplorerLinkProps = (locator: LocatorPublic<DatasetLocatorParams>) => {
return getRouterLinkProps({
href: locator.getRedirectUrl({}),
onClick: () => locator.navigate({}),
Expand Down
168 changes: 95 additions & 73 deletions x-pack/plugins/observability_solution/infra/public/plugin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,16 +13,26 @@ import {
DEFAULT_APP_CATEGORIES,
PluginInitializerContext,
AppDeepLinkLocations,
AppStatus,
ApplicationStart,
} from '@kbn/core/public';
import { i18n } from '@kbn/i18n';
import { enableInfrastructureHostsView } from '@kbn/observability-plugin/public';
import { ObservabilityTriggerId } from '@kbn/observability-shared-plugin/common';
import { BehaviorSubject, combineLatest, from } from 'rxjs';
import { map } from 'rxjs';
import {
BehaviorSubject,
combineLatest,
from,
map,
switchMap,
of,
distinctUntilChanged,
} from 'rxjs';
import type { EmbeddableApiContext } from '@kbn/presentation-publishing';
import { apiCanAddNewPanel } from '@kbn/presentation-containers';
import { IncompatibleActionError, ADD_PANEL_TRIGGER } from '@kbn/ui-actions-plugin/public';
import { COMMON_EMBEDDABLE_GROUPING } from '@kbn/embeddable-plugin/public';
import { OBSERVABILITY_LOGS_EXPLORER_APP_ID } from '@kbn/deeplinks-observability/constants';
import type { InfraPublicConfig } from '../common/plugin_config_types';
import { createInventoryMetricRuleType } from './alerting/inventory';
import { createLogThresholdRuleType } from './alerting/log_threshold';
Expand Down Expand Up @@ -106,79 +116,78 @@ export class Plugin implements InfraClientPluginClass {
messageFields: this.config.sources?.default?.fields?.message,
});

const startDep$AndHostViewFlag$ = combineLatest([
const startDep$AndAccessibleFlag$ = combineLatest([
from(core.getStartServices()),
core.settings.client.get$<boolean>(enableInfrastructureHostsView),
]);
]).pipe(
switchMap(([[{ application }], isInfrastructureHostsViewEnabled]) =>
combineLatest([
of(application),
of(isInfrastructureHostsViewEnabled),
getLogsExplorerAccessible$(application),
])
)
);

/** !! Need to be kept in sync with the deepLinks in x-pack/plugins/observability_solution/infra/public/plugin.ts */
pluginsSetup.observabilityShared.navigation.registerSections(
startDep$AndHostViewFlag$.pipe(
map(
([
[
{
application: { capabilities },
},
],
isInfrastructureHostsViewEnabled,
]) => {
const { infrastructure, logs, discover, fleet } = capabilities;
return [
...(logs.show
? [
{
label: 'Logs',
sortKey: 200,
entries: [
...(discover?.show && fleet?.read
? [
{
label: 'Explorer',
app: 'observability-logs-explorer',
path: '/',
isBetaFeature: true,
},
]
: []),
...(this.config.featureFlags.logsUIEnabled
? [
{ label: 'Stream', app: 'logs', path: '/stream' },
{ label: 'Anomalies', app: 'logs', path: '/anomalies' },
{ label: 'Categories', app: 'logs', path: '/log-categories' },
]
: []),
],
},
]
: []),
...(infrastructure.show
? [
{
label: 'Infrastructure',
sortKey: 300,
entries: [
{ label: 'Inventory', app: 'metrics', path: '/inventory' },
...(this.config.featureFlags.metricsExplorerEnabled
? [{ label: 'Metrics Explorer', app: 'metrics', path: '/explorer' }]
: []),
...(isInfrastructureHostsViewEnabled
? [
{
label: 'Hosts',
isBetaFeature: true,
app: 'metrics',
path: '/hosts',
},
]
: []),
],
},
]
: []),
];
}
)
startDep$AndAccessibleFlag$.pipe(
map(([application, isInfrastructureHostsViewEnabled, isLogsExplorerAccessible]) => {
const { infrastructure, logs } = application.capabilities;
return [
...(logs.show
? [
{
label: 'Logs',
sortKey: 200,
entries: [
...(isLogsExplorerAccessible
? [
{
label: 'Explorer',
app: 'observability-logs-explorer',
path: '/',
isBetaFeature: true,
},
]
: []),
...(this.config.featureFlags.logsUIEnabled
? [
{ label: 'Stream', app: 'logs', path: '/stream' },
{ label: 'Anomalies', app: 'logs', path: '/anomalies' },
{ label: 'Categories', app: 'logs', path: '/log-categories' },
]
: []),
],
},
]
: []),
...(infrastructure.show
? [
{
label: 'Infrastructure',
sortKey: 300,
entries: [
{ label: 'Inventory', app: 'metrics', path: '/inventory' },
...(this.config.featureFlags.metricsExplorerEnabled
? [{ label: 'Metrics Explorer', app: 'metrics', path: '/explorer' }]
: []),
...(isInfrastructureHostsViewEnabled
? [
{
label: 'Hosts',
isBetaFeature: true,
app: 'metrics',
path: '/hosts',
},
]
: []),
],
},
]
: []),
];
})
)
);

Expand Down Expand Up @@ -366,9 +375,10 @@ export class Plugin implements InfraClientPluginClass {
},
});

startDep$AndHostViewFlag$.subscribe(
([_startServices, isInfrastructureHostsViewEnabled]: [
[CoreStart, InfraClientStartDeps, InfraClientStartExports],
startDep$AndAccessibleFlag$.subscribe(
([_startServices, isInfrastructureHostsViewEnabled, _isLogsExplorerAccessible]: [
ApplicationStart,
boolean,
boolean
]) => {
this.appUpdater$.next(() => ({
Expand Down Expand Up @@ -450,3 +460,15 @@ export class Plugin implements InfraClientPluginClass {

stop() {}
}

const getLogsExplorerAccessible$ = (application: CoreStart['application']) => {
const { applications$ } = application;
return applications$.pipe(
map(
(apps) =>
(apps.get(OBSERVABILITY_LOGS_EXPLORER_APP_ID)?.status ?? AppStatus.inaccessible) ===
AppStatus.accessible
),
distinctUntilChanged()
);
};

0 comments on commit 3883400

Please sign in to comment.