From 197d678f5fd602935daf491ba0f502bb01206428 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alejandro=20Fern=C3=A1ndez=20Haro?= Date: Thu, 19 Dec 2024 21:09:27 +0100 Subject: [PATCH] [ES `body` removal] `@elastic/fleet` (#204867) ## Summary Attempt to remove the deprecated `body` in the ES client. (cherry picked from commit d7ef161d8d8ddcfe652bb607a0c01002e985eae6) # Conflicts: # x-pack/plugins/fleet/server/services/agents/actions.ts --- .../fleet/common/types/models/agent_policy.ts | 2 +- .../plugins/fleet/common/types/models/epm.ts | 2 +- .../server/routes/data_streams/handlers.ts | 2 +- .../package_policies_to_agent_permissions.ts | 2 +- .../fleet/server/services/agent_policy.ts | 2 +- .../server/services/agents/action.mock.ts | 2 +- .../server/services/agents/actions.test.ts | 12 ++--- .../fleet/server/services/agents/actions.ts | 6 +-- .../server/services/agents/agent_service.ts | 4 +- .../fleet/server/services/agents/crud.test.ts | 6 +-- .../fleet/server/services/agents/crud.ts | 36 ++++++-------- .../fleet/server/services/agents/helpers.ts | 2 +- .../server/services/agents/reassign.test.ts | 14 +++--- .../agents/request_diagnostics.test.ts | 12 ++--- .../server/services/agents/unenroll.test.ts | 49 +++++++++---------- .../services/agents/update_agent_tags.test.ts | 20 ++++---- .../server/services/agents/upgrade.test.ts | 18 +++---- .../elasticsearch/index/update_settings.ts | 2 +- .../epm/elasticsearch/template/template.ts | 2 +- .../epm/elasticsearch/template/utils.ts | 2 +- .../elasticsearch/transform/reauthorize.ts | 2 +- ...experimental_datastream_features_helper.ts | 5 +- .../server/services/files/client_from_host.ts | 2 +- .../security/uninstall_token_service/index.ts | 2 +- 24 files changed, 98 insertions(+), 110 deletions(-) diff --git a/x-pack/plugins/fleet/common/types/models/agent_policy.ts b/x-pack/plugins/fleet/common/types/models/agent_policy.ts index f32356238bb93..6a2aa8c6864d0 100644 --- a/x-pack/plugins/fleet/common/types/models/agent_policy.ts +++ b/x-pack/plugins/fleet/common/types/models/agent_policy.ts @@ -5,7 +5,7 @@ * 2.0. */ -import type { SecurityRoleDescriptor } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { SecurityRoleDescriptor } from '@elastic/elasticsearch/lib/api/types'; import type { agentPolicyStatuses } from '../../constants'; import type { MonitoringType, PolicySecretReference, ValueOf } from '..'; diff --git a/x-pack/plugins/fleet/common/types/models/epm.ts b/x-pack/plugins/fleet/common/types/models/epm.ts index 2df4fb670f48d..f65534512e776 100644 --- a/x-pack/plugins/fleet/common/types/models/epm.ts +++ b/x-pack/plugins/fleet/common/types/models/epm.ts @@ -5,7 +5,7 @@ * 2.0. */ -import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type * as estypes from '@elastic/elasticsearch/lib/api/types'; import type { ASSETS_SAVED_OBJECT_TYPE, diff --git a/x-pack/plugins/fleet/server/routes/data_streams/handlers.ts b/x-pack/plugins/fleet/server/routes/data_streams/handlers.ts index 7ed4b5bacf336..8f1b084f31424 100644 --- a/x-pack/plugins/fleet/server/routes/data_streams/handlers.ts +++ b/x-pack/plugins/fleet/server/routes/data_streams/handlers.ts @@ -8,7 +8,7 @@ import type { Dictionary } from 'lodash'; import { keyBy, keys, merge } from 'lodash'; import type { RequestHandler } from '@kbn/core/server'; import pMap from 'p-map'; -import type { IndicesDataStreamsStatsDataStreamsStatsItem } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { IndicesDataStreamsStatsDataStreamsStatsItem } from '@elastic/elasticsearch/lib/api/types'; import { ByteSizeValue } from '@kbn/config-schema'; import type { DataStream } from '../../types'; diff --git a/x-pack/plugins/fleet/server/services/agent_policies/package_policies_to_agent_permissions.ts b/x-pack/plugins/fleet/server/services/agent_policies/package_policies_to_agent_permissions.ts index a5fc2ba25de47..4d5fdf0c79a4a 100644 --- a/x-pack/plugins/fleet/server/services/agent_policies/package_policies_to_agent_permissions.ts +++ b/x-pack/plugins/fleet/server/services/agent_policies/package_policies_to_agent_permissions.ts @@ -8,7 +8,7 @@ import type { SecurityIndicesPrivileges, SecurityRoleDescriptor, -} from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +} from '@elastic/elasticsearch/lib/api/types'; import { FLEET_APM_PACKAGE, diff --git a/x-pack/plugins/fleet/server/services/agent_policy.ts b/x-pack/plugins/fleet/server/services/agent_policy.ts index a16363fe21c0c..e1b13159ef7f0 100644 --- a/x-pack/plugins/fleet/server/services/agent_policy.ts +++ b/x-pack/plugins/fleet/server/services/agent_policy.ts @@ -22,7 +22,7 @@ import type { } from '@kbn/core/server'; import { SavedObjectsUtils } from '@kbn/core/server'; -import type { BulkResponseItem } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { BulkResponseItem } from '@elastic/elasticsearch/lib/api/types'; import { DEFAULT_SPACE_ID } from '@kbn/spaces-plugin/common/constants'; diff --git a/x-pack/plugins/fleet/server/services/agents/action.mock.ts b/x-pack/plugins/fleet/server/services/agents/action.mock.ts index 77dc46b972532..50c2f0d6b0fbf 100644 --- a/x-pack/plugins/fleet/server/services/agents/action.mock.ts +++ b/x-pack/plugins/fleet/server/services/agents/action.mock.ts @@ -152,7 +152,7 @@ export function createClientMock() { esClientMock.mget.mockResponseImplementation((params) => { // @ts-expect-error - const docs = params?.body.docs.map(({ _id }) => { + const docs = params?.docs.map(({ _id }) => { let result; switch (_id) { case agentInHostedDoc._id: diff --git a/x-pack/plugins/fleet/server/services/agents/actions.test.ts b/x-pack/plugins/fleet/server/services/agents/actions.test.ts index b8cb2ce8c8d6a..594d553bff941 100644 --- a/x-pack/plugins/fleet/server/services/agents/actions.test.ts +++ b/x-pack/plugins/fleet/server/services/agents/actions.test.ts @@ -135,7 +135,7 @@ describe('Agent actions', () => { expect(esClient.create).toBeCalledWith( expect.objectContaining({ - body: expect.objectContaining({ + document: expect.objectContaining({ signed: { data: expect.any(String), signature: expect.any(String), @@ -180,7 +180,7 @@ describe('Agent actions', () => { expect(esClient.create).toBeCalledWith( expect.objectContaining({ - body: expect.not.objectContaining({ + document: expect.not.objectContaining({ signed: expect.any(Object), }), }) @@ -235,7 +235,7 @@ describe('Agent actions', () => { await bulkCreateAgentActions(esClient, newActions); expect(esClient.bulk).toHaveBeenCalledWith( expect.objectContaining({ - body: expect.arrayContaining([ + operations: expect.arrayContaining([ expect.arrayContaining([ expect.objectContaining({ signed: { @@ -274,7 +274,7 @@ describe('Agent actions', () => { await bulkCreateAgentActions(esClient, newActions); expect(esClient.bulk).toHaveBeenCalledWith( expect.objectContaining({ - body: expect.arrayContaining([ + operations: expect.arrayContaining([ expect.arrayContaining([ expect.not.objectContaining({ signed: { @@ -350,7 +350,7 @@ describe('Agent actions', () => { expect(esClient.create).toBeCalledTimes(2); expect(esClient.create).toBeCalledWith( expect.objectContaining({ - body: expect.objectContaining({ + document: expect.objectContaining({ type: 'CANCEL', data: { target_id: 'action1' }, agents: ['agent1', 'agent2'], @@ -359,7 +359,7 @@ describe('Agent actions', () => { ); expect(esClient.create).toBeCalledWith( expect.objectContaining({ - body: expect.objectContaining({ + document: expect.objectContaining({ type: 'CANCEL', data: { target_id: 'action1' }, agents: ['agent3', 'agent4'], diff --git a/x-pack/plugins/fleet/server/services/agents/actions.ts b/x-pack/plugins/fleet/server/services/agents/actions.ts index f0dcd9a1ac62d..a779499ca87b9 100644 --- a/x-pack/plugins/fleet/server/services/agents/actions.ts +++ b/x-pack/plugins/fleet/server/services/agents/actions.ts @@ -78,7 +78,7 @@ export async function createAgentAction( await esClient.create({ index: AGENT_ACTIONS_INDEX, id: uuidv4(), - body, + document: body, refresh: 'wait_for', }); @@ -112,7 +112,7 @@ export async function bulkCreateAgentActions( const messageSigningService = appContextService.getMessageSigningService(); await esClient.bulk({ index: AGENT_ACTIONS_INDEX, - body: await Promise.all( + operations: await Promise.all( actions.flatMap(async (action) => { const body: FleetServerAgentAction = { '@timestamp': new Date().toISOString(), @@ -221,7 +221,7 @@ export async function bulkCreateAgentActionResults( await esClient.bulk({ index: AGENT_ACTIONS_RESULTS_INDEX, - body: bulkBody, + operations: bulkBody, refresh: 'wait_for', }); } diff --git a/x-pack/plugins/fleet/server/services/agents/agent_service.ts b/x-pack/plugins/fleet/server/services/agents/agent_service.ts index 94583284d87f8..b18394b0aea08 100644 --- a/x-pack/plugins/fleet/server/services/agents/agent_service.ts +++ b/x-pack/plugins/fleet/server/services/agents/agent_service.ts @@ -13,9 +13,9 @@ import type { SavedObjectsClientContract, } from '@kbn/core/server'; -import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/types'; -import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type * as estypes from '@elastic/elasticsearch/lib/api/types'; import type { SortResults } from '@elastic/elasticsearch/lib/api/types'; diff --git a/x-pack/plugins/fleet/server/services/agents/crud.test.ts b/x-pack/plugins/fleet/server/services/agents/crud.test.ts index 00119e5bc44fb..6ccf5653bfc8f 100644 --- a/x-pack/plugins/fleet/server/services/agents/crud.test.ts +++ b/x-pack/plugins/fleet/server/services/agents/crud.test.ts @@ -107,9 +107,7 @@ describe('Agents CRUD test', () => { expect(searchMock).toHaveBeenCalledWith( expect.objectContaining({ aggs: { tags: { terms: { field: 'tags', size: 10000 } } }, - body: { - query: expect.any(Object), - }, + query: expect.any(Object), index: '.fleet-agents', size: 0, fields: ['status'], @@ -164,7 +162,7 @@ describe('Agents CRUD test', () => { }) ); - expect(searchMock.mock.calls.at(-1)[0].body.query).toEqual( + expect(searchMock.mock.calls.at(-1)[0].query).toEqual( toElasticsearchQuery( _joinFilters(['fleet-agents.policy_id: 123', 'NOT status:unenrolled'])! ) diff --git a/x-pack/plugins/fleet/server/services/agents/crud.ts b/x-pack/plugins/fleet/server/services/agents/crud.ts index e6a264c394397..bc3a9cb6028ff 100644 --- a/x-pack/plugins/fleet/server/services/agents/crud.ts +++ b/x-pack/plugins/fleet/server/services/agents/crud.ts @@ -6,13 +6,13 @@ */ import { groupBy } from 'lodash'; -import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type * as estypes from '@elastic/elasticsearch/lib/api/types'; import type { SortResults } from '@elastic/elasticsearch/lib/api/types'; import type { SavedObjectsClientContract, ElasticsearchClient } from '@kbn/core/server'; import type { KueryNode } from '@kbn/es-query'; import { fromKueryExpression, toElasticsearchQuery } from '@kbn/es-query'; import { DEFAULT_SPACE_ID } from '@kbn/spaces-plugin/common'; -import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/types'; import type { AgentSOAttributes, Agent, ListWithKuery } from '../../types'; import { appContextService, agentPolicyService } from '..'; @@ -169,13 +169,13 @@ export async function getAgentTags( } const kueryNode = _joinFilters(filters); - const body = kueryNode ? { query: toElasticsearchQuery(kueryNode) } : {}; + const query = kueryNode ? { query: toElasticsearchQuery(kueryNode) } : {}; const runtimeFields = await buildAgentStatusRuntimeField(soClient); try { const result = await esClient.search<{}, { tags: { buckets: Array<{ key: string }> } }>({ index: AGENTS_INDEX, size: 0, - body, + ...query, fields: Object.keys(runtimeFields), runtime_mappings: runtimeFields, aggs: { @@ -546,17 +546,15 @@ export async function getAgentVersionsForAgentPolicyIds( FleetServerAgent, Record<'agent_versions', { buckets: Array<{ key: string; doc_count: number }> }> >({ - body: { - query: { - bool: { - filter: [ - { - terms: { - policy_id: agentPolicyIds, - }, + query: { + bool: { + filter: [ + { + terms: { + policy_id: agentPolicyIds, }, - ], - }, + }, + ], }, }, index: AGENTS_INDEX, @@ -628,7 +626,7 @@ export async function updateAgent( await esClient.update({ id: agentId, index: AGENTS_INDEX, - body: { doc: agentSOAttributesToFleetServerAgentDoc(data) }, + doc: agentSOAttributesToFleetServerAgentDoc(data), refresh: 'wait_for', }); } @@ -645,7 +643,7 @@ export async function bulkUpdateAgents( return; } - const body = updateData.flatMap(({ agentId, data }) => [ + const operations = updateData.flatMap(({ agentId, data }) => [ { update: { _id: agentId, @@ -658,7 +656,7 @@ export async function bulkUpdateAgents( ]); const res = await esClient.bulk({ - body, + operations, index: AGENTS_INDEX, refresh: 'wait_for', }); @@ -676,9 +674,7 @@ export async function deleteAgent(esClient: ElasticsearchClient, agentId: string await esClient.update({ id: agentId, index: AGENTS_INDEX, - body: { - doc: { active: false }, - }, + doc: { active: false }, }); } catch (err) { if (isESClientError(err) && err.meta.statusCode === 404) { diff --git a/x-pack/plugins/fleet/server/services/agents/helpers.ts b/x-pack/plugins/fleet/server/services/agents/helpers.ts index 7433fa441953d..94a25ba59df59 100644 --- a/x-pack/plugins/fleet/server/services/agents/helpers.ts +++ b/x-pack/plugins/fleet/server/services/agents/helpers.ts @@ -5,7 +5,7 @@ * 2.0. */ -import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type * as estypes from '@elastic/elasticsearch/lib/api/types'; import type { SortResults } from '@elastic/elasticsearch/lib/api/types'; import type { SearchHit } from '@kbn/es-types'; diff --git a/x-pack/plugins/fleet/server/services/agents/reassign.test.ts b/x-pack/plugins/fleet/server/services/agents/reassign.test.ts index 5d55fdd5da31e..cf48ee20159f7 100644 --- a/x-pack/plugins/fleet/server/services/agents/reassign.test.ts +++ b/x-pack/plugins/fleet/server/services/agents/reassign.test.ts @@ -4,7 +4,7 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ -import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type * as estypes from '@elastic/elasticsearch/lib/api/types'; import { HostedAgentPolicyRestrictionRelatedError } from '../../errors'; @@ -40,7 +40,7 @@ describe('reassignAgent', () => { expect(esClient.update).toBeCalledTimes(1); const calledWith = esClient.update.mock.calls[0]; expect(calledWith[0]?.id).toBe(agentInRegularDoc._id); - expect((calledWith[0] as estypes.UpdateRequest)?.body?.doc).toHaveProperty( + expect((calledWith[0] as estypes.UpdateRequest)?.doc).toHaveProperty( 'policy_id', regularAgentPolicySO.id ); @@ -101,14 +101,14 @@ describe('reassignAgent', () => { // calls ES update with correct values const calledWith = esClient.bulk.mock.calls[0][0]; // only 1 are regular and bulk write two line per update - expect((calledWith as estypes.BulkRequest).body?.length).toBe(2); + expect((calledWith as estypes.BulkRequest).operations?.length).toBe(2); // @ts-expect-error - expect(calledWith.body[0].update._id).toEqual(agentInRegularDoc._id); + expect(calledWith.operations[0].update._id).toEqual(agentInRegularDoc._id); // hosted policy is updated in action results with error const calledWithActionResults = esClient.bulk.mock.calls[1][0] as estypes.BulkRequest; // bulk write two line per create - expect(calledWithActionResults.body?.length).toBe(4); + expect(calledWithActionResults.operations?.length).toBe(4); const expectedObject = expect.objectContaining({ '@timestamp': expect.anything(), action_id: expect.anything(), @@ -116,7 +116,7 @@ describe('reassignAgent', () => { error: 'Cannot reassign an agent from hosted agent policy hosted-agent-policy in Fleet because the agent policy is managed by an external orchestration solution, such as Elastic Cloud, Kubernetes, etc. Please make changes using your orchestration solution.', }); - expect(calledWithActionResults.body?.[1] as any).toEqual(expectedObject); + expect(calledWithActionResults.operations?.[1]).toEqual(expectedObject); }); it('should report errors from ES agent update call', async () => { @@ -147,7 +147,7 @@ describe('reassignAgent', () => { agent_id: agentInRegularDoc._id, error: 'version conflict', }); - expect(calledWithActionResults.body?.[1] as any).toEqual(expectedObject); + expect(calledWithActionResults.operations?.[1]).toEqual(expectedObject); }); }); }); diff --git a/x-pack/plugins/fleet/server/services/agents/request_diagnostics.test.ts b/x-pack/plugins/fleet/server/services/agents/request_diagnostics.test.ts index 7f6af525695cd..c6c3fc1622f20 100644 --- a/x-pack/plugins/fleet/server/services/agents/request_diagnostics.test.ts +++ b/x-pack/plugins/fleet/server/services/agents/request_diagnostics.test.ts @@ -4,7 +4,7 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ -import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type * as estypes from '@elastic/elasticsearch/lib/api/types'; import { appContextService } from '../app_context'; import { createAppContextStartContractMock } from '../../mocks'; @@ -33,7 +33,7 @@ describe('requestDiagnostics', () => { expect(esClient.create).toHaveBeenCalledWith( expect.objectContaining({ - body: expect.objectContaining({ + document: expect.objectContaining({ agents: ['agent-in-regular-policy'], type: 'REQUEST_DIAGNOSTICS', expiration: expect.anything(), @@ -53,7 +53,7 @@ describe('requestDiagnostics', () => { expect(esClient.create).toHaveBeenCalledWith( expect.objectContaining({ - body: expect.objectContaining({ + document: expect.objectContaining({ agents: ['agent-in-regular-policy-newer', 'agent-in-regular-policy-newer2'], type: 'REQUEST_DIAGNOSTICS', expiration: expect.anything(), @@ -70,7 +70,7 @@ describe('requestDiagnostics', () => { expect(esClient.create).toHaveBeenCalledWith( expect.objectContaining({ - body: expect.objectContaining({ + document: expect.objectContaining({ agents: ['agent-in-regular-policy-newer', 'agent-in-regular-policy'], type: 'REQUEST_DIAGNOSTICS', expiration: expect.anything(), @@ -80,14 +80,14 @@ describe('requestDiagnostics', () => { ); const calledWithActionResults = esClient.bulk.mock.calls[0][0] as estypes.BulkRequest; // bulk write two line per create - expect(calledWithActionResults.body?.length).toBe(2); + expect(calledWithActionResults.operations?.length).toBe(2); const expectedObject = expect.objectContaining({ '@timestamp': expect.anything(), action_id: expect.anything(), agent_id: 'agent-in-regular-policy', error: 'Agent agent-in-regular-policy does not support request diagnostics action.', }); - expect(calledWithActionResults.body?.[1] as any).toEqual(expectedObject); + expect(calledWithActionResults.operations?.[1]).toEqual(expectedObject); }); }); }); diff --git a/x-pack/plugins/fleet/server/services/agents/unenroll.test.ts b/x-pack/plugins/fleet/server/services/agents/unenroll.test.ts index b43c600a09a5d..222d49ae44eed 100644 --- a/x-pack/plugins/fleet/server/services/agents/unenroll.test.ts +++ b/x-pack/plugins/fleet/server/services/agents/unenroll.test.ts @@ -4,7 +4,7 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ -import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type * as estypes from '@elastic/elasticsearch/lib/api/types'; import { AGENT_ACTIONS_INDEX, AGENT_ACTIONS_RESULTS_INDEX } from '../../../common'; @@ -48,9 +48,7 @@ describe('unenroll', () => { expect(esClient.update).toBeCalledTimes(1); const calledWith = esClient.update.mock.calls[0]; expect(calledWith[0]?.id).toBe(agentInRegularDoc._id); - expect((calledWith[0] as estypes.UpdateRequest)?.body).toHaveProperty( - 'doc.unenrollment_started_at' - ); + expect(calledWith[0] as estypes.UpdateRequest).toHaveProperty('doc.unenrollment_started_at'); }); it('cannot unenroll from hosted agent policy by default', async () => { @@ -78,9 +76,7 @@ describe('unenroll', () => { expect(esClient.update).toBeCalledTimes(1); const calledWith = esClient.update.mock.calls[0]; expect(calledWith[0]?.id).toBe(agentInHostedDoc._id); - expect((calledWith[0] as estypes.UpdateRequest)?.body).toHaveProperty( - 'doc.unenrollment_started_at' - ); + expect(calledWith[0] as estypes.UpdateRequest).toHaveProperty('doc.unenrollment_started_at'); }); it('can unenroll from hosted agent policy with force=true and revoke=true', async () => { @@ -90,7 +86,7 @@ describe('unenroll', () => { expect(esClient.update).toBeCalledTimes(1); const calledWith = esClient.update.mock.calls[0]; expect(calledWith[0]?.id).toBe(agentInHostedDoc._id); - expect((calledWith[0] as estypes.UpdateRequest)?.body).toHaveProperty('doc.unenrolled_at'); + expect(calledWith[0] as estypes.UpdateRequest).toHaveProperty('doc.unenrolled_at'); }); }); @@ -102,10 +98,10 @@ describe('unenroll', () => { // calls ES update with correct values const calledWith = esClient.bulk.mock.calls[0][0]; - const ids = (calledWith as estypes.BulkRequest)?.body + const ids = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.update !== undefined) .map((i: any) => i.update._id); - const docs = (calledWith as estypes.BulkRequest)?.body + const docs = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.doc) .map((i: any) => i.doc); expect(ids).toEqual(idsToUnenroll); @@ -123,10 +119,10 @@ describe('unenroll', () => { // calls ES update with correct values const onlyRegular = [agentInRegularDoc._id, agentInRegularDoc2._id]; const calledWith = esClient.bulk.mock.calls[0][0]; - const ids = (calledWith as estypes.BulkRequest)?.body + const ids = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.update !== undefined) .map((i: any) => i.update._id); - const docs = (calledWith as estypes.BulkRequest)?.body + const docs = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.doc) .map((i: any) => i.doc); expect(ids).toEqual(onlyRegular); @@ -137,7 +133,7 @@ describe('unenroll', () => { // hosted policy is updated in action results with error const calledWithActionResults = esClient.bulk.mock.calls[1][0] as estypes.BulkRequest; // bulk write two line per create - expect(calledWithActionResults.body?.length).toBe(2); + expect(calledWithActionResults.operations?.length).toBe(2); const expectedObject = expect.objectContaining({ '@timestamp': expect.anything(), action_id: expect.anything(), @@ -145,7 +141,7 @@ describe('unenroll', () => { error: 'Cannot unenroll agent-in-hosted-policy from a hosted agent policy hosted-agent-policy in Fleet because the agent policy is managed by an external orchestration solution, such as Elastic Cloud, Kubernetes, etc. Please make changes using your orchestration solution.', }); - expect(calledWithActionResults.body?.[1] as any).toEqual(expectedObject); + expect(calledWithActionResults.operations?.[1]).toEqual(expectedObject); }); it('force unenroll updates in progress unenroll actions', async () => { @@ -186,7 +182,8 @@ describe('unenroll', () => { }); expect(esClient.bulk.mock.calls.length).toEqual(3); - const bulkBody = (esClient.bulk.mock.calls[2][0] as estypes.BulkRequest)?.body?.[1] as any; + const bulkBody = (esClient.bulk.mock.calls[2][0] as estypes.BulkRequest) + ?.operations?.[1] as any; expect(bulkBody.agent_id).toEqual(agentInRegularDoc._id); expect(bulkBody.action_id).toEqual('other-action'); }); @@ -248,10 +245,10 @@ describe('unenroll', () => { // calls ES update with correct values const onlyRegular = [agentInRegularDoc._id, agentInRegularDoc2._id]; const calledWith = esClient.bulk.mock.calls[0][0]; - const ids = (calledWith as estypes.BulkRequest)?.body + const ids = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.update !== undefined) .map((i: any) => i.update._id); - const docs = (calledWith as estypes.BulkRequest)?.body + const docs = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.doc) .map((i: any) => i.doc); expect(ids).toEqual(onlyRegular); @@ -260,19 +257,19 @@ describe('unenroll', () => { } const errorResults = esClient.bulk.mock.calls[2][0]; - const errorIds = (errorResults as estypes.BulkRequest)?.body + const errorIds = (errorResults as estypes.BulkRequest)?.operations ?.filter((i: any) => i.agent_id) .map((i: any) => i.agent_id); expect(errorIds).toEqual([agentInHostedDoc._id]); const actionResults = esClient.bulk.mock.calls[1][0]; - const resultIds = (actionResults as estypes.BulkRequest)?.body + const resultIds = (actionResults as estypes.BulkRequest)?.operations ?.filter((i: any) => i.agent_id) .map((i: any) => i.agent_id); expect(resultIds).toEqual(onlyRegular); const action = esClient.create.mock.calls[0][0] as any; - expect(action.body.type).toEqual('FORCE_UNENROLL'); + expect(action.document.type).toEqual('FORCE_UNENROLL'); }); it('can unenroll from hosted agent policy with force=true', async () => { @@ -283,10 +280,10 @@ describe('unenroll', () => { // calls ES update with correct values const calledWith = esClient.bulk.mock.calls[0][0]; - const ids = (calledWith as estypes.BulkRequest)?.body + const ids = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.update !== undefined) .map((i: any) => i.update._id); - const docs = (calledWith as estypes.BulkRequest)?.body + const docs = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.doc) .map((i: any) => i.doc); expect(ids).toEqual(idsToUnenroll); @@ -311,10 +308,10 @@ describe('unenroll', () => { // calls ES update with correct values const calledWith = esClient.bulk.mock.calls[0][0]; - const ids = (calledWith as estypes.BulkRequest)?.body + const ids = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.update !== undefined) .map((i: any) => i.update._id); - const docs = (calledWith as estypes.BulkRequest)?.body + const docs = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.doc) .map((i: any) => i.doc); expect(ids).toEqual(idsToUnenroll); @@ -323,13 +320,13 @@ describe('unenroll', () => { } const actionResults = esClient.bulk.mock.calls[1][0]; - const resultIds = (actionResults as estypes.BulkRequest)?.body + const resultIds = (actionResults as estypes.BulkRequest)?.operations ?.filter((i: any) => i.agent_id) .map((i: any) => i.agent_id); expect(resultIds).toEqual(idsToUnenroll); const action = esClient.create.mock.calls[0][0] as any; - expect(action.body.type).toEqual('FORCE_UNENROLL'); + expect(action.document.type).toEqual('FORCE_UNENROLL'); }); }); diff --git a/x-pack/plugins/fleet/server/services/agents/update_agent_tags.test.ts b/x-pack/plugins/fleet/server/services/agents/update_agent_tags.test.ts index cd408d953e31a..6a2410dfa3c16 100644 --- a/x-pack/plugins/fleet/server/services/agents/update_agent_tags.test.ts +++ b/x-pack/plugins/fleet/server/services/agents/update_agent_tags.test.ts @@ -112,7 +112,7 @@ describe('update_agent_tags', () => { await updateAgentTags(soClient, esClient, { agentIds: ['agent1'] }, ['one'], []); const agentAction = esClient.create.mock.calls[0][0] as any; - expect(agentAction?.body).toEqual( + expect(agentAction?.document).toEqual( expect.objectContaining({ action_id: expect.anything(), agents: [expect.any(String)], @@ -122,11 +122,11 @@ describe('update_agent_tags', () => { ); const actionResults = esClient.bulk.mock.calls[0][0] as any; - const agentIds = actionResults?.body + const agentIds = actionResults?.operations ?.filter((i: any) => i.agent_id) .map((i: any) => i.agent_id); expect(agentIds.length).toEqual(1); - expect(actionResults.body[1].error).not.toBeDefined(); + expect(actionResults.operations[1].error).not.toBeDefined(); }); it('should skip hosted agent from total when agentIds are passed', async () => { @@ -144,7 +144,7 @@ describe('update_agent_tags', () => { ); const agentAction = esClientMock.create.mock.calls[0][0] as any; - expect(agentAction?.body).toEqual( + expect(agentAction?.document).toEqual( expect.objectContaining({ action_id: expect.anything(), agents: [expect.any(String)], @@ -165,7 +165,7 @@ describe('update_agent_tags', () => { await updateAgentTags(soClient, esClient, { agentIds: ['agent1'] }, ['one'], []); const agentAction = esClient.create.mock.calls[0][0] as any; - expect(agentAction?.body).toEqual( + expect(agentAction?.document).toEqual( expect.objectContaining({ action_id: expect.anything(), agents: ['failure1'], @@ -175,7 +175,7 @@ describe('update_agent_tags', () => { ); const errorResults = esClient.bulk.mock.calls[0][0] as any; - expect(errorResults.body[1].error).toEqual('error reason'); + expect(errorResults.operations[1].error).toEqual('error reason'); }); it('should throw error on version conflicts', async () => { @@ -217,10 +217,10 @@ describe('update_agent_tags', () => { ).rejects.toThrowError('Version conflict of 100 agents'); const agentAction = esClient.create.mock.calls[0][0] as any; - expect(agentAction?.body.agents.length).toEqual(100); + expect(agentAction?.document.agents.length).toEqual(100); const errorResults = esClient.bulk.mock.calls[0][0] as any; - expect(errorResults.body[1].error).toEqual('version conflict on last retry'); + expect(errorResults.operations[1].error).toEqual('version conflict on last retry'); }); it('should combine action agents from updated, failures and version conflicts on last retry', async () => { @@ -249,7 +249,7 @@ describe('update_agent_tags', () => { ).rejects.toThrowError('Version conflict of 1 agents'); const agentAction = esClient.create.mock.calls[0][0] as any; - expect(agentAction?.body.agents.length).toEqual(3); + expect(agentAction?.document.agents.length).toEqual(3); }); it('should run add tags async when actioning more agents than batch size', async () => { @@ -367,7 +367,7 @@ describe('update_agent_tags', () => { ); const agentAction = esClient.create.mock.calls[0][0] as any; - expect(agentAction?.body).toEqual( + expect(agentAction?.document).toEqual( expect.objectContaining({ action_id: expect.anything(), agents: [expect.any(String)], diff --git a/x-pack/plugins/fleet/server/services/agents/upgrade.test.ts b/x-pack/plugins/fleet/server/services/agents/upgrade.test.ts index 7dbfaf86bd272..f39f557076283 100644 --- a/x-pack/plugins/fleet/server/services/agents/upgrade.test.ts +++ b/x-pack/plugins/fleet/server/services/agents/upgrade.test.ts @@ -5,7 +5,7 @@ * 2.0. */ -import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type * as estypes from '@elastic/elasticsearch/lib/api/types'; import { appContextService } from '../app_context'; import type { Agent } from '../../types'; @@ -58,10 +58,10 @@ describe('sendUpgradeAgentsActions (plural)', () => { // calls ES update with correct values const calledWith = esClient.bulk.mock.calls[0][0]; - const ids = (calledWith as estypes.BulkRequest)?.body + const ids = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.update !== undefined) .map((i: any) => i.update._id); - const docs = (calledWith as estypes.BulkRequest)?.body + const docs = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.doc) .map((i: any) => i.doc); @@ -80,10 +80,10 @@ describe('sendUpgradeAgentsActions (plural)', () => { // calls ES update with correct values const onlyRegular = [agentInRegularDoc._id, agentInRegularDoc2._id]; const calledWith = esClient.bulk.mock.calls[0][0]; - const ids = (calledWith as estypes.BulkRequest)?.body + const ids = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.update !== undefined) .map((i: any) => i.update._id); - const docs = (calledWith as estypes.BulkRequest)?.body + const docs = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.doc) .map((i: any) => i.doc); expect(ids).toEqual(onlyRegular); @@ -95,7 +95,7 @@ describe('sendUpgradeAgentsActions (plural)', () => { // hosted policy is updated in action results with error const calledWithActionResults = esClient.bulk.mock.calls[1][0] as estypes.BulkRequest; // bulk write two line per create - expect(calledWithActionResults.body?.length).toBe(2); + expect(calledWithActionResults.operations?.length).toBe(2); const expectedObject = expect.objectContaining({ '@timestamp': expect.anything(), action_id: expect.anything(), @@ -103,7 +103,7 @@ describe('sendUpgradeAgentsActions (plural)', () => { error: 'Cannot upgrade agent in hosted agent policy hosted-agent-policy in Fleet because the agent policy is managed by an external orchestration solution, such as Elastic Cloud, Kubernetes, etc. Please make changes using your orchestration solution.', }); - expect(calledWithActionResults.body?.[1] as any).toEqual(expectedObject); + expect(calledWithActionResults.operations?.[1]).toEqual(expectedObject); }); it('can upgrade from hosted agent policy with force=true', async () => { @@ -118,10 +118,10 @@ describe('sendUpgradeAgentsActions (plural)', () => { // calls ES update with correct values const calledWith = esClient.bulk.mock.calls[0][0]; - const ids = (calledWith as estypes.BulkRequest)?.body + const ids = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.update !== undefined) .map((i: any) => i.update._id); - const docs = (calledWith as estypes.BulkRequest)?.body + const docs = (calledWith as estypes.BulkRequest)?.operations ?.filter((i: any) => i.doc) .map((i: any) => i.doc); expect(ids).toEqual(idsToAction); diff --git a/x-pack/plugins/fleet/server/services/epm/elasticsearch/index/update_settings.ts b/x-pack/plugins/fleet/server/services/epm/elasticsearch/index/update_settings.ts index 766d03f6a776c..512a6661d80d5 100644 --- a/x-pack/plugins/fleet/server/services/epm/elasticsearch/index/update_settings.ts +++ b/x-pack/plugins/fleet/server/services/epm/elasticsearch/index/update_settings.ts @@ -7,7 +7,7 @@ import type { ElasticsearchClient } from '@kbn/core-elasticsearch-server'; -import type { IndicesIndexSettings } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { IndicesIndexSettings } from '@elastic/elasticsearch/lib/api/types'; import { appContextService } from '../../..'; diff --git a/x-pack/plugins/fleet/server/services/epm/elasticsearch/template/template.ts b/x-pack/plugins/fleet/server/services/epm/elasticsearch/template/template.ts index 3c9cce1bcf8b6..c13e59dd50930 100644 --- a/x-pack/plugins/fleet/server/services/epm/elasticsearch/template/template.ts +++ b/x-pack/plugins/fleet/server/services/epm/elasticsearch/template/template.ts @@ -10,7 +10,7 @@ import type { IndicesIndexSettings, MappingDynamicTemplate, MappingTypeMapping, -} from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +} from '@elastic/elasticsearch/lib/api/types'; import pMap from 'p-map'; import { isResponseError } from '@kbn/es-errors'; diff --git a/x-pack/plugins/fleet/server/services/epm/elasticsearch/template/utils.ts b/x-pack/plugins/fleet/server/services/epm/elasticsearch/template/utils.ts index 6a34beb371082..2b5102eb2f481 100644 --- a/x-pack/plugins/fleet/server/services/epm/elasticsearch/template/utils.ts +++ b/x-pack/plugins/fleet/server/services/epm/elasticsearch/template/utils.ts @@ -4,7 +4,7 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ -import type { MappingTypeMapping } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { MappingTypeMapping } from '@elastic/elasticsearch/lib/api/types'; import { USER_SETTINGS_TEMPLATE_SUFFIX } from '../../../../constants'; diff --git a/x-pack/plugins/fleet/server/services/epm/elasticsearch/transform/reauthorize.ts b/x-pack/plugins/fleet/server/services/epm/elasticsearch/transform/reauthorize.ts index d664392b8b676..9beaa7830ebd8 100644 --- a/x-pack/plugins/fleet/server/services/epm/elasticsearch/transform/reauthorize.ts +++ b/x-pack/plugins/fleet/server/services/epm/elasticsearch/transform/reauthorize.ts @@ -11,7 +11,7 @@ import type { SavedObjectsClientContract } from '@kbn/core-saved-objects-api-ser import { sortBy, uniqBy } from 'lodash'; import { isPopulatedObject } from '@kbn/ml-is-populated-object'; -import type { ErrorResponseBase } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { ErrorResponseBase } from '@elastic/elasticsearch/lib/api/types'; import type { SecondaryAuthorizationHeader } from '../../../../../common/types/models/transform_api_key'; import { updateEsAssetReferences } from '../../packages/es_assets_reference'; diff --git a/x-pack/plugins/fleet/server/services/experimental_datastream_features_helper.ts b/x-pack/plugins/fleet/server/services/experimental_datastream_features_helper.ts index a33f936a613f4..0f766062ab20e 100644 --- a/x-pack/plugins/fleet/server/services/experimental_datastream_features_helper.ts +++ b/x-pack/plugins/fleet/server/services/experimental_datastream_features_helper.ts @@ -5,10 +5,7 @@ * 2.0. */ -import type { - MappingProperty, - PropertyName, -} from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { MappingProperty, PropertyName } from '@elastic/elasticsearch/lib/api/types'; import type { ExperimentalDataStreamFeature } from '../../common/types'; diff --git a/x-pack/plugins/fleet/server/services/files/client_from_host.ts b/x-pack/plugins/fleet/server/services/files/client_from_host.ts index 814d342ddd993..4781f9467fb77 100644 --- a/x-pack/plugins/fleet/server/services/files/client_from_host.ts +++ b/x-pack/plugins/fleet/server/services/files/client_from_host.ts @@ -9,7 +9,7 @@ import type { Readable } from 'stream'; import type { ElasticsearchClient } from '@kbn/core-elasticsearch-server'; import type { Logger } from '@kbn/core/server'; -import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type * as estypes from '@elastic/elasticsearch/lib/api/types'; import type { FileClient } from '@kbn/files-plugin/server'; import { createEsFileClient } from '@kbn/files-plugin/server'; diff --git a/x-pack/plugins/fleet/server/services/security/uninstall_token_service/index.ts b/x-pack/plugins/fleet/server/services/security/uninstall_token_service/index.ts index 1f58fcafd396b..275dcfc3a281d 100644 --- a/x-pack/plugins/fleet/server/services/security/uninstall_token_service/index.ts +++ b/x-pack/plugins/fleet/server/services/security/uninstall_token_service/index.ts @@ -28,7 +28,7 @@ import { asyncForEach, asyncMap } from '@kbn/std'; import type { AggregationsTermsInclude, AggregationsTermsExclude, -} from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +} from '@elastic/elasticsearch/lib/api/types'; import { isResponseError } from '@kbn/es-errors'; import { DEFAULT_SPACE_ID } from '@kbn/spaces-plugin/common'; import { DEFAULT_NAMESPACE_STRING } from '@kbn/core-saved-objects-utils-server';