Skip to content

Commit

Permalink
[Cloud Security] Plugin Initialize - Updating `logs-cloud_security_po…
Browse files Browse the repository at this point in the history
…sture.findings_latest-default` index mappings (#151460)

(cherry picked from commit eba0dc6)
  • Loading branch information
kfirpeled committed Feb 20, 2023
1 parent 4ed6814 commit c7e4d9f
Showing 1 changed file with 37 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
*/
import type { ElasticsearchClient, Logger } from '@kbn/core/server';
import { errors } from '@elastic/elasticsearch';
import type { MappingTypeMapping } from '@elastic/elasticsearch/lib/api/types';
import {
BENCHMARK_SCORE_INDEX_DEFAULT_NS,
BENCHMARK_SCORE_INDEX_PATTERN,
Expand Down Expand Up @@ -107,7 +108,21 @@ const createLatestFindingsIndex = async (esClient: ElasticsearchClient, logger:
composed_of,
});

await createIndexSafe(esClient, logger, LATEST_FINDINGS_INDEX_DEFAULT_NS);
const result = await createIndexSafe(esClient, logger, LATEST_FINDINGS_INDEX_DEFAULT_NS);

if (result === 'already-exists') {
// Make sure mappings are up-to-date
const simulateResponse = await esClient.indices.simulateTemplate({
name: LATEST_FINDINGS_INDEX_TEMPLATE_NAME,
});

await updateIndexSafe(
esClient,
logger,
LATEST_FINDINGS_INDEX_DEFAULT_NS,
simulateResponse.template.mappings
);
}
} catch (e) {
logger.error(
`Failed to upsert index template [Template: ${LATEST_FINDINGS_INDEX_TEMPLATE_NAME}]`
Expand Down Expand Up @@ -155,11 +170,32 @@ const createIndexSafe = async (esClient: ElasticsearchClient, logger: Logger, in
});

logger.info(`Created index successfully [Name: ${index}]`);
return 'success';
} else {
logger.trace(`Index already exists [Name: ${index}]`);
return 'already-exists';
}
} catch (e) {
logger.error(`Failed to create index [Name: ${index}]`);
logger.error(e);
return 'fail';
}
};

const updateIndexSafe = async (
esClient: ElasticsearchClient,
logger: Logger,
index: string,
mappings: MappingTypeMapping
) => {
try {
await esClient.indices.putMapping({
index,
properties: mappings.properties,
});
logger.info(`Updated index successfully [Name: ${index}]`);
} catch (e) {
logger.error(`Failed to update index [Name: ${index}]`);
logger.error(e);
}
};

0 comments on commit c7e4d9f

Please sign in to comment.