From 2a242ec8c8250a7e7d5ad943dff7b71ff93acfdb Mon Sep 17 00:00:00 2001 From: Samuel Hassine Date: Wed, 3 Feb 2021 21:15:20 +0100 Subject: [PATCH] [api] Add migration to purge indicates indexing --- .../StixDomainObjectKnowledge.js | 2 +- .../src/database/elasticSearch.js | 2 +- ...612381566895-clear_indicates_indexation.js | 41 +++++++++++++++++++ 3 files changed, 43 insertions(+), 2 deletions(-) create mode 100644 opencti-platform/opencti-graphql/src/migrations/1612381566895-clear_indicates_indexation.js diff --git a/opencti-platform/opencti-front/src/private/components/common/stix_domain_objects/StixDomainObjectKnowledge.js b/opencti-platform/opencti-front/src/private/components/common/stix_domain_objects/StixDomainObjectKnowledge.js index 3f84121fafd6..fc907e2400f4 100644 --- a/opencti-platform/opencti-front/src/private/components/common/stix_domain_objects/StixDomainObjectKnowledge.js +++ b/opencti-platform/opencti-front/src/private/components/common/stix_domain_objects/StixDomainObjectKnowledge.js @@ -269,7 +269,7 @@ class StixDomainObjectKnowledge extends Component { /> {stixDomainObjectType === 'Sector' && ( - + { const query = { index: indexName, ignore_throttled: IGNORE_THROTTLED, - _source_excludes: `${REL_INDEX_PREFIX}*`, + //_source_excludes: `${REL_INDEX_PREFIX}*`, track_total_hits: true, body, }; diff --git a/opencti-platform/opencti-graphql/src/migrations/1612381566895-clear_indicates_indexation.js b/opencti-platform/opencti-graphql/src/migrations/1612381566895-clear_indicates_indexation.js new file mode 100644 index 000000000000..e61cf75d9d63 --- /dev/null +++ b/opencti-platform/opencti-graphql/src/migrations/1612381566895-clear_indicates_indexation.js @@ -0,0 +1,41 @@ +import * as R from 'ramda'; +import { Promise } from 'bluebird'; +import { READ_DATA_INDICES } from '../database/utils'; +import { ENTITY_TYPE_INDICATOR } from '../schema/stixDomainObject'; +import { BULK_TIMEOUT, elBulk, elList, ES_MAX_CONCURRENCY, MAX_SPLIT } from '../database/elasticSearch'; +import { logger } from '../config/conf'; +import { SYSTEM_USER } from '../domain/user'; +import { ABSTRACT_STIX_CORE_OBJECT, ABSTRACT_STIX_CORE_RELATIONSHIP } from '../schema/general'; + +export const up = async (next) => { + const start = new Date().getTime(); + logger.info(`[MIGRATION] Cleaning indicates for all entities and relationships`); + const bulkOperations = []; + const callback = (entities) => { + const op = entities + .filter((n) => n.entity_type !== ENTITY_TYPE_INDICATOR) + .map((att) => { + return [{ update: { _index: att._index, _id: att.id } }, { doc: { 'rel_indicates.internal_id': null } }]; + }) + .flat(); + bulkOperations.push(...op); + }; + const filters = [{ key: 'rel_indicates.internal_id', values: ['EXISTS'] }]; + const opts = { types: [ABSTRACT_STIX_CORE_OBJECT, ABSTRACT_STIX_CORE_RELATIONSHIP], filters, callback }; + await elList(SYSTEM_USER, READ_DATA_INDICES, opts); + // Apply operations. + let currentProcessing = 0; + const groupsOfOperations = R.splitEvery(MAX_SPLIT, bulkOperations); + const concurrentUpdate = async (bulk) => { + await elBulk({ refresh: true, timeout: BULK_TIMEOUT, body: bulk }); + currentProcessing += bulk.length; + logger.info(`[OPENCTI] Cleaning indicates indexation: ${currentProcessing} / ${bulkOperations.length}`); + }; + await Promise.map(groupsOfOperations, concurrentUpdate, { concurrency: ES_MAX_CONCURRENCY }); + logger.info(`[MIGRATION] Cleaning indicates done in ${new Date() - start} ms`); + next(); +}; + +export const down = async (next) => { + next(); +};