mirror of
https://github.com/elastic/kibana.git
synced 2025-06-27 18:51:07 -04:00
This PR removes the Profiling dependency from APM, introduced on `8.10`. - Exposes a new service in profiling-data-access plugin - Create a new APM API that calls the new service and checks if Profiling is initialized - Move Locators from the Profiling plugin to the Observability-shared plugin - Move logic to check Profiling status (has_setup/has_data...) from Profiling server to profiling-data-access plugin - Create API tests, testing the status services based on different scenarios: - When profiling hasn't been initialized and there's no data - When profiling is initialized but has no data - When collector integration is not installed - When symbolized integration is not installed - When APM server integration is not found --------- Co-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com>
24 lines
817 B
TypeScript
24 lines
817 B
TypeScript
/*
|
|
* 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 { PartialSetupState, ProfilingSetupOptions } from './setup';
|
|
|
|
export const PROFILING_READER_ROLE_NAME = 'profiling-reader';
|
|
export const METADATA_VERSION = 1;
|
|
|
|
export async function validateSecurityRole({
|
|
client,
|
|
}: ProfilingSetupOptions): Promise<PartialSetupState> {
|
|
const esClient = client.getEsClient();
|
|
const roles = await esClient.security.getRole();
|
|
const profilingRole = roles[PROFILING_READER_ROLE_NAME];
|
|
return {
|
|
permissions: {
|
|
configured: !!profilingRole && profilingRole.metadata.version === METADATA_VERSION,
|
|
},
|
|
};
|
|
}
|