Skip to content

Commit

Permalink
[8.x] [Discover] Add context awareness framework documentation (elast…
Browse files Browse the repository at this point in the history
…ic#192429) (elastic#192909)

# Backport

This will backport the following commits from `main` to `8.x`:
- [[Discover] Add context awareness framework documentation
(elastic#192429)](elastic#192429)

<!--- Backport version: 9.4.3 -->

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

<!--BACKPORT [{"author":{"name":"Davis
McPhee","email":"[email protected]"},"sourceCommit":{"committedDate":"2024-09-13T01:10:50Z","message":"[Discover]
Add context awareness framework documentation (elastic#192429)\n\n##
Summary\r\n\r\nThis PR adds initial developer documentation for the
Discover context\r\nawareness framework, with the aim of providing a
solid foundation for\r\nsolution engineers to begin working with it and
adding their own\r\nprofiles and extension point implementations:\r\n-
Adds a `README.md` file to the Discover `context_awareness`
folder\r\nincluding the main developer documentation.\r\n- Adds TSDoc
comments to all public types and functions used by the\r\ncontext
awareness framework.\r\n- Reorganizes the `profile_providers` folder to
provide a clearer folder\r\nstructure to support collaboration with
solution teams.\r\n\r\nResolves elastic#184698.\r\n\r\n### Checklist\r\n\r\n- [
] Any text added follows [EUI's
writing\r\nguidelines](https://elastic.github.io/eui/#/guidelines/writing),
uses\r\nsentence case text and includes
[i18n\r\nsupport](https://github.com/elastic/kibana/blob/main/packages/kbn-i18n/README.md)\r\n-
[x]\r\n[Documentation](https://www.elastic.co/guide/en/kibana/master/development-documentation.html)\r\nwas
added for features that require explanation or tutorials\r\n- [ ] [Unit
or
functional\r\ntests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)\r\nwere
updated or added to match the most common scenarios\r\n- [ ] [Flaky
Test\r\nRunner](https://ci-stats.kibana.dev/trigger_flaky_test_runner/1)
was\r\nused on any tests changed\r\n- [ ] Any UI touched in this PR is
usable by keyboard only (learn more\r\nabout [keyboard
accessibility](https://webaim.org/techniques/keyboard/))\r\n- [ ] Any UI
touched in this PR does not create any new axe failures\r\n(run axe in
browser:\r\n[FF](https://addons.mozilla.org/en-US/firefox/addon/axe-devtools/),\r\n[Chrome](https://chrome.google.com/webstore/detail/axe-web-accessibility-tes/lhdoppojpmngadmnindnejefpokejbdd?hl=en-US))\r\n-
[ ] If a plugin configuration key changed, check if it needs to
be\r\nallowlisted in the cloud and added to the
[docker\r\nlist](https://github.com/elastic/kibana/blob/main/src/dev/build/tasks/os_packages/docker_generator/resources/base/bin/kibana-docker)\r\n-
[ ] This renders correctly on smaller devices using a
responsive\r\nlayout. (You can test this [in
your\r\nbrowser](https://www.browserstack.com/guide/responsive-testing-on-local-server))\r\n-
[ ] This was checked for
[cross-browser\r\ncompatibility](https://www.elastic.co/support/matrix#matrix_browsers)\r\n\r\n###
For maintainers\r\n\r\n- [ ] This was checked for breaking API changes
and was
[labeled\r\nappropriately](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)","sha":"f6c8a2e5865c389b80d4a2440aaf20ea6fab0617","branchLabelMapping":{"^v9.0.0$":"main","^v8.16.0$":"8.x","^v(\\d+).(\\d+).\\d+$":"$1.$2"}},"sourcePullRequest":{"labels":["release_note:skip","v9.0.0","Team:DataDiscovery","backport:prev-minor","v8.16.0"],"title":"[Discover]
Add context awareness framework
documentation","number":192429,"url":"https://github.com/elastic/kibana/pull/192429","mergeCommit":{"message":"[Discover]
Add context awareness framework documentation (elastic#192429)\n\n##
Summary\r\n\r\nThis PR adds initial developer documentation for the
Discover context\r\nawareness framework, with the aim of providing a
solid foundation for\r\nsolution engineers to begin working with it and
adding their own\r\nprofiles and extension point implementations:\r\n-
Adds a `README.md` file to the Discover `context_awareness`
folder\r\nincluding the main developer documentation.\r\n- Adds TSDoc
comments to all public types and functions used by the\r\ncontext
awareness framework.\r\n- Reorganizes the `profile_providers` folder to
provide a clearer folder\r\nstructure to support collaboration with
solution teams.\r\n\r\nResolves elastic#184698.\r\n\r\n### Checklist\r\n\r\n- [
] Any text added follows [EUI's
writing\r\nguidelines](https://elastic.github.io/eui/#/guidelines/writing),
uses\r\nsentence case text and includes
[i18n\r\nsupport](https://github.com/elastic/kibana/blob/main/packages/kbn-i18n/README.md)\r\n-
[x]\r\n[Documentation](https://www.elastic.co/guide/en/kibana/master/development-documentation.html)\r\nwas
added for features that require explanation or tutorials\r\n- [ ] [Unit
or
functional\r\ntests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)\r\nwere
updated or added to match the most common scenarios\r\n- [ ] [Flaky
Test\r\nRunner](https://ci-stats.kibana.dev/trigger_flaky_test_runner/1)
was\r\nused on any tests changed\r\n- [ ] Any UI touched in this PR is
usable by keyboard only (learn more\r\nabout [keyboard
accessibility](https://webaim.org/techniques/keyboard/))\r\n- [ ] Any UI
touched in this PR does not create any new axe failures\r\n(run axe in
browser:\r\n[FF](https://addons.mozilla.org/en-US/firefox/addon/axe-devtools/),\r\n[Chrome](https://chrome.google.com/webstore/detail/axe-web-accessibility-tes/lhdoppojpmngadmnindnejefpokejbdd?hl=en-US))\r\n-
[ ] If a plugin configuration key changed, check if it needs to
be\r\nallowlisted in the cloud and added to the
[docker\r\nlist](https://github.com/elastic/kibana/blob/main/src/dev/build/tasks/os_packages/docker_generator/resources/base/bin/kibana-docker)\r\n-
[ ] This renders correctly on smaller devices using a
responsive\r\nlayout. (You can test this [in
your\r\nbrowser](https://www.browserstack.com/guide/responsive-testing-on-local-server))\r\n-
[ ] This was checked for
[cross-browser\r\ncompatibility](https://www.elastic.co/support/matrix#matrix_browsers)\r\n\r\n###
For maintainers\r\n\r\n- [ ] This was checked for breaking API changes
and was
[labeled\r\nappropriately](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)","sha":"f6c8a2e5865c389b80d4a2440aaf20ea6fab0617"}},"sourceBranch":"main","suggestedTargetBranches":["8.x"],"targetPullRequestStates":[{"branch":"main","label":"v9.0.0","branchLabelMappingKey":"^v9.0.0$","isSourceBranch":true,"state":"MERGED","url":"https://github.com/elastic/kibana/pull/192429","number":192429,"mergeCommit":{"message":"[Discover]
Add context awareness framework documentation (elastic#192429)\n\n##
Summary\r\n\r\nThis PR adds initial developer documentation for the
Discover context\r\nawareness framework, with the aim of providing a
solid foundation for\r\nsolution engineers to begin working with it and
adding their own\r\nprofiles and extension point implementations:\r\n-
Adds a `README.md` file to the Discover `context_awareness`
folder\r\nincluding the main developer documentation.\r\n- Adds TSDoc
comments to all public types and functions used by the\r\ncontext
awareness framework.\r\n- Reorganizes the `profile_providers` folder to
provide a clearer folder\r\nstructure to support collaboration with
solution teams.\r\n\r\nResolves elastic#184698.\r\n\r\n### Checklist\r\n\r\n- [
] Any text added follows [EUI's
writing\r\nguidelines](https://elastic.github.io/eui/#/guidelines/writing),
uses\r\nsentence case text and includes
[i18n\r\nsupport](https://github.com/elastic/kibana/blob/main/packages/kbn-i18n/README.md)\r\n-
[x]\r\n[Documentation](https://www.elastic.co/guide/en/kibana/master/development-documentation.html)\r\nwas
added for features that require explanation or tutorials\r\n- [ ] [Unit
or
functional\r\ntests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)\r\nwere
updated or added to match the most common scenarios\r\n- [ ] [Flaky
Test\r\nRunner](https://ci-stats.kibana.dev/trigger_flaky_test_runner/1)
was\r\nused on any tests changed\r\n- [ ] Any UI touched in this PR is
usable by keyboard only (learn more\r\nabout [keyboard
accessibility](https://webaim.org/techniques/keyboard/))\r\n- [ ] Any UI
touched in this PR does not create any new axe failures\r\n(run axe in
browser:\r\n[FF](https://addons.mozilla.org/en-US/firefox/addon/axe-devtools/),\r\n[Chrome](https://chrome.google.com/webstore/detail/axe-web-accessibility-tes/lhdoppojpmngadmnindnejefpokejbdd?hl=en-US))\r\n-
[ ] If a plugin configuration key changed, check if it needs to
be\r\nallowlisted in the cloud and added to the
[docker\r\nlist](https://github.com/elastic/kibana/blob/main/src/dev/build/tasks/os_packages/docker_generator/resources/base/bin/kibana-docker)\r\n-
[ ] This renders correctly on smaller devices using a
responsive\r\nlayout. (You can test this [in
your\r\nbrowser](https://www.browserstack.com/guide/responsive-testing-on-local-server))\r\n-
[ ] This was checked for
[cross-browser\r\ncompatibility](https://www.elastic.co/support/matrix#matrix_browsers)\r\n\r\n###
For maintainers\r\n\r\n- [ ] This was checked for breaking API changes
and was
[labeled\r\nappropriately](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process)","sha":"f6c8a2e5865c389b80d4a2440aaf20ea6fab0617"}},{"branch":"8.x","label":"v8.16.0","branchLabelMappingKey":"^v8.16.0$","isSourceBranch":false,"state":"NOT_CREATED"}]}]
BACKPORT-->

Co-authored-by: Davis McPhee <[email protected]>
  • Loading branch information
kibanamachine and davismcphee authored Sep 13, 2024
1 parent a013a65 commit eafb15c
Show file tree
Hide file tree
Showing 56 changed files with 755 additions and 135 deletions.
193 changes: 193 additions & 0 deletions src/plugins/discover/public/context_awareness/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,193 @@
# Discover context awareness

**If you're looking for available extension point definitions, they're located in the `Profile` interface in [`types.ts`](types.ts).**

## Summary

The Discover context awareness framework allows Discover's UI and functionality to adapt to the surrounding context of the page, including solution type, data source, current search parameters, etc., in order to provide curated data exploration experiences across a variety of data types and scenarios. Support for this is implemented through a system of profiles that map to distinct context levels, and extension points that provide interfaces for customizing specific aspects of Discover.

## Concepts

### Context levels

There are currently three context levels supported in Discover:

- Root context:
- Based on the current solution type.
- Resolved at application initialization.
- Runs synchronously or asynchronously.
- Data source context:
- Based on the current ES|QL query or data view.
- Resolved on ES|QL query or data view change, before data fetching occurs.
- Runs synchronously or asynchronously.
- Document context:
- Based on individual ES|QL records or ES documents.
- Resolved individually for each ES|QL record or ES document after data fetching runs.
- Runs synchronously only.

### Composable profiles

Discover uses a concept called "composable profiles" to support context awareness. Composable profiles are implementations of a core `Profile` interface (or a subset of it) containing all of the available extension points Discover supports. A composable profile can be implemented at any context level through a "profile provider", responsible for defining the composable profile and its associated context resolution method, called `resolve`. Each provider's `resolve` method is passed a parameters object specific to its context level, which it uses to determine if its associated `profile` is a match. In cases where it is a match, the `resolve` method also returns related metadata in a `context` object.

Within Discover there is always one resolved root profile, one resolved data source profile (as long as search results exist), and a resolved document profile for each search result in the data grid. Profile providers have access to the `context` objects of higher level providers within their `resolve` method (`root` > `data source` > `document`), making it possible to create context-dependent profiles. For example, an `oblt-logs-data-source` profile which is used when the current solution type is Observability, and the current data source contains logs data.

Definitions for the core `Profile` interface are located in the [`types.ts`](types.ts) file.

Definitions for the available profile provider types are located in the [`profiles`](./profiles) folder.

### Merged accessors

Composable profiles operate similarly to middleware in that each of their extension point implementations are passed a `prev` argument, which can be called to access the results from profiles at previous context levels, and allows overwriting or composing a final result from the previous results. The function Discover calls to trigger the extension point merging process and obtain a final result from the combined profiles is referred to as a "merged accessor".

The merging order for profiles is based on the context level hierarchy (`root` > `data source` > `document`), meaning the root profile is passed a base implementation as its `prev` argument, the data source profile is passed the root implementation as `prev` (if one exists, otherwise the base implementation), and document profiles are passed the data source implementation as `prev` (if one exists, otherwise the root or base implementation).

The following diagram illustrates the extension point merging process:
![image](./docs/merged_accessors.png)

Definitions for composable profiles and the merging routine are located in the [`composable_profile.ts`](./composable_profile.ts) file.

### Supporting services

The context awareness framework is driven by two main supporting services called `ProfileService` and `ProfilesManager`.

Each context level has a dedicated profile service, e.g. `RootProfileService`, which is responsible for accepting profile provider registrations and looping over each provider in order during context resolution to identify a matching profile. Each resolution call can result in only one matching profile, which is the first to return a match based on execution order.

A single `ProfilesManager` is instantiated on Discover load, or one per saved search panel in a dashboard. The profiles manager is responsible for the following:

- Managing state associated with the current Discover context.
- Coordinating profile services and exposing resolution methods for each context level.
- Providing access to the combined set of resolved profiles.
- Deduplicating profile resolution attempts with identical parameters.
- Error handling and fallback behaviour on profile resolution failure.

`ProfileService` definitions and implementation are located in the [`profiles_service.ts`](./profile_service.ts) file.

The `ProfilesManager` implementation is located in the [`profiles_manager.ts`](./profiles_manager.ts) file.

### Putting it all together

The following diagram models the overall Discover context awareness framework and how each of the above concepts come together:
![image](./docs/architecture.png)

## Code organization

One of the core ideas of the context awareness framework is that Discover is still a single application which should know about which profiles it supports and directly import the code needed to support them. This is why profile registrations are all handled internally to the plugin instead of having a registration system exposed through the plugin contract. This approach comes with several main benefits:

- There is a single, central place where all profile registrations happen, which is much easier to maintan versus scattered registrations.
- The Data Discovery team remains aware of which profiles exist and what changes are made. This is critical to ensure the Data Discovery team is able to provide adequate customer and SDH support for Discover.
- Common code and utilities can be easily shared across profiles since they need to be accessible to Discover by default, rather than being scattered throughout various plugin codebases.

It also comes with an important drawback: **Discover cannot depend on other plugins (e.g. solution plugins) to import code for profiles due to the dependency graph issues it would create.**

This means that in an ideal situation, the code for Discover profiles should either live directly within the Discover codebase, or within dedicated packages which Discover imports from:

- When adding solution specific code directly to the Discover codebase, it should be done in an organized way in order to support shared ownership. For example, the [`profile_providers/security`](./profile_providers/security) folder contains code specific to Security Solution maintained profiles, and an override has been added to the [`CODEOWNERS`](/.github/CODEOWNERS) file to reflect the shared ownership of this folder.
- When creating a dedicated package for some profile code, the maintaining team can retain full ownership over the package, and Discover is only responsible for importing the functionality and adding it to the associated profile registration.

There are situations where neither of the above two options are viable, such as when migrating large pieces of functionality from a solution plugin to a Discover profile, which could be time consuming and involve moving huge amounts of code to packages. For these situations, there's a [discover_shared](/src/plugins/discover_shared) plugin specifically to support inversion of control for Discover profile features (see the [`README`](/src/plugins/discover_shared/README.md) for more details).

By ensuring all Discover profiles use the same IoC mechanism, changes or improvements to the system can be centralized, and areas that use it can easily be located. In general, this should be used as a last resort when the benefits of importing directly from packages aren't worth the effort to migrate the code, and ideally teams who use it should have a plan to later refactor the code into packages.

## Registering a profile

In order to register a Discover profile, follow these steps:

1. Identify at which [context level](#context-levels) your profile should be implemented.
2. Create a subfolder for your profile provider within the [`profile_providers`](./profile_providers) folder. Common Discover providers should be created within the `profile_providers/common` subfolder, while solution specific providers should be created within a `profile_providers/{SOLUTION_TYPE}` subfolder, e.g. `profile_providers/security/security_root_profile`.
3. Create a `profile.ts(x)` file within your provider subfolder that exports a factory function which optionally accepts a `ProfileProviderServices` parameter and returns your provider implementation, e.g. `createSecurityRootProfileProvider(services: ProfileProviderServices) => RootProfileProvider`.
4. **If your provider is not ready for GA or should only be enabled for specific configurations, make sure to set the `isExperimental` flag to `true` in your profile provider.** This will ensure the profile is disabled by default, and can be enabled in `kibana.yml` like this: `discover.experimental.enabledProfiles: [{YOUR_PROFILE_ID}]`.
5. Call and return the result of your provider factory function from the corresponding factory function in [`register_profile_providers.ts`](./profile_providers/register_profile_providers.ts), e.g. `createRootProfileProviders`. The order of providers in the returned array determines the execution order during context resolution.

Existing providers can be extended using the [`extendProfileProvider`](./profile_providers/extend_profile_provider.ts) utility, allowing multiple sub profiles to be composed from a shared parent profile.

Example profile provider implementations are located in [`profile_providers/example`](./profile_providers/example).

## Example implementation

```ts
/**
* profile_providers/common/example_data_source_profile/profile.tsx
*/

import React from 'react';
import { getFieldValue } from '@kbn/discover-utils';
import { isOfAggregateQueryType } from '@kbn/es-query';
import { getIndexPatternFromESQLQuery } from '@kbn/esql-utils';
import { DataSourceType, isDataSourceType } from '../../../../../common/data_sources';
import { DataSourceCategory, DataSourceProfileProvider } from '../../../profiles';
import { ProfileProviderServices } from '../../profile_provider_services';

// Export profile provider factory function, optionally accepting ProfileProviderServices,
// and returning a profile provider for a specific context level
export const createExampleDataSourceProfileProvider = (
services: ProfileProviderServices
): DataSourceProfileProvider => ({
// All profiles must have a unique ID
profileId: 'example-data-source-profile',

// Set isExperimental flag to true if profile should be disabled by default
isExperimental: true,

// The composable profile definition
profile: {
// Each available method maps to a Discover extension point
getCellRenderers: (prev) => () => ({
// Calling prev() provides access to results from previous context levels,
// making it possible to compose a result from multiple profiles
...prev(),

// Extend the previous results with a cell renderer for the message field
message: (props) => {
const message = getFieldValue(props.row, 'message');
return <span>Custom message cell: {message}</span>;
},
}),
},

// The method responsible for context resolution,
// passed a params object with props specific to the context level,
// as well as providing access to higher level context objects
resolve: (params) => {
let indexPattern: string | undefined;

// Extract the index pattern from the current ES|QL query or data view
if (isDataSourceType(params.dataSource, DataSourceType.Esql)) {
if (!isOfAggregateQueryType(params.query)) {
return { isMatch: false };
}

indexPattern = getIndexPatternFromESQLQuery(params.query.esql);
} else if (isDataSourceType(params.dataSource, DataSourceType.DataView) && params.dataView) {
indexPattern = params.dataView.getIndexPattern();
}

// If the profile is not a match, return isMatch: false in the result
if (indexPattern !== 'my-example-logs') {
return { isMatch: false };
}

// If the profile is a match, return isMatch: true in the result,
// plus a context object containing details of the current context
return {
isMatch: true,
context: { category: DataSourceCategory.Logs },
};
},
});

/**
* profile_providers/register_profile_providers.ts
*/

// Locate the factory function for the matching context level
const createDataSourceProfileProviders = (providerServices: ProfileProviderServices) => [
// Call the profile provider factory function and return its result in the array
createExampleDataSourceProfileProvider(providerServices),
...createLogsDataSourceProfileProviders(providerServices),
];

/**
* Navigate to Discover and execute the following ES|QL query
* to resolve the profile: `FROM my-example-logs`
*/
```
Original file line number Diff line number Diff line change
Expand Up @@ -9,19 +9,36 @@

import type { Profile } from './types';

/**
* A partial profile implementation
*/
export type PartialProfile = Partial<Profile>;

/**
* An accessor function that allows retrieving the extension point result from previous profiles
*/
export type ComposableAccessor<T> = (getPrevious: T) => T;

/**
* A partial profile implementation that supports composition across multiple profiles
*/
export type ComposableProfile<TProfile extends PartialProfile = Profile> = {
[TKey in keyof TProfile]?: ComposableAccessor<TProfile[TKey]>;
};

/**
* Merges extension point implementations from multiple profiles into a single accessor function
* @param profiles The profiles to merge
* @param key The key of the extension point to merge
* @param baseImpl The base implementation for the extension point
* @returns The merged extension point accessor function
*/
export const getMergedAccessor = <TKey extends keyof Profile>(
profiles: ComposableProfile[],
key: TKey,
baseImpl: Profile[TKey]
) => {
// root, data source, and document profiles are merged in order
return profiles.reduce((nextAccessor, profile) => {
const currentAccessor = profile[key];
return currentAccessor ? currentAccessor(nextAccessor) : nextAccessor;
Expand Down
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,11 @@ import { useProfileAccessor } from './use_profile_accessor';

export const DISCOVER_CELL_ACTION_TYPE = 'discover-cellAction-type';

/**
* Hook to register additional cell actions based on the resolved profiles
* @param options Additional cell action options
* @returns The current cell actions metadata
*/
export const useAdditionalCellActions = ({
dataSource,
dataView,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,12 @@ import type { GetProfilesOptions } from '../profiles_manager';
import { useProfiles } from './use_profiles';
import type { Profile } from '../types';

/**
* Hook to retrieve an extension point accessor based on the resolved profiles
* @param key The key of the extension point
* @param options Options to get the resolved profiles
* @returns The resolved accessor function
*/
export const useProfileAccessor = <TKey extends keyof Profile>(
key: TKey,
options: GetProfilesOptions = {}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,11 @@ import { useEffect, useMemo, useState } from 'react';
import { useDiscoverServices } from '../../hooks/use_discover_services';
import type { GetProfilesOptions } from '../profiles_manager';

/**
* Hook to retreive the resolved profiles
* @param options Profiles options
* @returns The resolved profiles
*/
export const useProfiles = ({ record }: GetProfilesOptions = {}) => {
const { profilesManager } = useDiscoverServices();
const [profiles, setProfiles] = useState(() => profilesManager.getProfiles({ record }));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,11 @@
import { useEffect, useState } from 'react';
import { useDiscoverServices } from '../../hooks/use_discover_services';

/**
* Hook to trigger and wait for root profile resolution
* @param options Options object
* @returns If the root profile is loading
*/
export const useRootProfile = ({ solutionNavId }: { solutionNavId: string | null }) => {
const { profilesManager } = useDiscoverServices();
const [rootProfileLoading, setRootProfileLoading] = useState(true);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
import { i18n } from '@kbn/i18n';
import { UnifiedDocViewerLogsOverview } from '@kbn/unified-doc-viewer-plugin/public';
import React from 'react';
import type { DocumentProfileProvider } from '../../../profiles';
import type { DocumentProfileProvider } from '../../../../profiles';

export const getDocViewer: DocumentProfileProvider['profile']['getDocViewer'] =
(prev) => (params) => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,8 @@ import {
DocumentType,
RootContext,
SolutionType,
} from '../../profiles';
import { createContextAwarenessMocks } from '../../__mocks__';
} from '../../../profiles';
import { createContextAwarenessMocks } from '../../../__mocks__';
import { createLogDocumentProfileProvider } from './profile';

const mockServices = createContextAwarenessMocks().profileProviderServices;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@
*/

import { DataTableRecord } from '@kbn/discover-utils';
import { DocumentProfileProvider, DocumentType } from '../../profiles';
import { ProfileProviderServices } from '../profile_provider_services';
import { DocumentProfileProvider, DocumentType } from '../../../profiles';
import { ProfileProviderServices } from '../../profile_provider_services';
import { getDocViewer } from './accessors';

export const createLogDocumentProfileProvider = (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,9 @@
* License v3.0 only", or the "Server Side Public License, v 1".
*/

import { LOG_LEVEL_FIELDS } from '../../../../../common/data_types/logs/constants';
import { getLogLevelBadgeCell } from '../../../../components/data_types/logs/log_level_badge_cell';
import type { DataSourceProfileProvider } from '../../../profiles';
import { LOG_LEVEL_FIELDS } from '../../../../../../common/data_types/logs/constants';
import { getLogLevelBadgeCell } from '../../../../../components/data_types/logs/log_level_badge_cell';
import type { DataSourceProfileProvider } from '../../../../profiles';

export const getCellRenderers: DataSourceProfileProvider['profile']['getCellRenderers'] =
(prev) => () => ({
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,8 @@
* License v3.0 only", or the "Server Side Public License, v 1".
*/

import type { DataSourceProfileProvider } from '../../../profiles';
import { DefaultAppStateColumn } from '../../../types';
import type { DataSourceProfileProvider } from '../../../../profiles';
import { DefaultAppStateColumn } from '../../../../types';

export const createGetDefaultAppState = ({
defaultColumns,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
import { createDegradedDocsControl, createStacktraceControl } from '@kbn/discover-utils';
import { retrieveMetadataColumns } from '@kbn/esql-utils';
import { AggregateQuery, isOfAggregateQueryType } from '@kbn/es-query';
import type { DataSourceProfileProvider } from '../../../profiles';
import type { DataSourceProfileProvider } from '../../../../profiles';

export const getRowAdditionalLeadingControls: DataSourceProfileProvider['profile']['getRowAdditionalLeadingControls'] =
(prev) => (params) => {
Expand Down
Loading

0 comments on commit eafb15c

Please sign in to comment.