mirror of
https://github.com/elastic/kibana.git
synced 2025-04-25 02:09:32 -04:00
* Removing circular dependency between spaces and security * Apply suggestions from code review Co-authored-by: Constance <constancecchen@users.noreply.github.com> Co-authored-by: Aleh Zasypkin <aleh.zasypkin@gmail.com> * Tests refactor - Reorganize top level describes into 3 space-based blocks into based on spaces: - space disabled - spaces plugin unavailable - space enabled (most previous tests go under this new block) with new beforeEach - wrote new tests for uncovered lines 58, 66-69 * Review1: address PR feedback * changing fake requests for alerts/actions * Fixing tests * fixing more tests * Additional testing and refactoring * Apply suggestions from code review Co-authored-by: Aleh Zasypkin <aleh.zasypkin@gmail.com> * Review 2: Address feedback * Make ESLint happy again Co-authored-by: Constance <constancecchen@users.noreply.github.com> Co-authored-by: Aleh Zasypkin <aleh.zasypkin@gmail.com> Co-authored-by: Constance Chen <constance.chen.3@gmail.com> Co-authored-by: Constance <constancecchen@users.noreply.github.com> Co-authored-by: Aleh Zasypkin <aleh.zasypkin@gmail.com> Co-authored-by: Constance Chen <constance.chen.3@gmail.com>
38 lines
1.3 KiB
TypeScript
38 lines
1.3 KiB
TypeScript
/*
|
|
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
|
* or more contributor license agreements. Licensed under the Elastic License;
|
|
* you may not use this file except in compliance with the Elastic License.
|
|
*/
|
|
|
|
import { SpacesPluginSetup } from '../../../spaces/server';
|
|
import { AuditServiceSetup } from '../audit';
|
|
import { AuthorizationServiceSetup } from '../authorization';
|
|
import { LegacySpacesAuditLogger } from './legacy_audit_logger';
|
|
import { SecureSpacesClientWrapper } from './secure_spaces_client_wrapper';
|
|
|
|
interface Deps {
|
|
audit: AuditServiceSetup;
|
|
authz: AuthorizationServiceSetup;
|
|
spaces?: SpacesPluginSetup;
|
|
}
|
|
|
|
export const setupSpacesClient = ({ audit, authz, spaces }: Deps) => {
|
|
if (!spaces) {
|
|
return;
|
|
}
|
|
const { spacesClient } = spaces;
|
|
|
|
spacesClient.setClientRepositoryFactory((request, savedObjectsStart) => {
|
|
if (authz.mode.useRbacForRequest(request)) {
|
|
return savedObjectsStart.createInternalRepository(['space']);
|
|
}
|
|
return savedObjectsStart.createScopedRepository(request, ['space']);
|
|
});
|
|
|
|
const spacesAuditLogger = new LegacySpacesAuditLogger(audit.getLogger());
|
|
|
|
spacesClient.registerClientWrapper(
|
|
(request, baseClient) =>
|
|
new SecureSpacesClientWrapper(baseClient, request, authz, spacesAuditLogger)
|
|
);
|
|
};
|