Skip to content

Commit

Permalink
[Fleet] Fix assets being unintentionally moved to the default space d…
Browse files Browse the repository at this point in the history
…uring Fleet setup (elastic#176173)

## Summary

Fixes elastic#175173

Use a scoped SO client when importing assets to prevent always importing
assets into the default space during Fleet setup.

## To do

Add tests?

---------

Co-authored-by: Kibana Machine <[email protected]>
  • Loading branch information
kpollich and kibanamachine authored Feb 5, 2024
1 parent 7d32d6b commit c07ee4a
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 6 deletions.
8 changes: 4 additions & 4 deletions x-pack/plugins/fleet/server/services/epm/packages/install.ts
Original file line number Diff line number Diff line change
Expand Up @@ -562,13 +562,13 @@ async function installPackageCommon(options: {
return { error: err, installType, installSource };
}

const savedObjectsImporter = appContextService
.getSavedObjects()
.createImporter(savedObjectsClient, { importSizeLimit: 15_000 });

// Saved object client need to be scopped with the package space for saved object tagging
const savedObjectClientWithSpace = appContextService.getInternalUserSOClientForSpaceId(spaceId);

const savedObjectsImporter = appContextService
.getSavedObjects()
.createImporter(savedObjectClientWithSpace, { importSizeLimit: 15_000 });

const savedObjectTagAssignmentService = appContextService
.getSavedObjectsTagging()
.createInternalAssignmentService({ client: savedObjectClientWithSpace });
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,9 @@
* 2.0; you may not use this file except in compliance with the Elastic License
* 2.0.
*/
import { INGEST_SAVED_OBJECT_INDEX } from '@kbn/core-saved-objects-server';
import expect from '@kbn/expect';
import { PACKAGES_SAVED_OBJECT_TYPE } from '@kbn/fleet-plugin/common';
import pRetry from 'p-retry';
import { FtrProviderContext } from '../../../api_integration/ftr_provider_context';
import { skipIfNoDockerRegistry } from '../../helpers';
Expand All @@ -19,6 +21,8 @@ export default function (providerContext: FtrProviderContext) {
const dockerServers = getService('dockerServers');
const esArchiver = getService('esArchiver');
const server = dockerServers.get('registry');
const es = getService('es');

const pkgName = 'system';
const pkgVersion = '1.27.0';

Expand All @@ -37,7 +41,7 @@ export default function (providerContext: FtrProviderContext) {
};

const installPackageInSpace = async (pkg: string, version: string, spaceId: string) => {
await supertest
return supertest
.post(`/s/${spaceId}/api/fleet/epm/packages/${pkg}/${version}`)
.set('kbn-xsrf', 'xxxx')
.send({ force: true })
Expand Down Expand Up @@ -68,7 +72,7 @@ export default function (providerContext: FtrProviderContext) {
})
.catch(() => {});

describe.skip('When installing system integration in multiple spaces', async () => {
describe('When installing system integration in multiple spaces', async () => {
skipIfNoDockerRegistry(providerContext);
setupFleetAndAgents(providerContext);

Expand Down Expand Up @@ -130,5 +134,41 @@ export default function (providerContext: FtrProviderContext) {
const spaceTag = await getTag(`fleet-pkg-${pkgName}-fleet_test_space`, testSpaceId);
expect(spaceTag).not.equal(undefined);
});

it('should keep assets in space when format version is bumped', async () => {
const nginxPkgName = 'nginx';
const nginxPkgVersion = '1.17.0';

const installResponse = await installPackageInSpace(
nginxPkgName,
nginxPkgVersion,
testSpaceId
);

const firstAsset = installResponse.body.items.find((item: any) => item.type === 'dashboard');

// Bump format version directly on installation saved object, then call setup to trigger a reinstall
await es.update({
index: INGEST_SAVED_OBJECT_INDEX,
id: `${PACKAGES_SAVED_OBJECT_TYPE}:${nginxPkgName}`,
body: {
doc: {
[PACKAGES_SAVED_OBJECT_TYPE]: {
install_format_schema_version: '99.99.99',
},
},
},
});

await supertest.post(`/api/fleet/setup`).set('kbn-xsrf', 'xxxx').send();

const res = await es.get({
index: '.kibana_analytics',
id: `${firstAsset.type}:${firstAsset.id}`,
});

expect(res.found).to.be(true);
expect((res._source as any).namespaces).to.eql([testSpaceId]);
});
});
}

0 comments on commit c07ee4a

Please sign in to comment.