Skip to content

Commit

Permalink
[EEM] Calculate the latest metadata lookback based on the calculated …
Browse files Browse the repository at this point in the history
…history delay (elastic#191324)
  • Loading branch information
simianhacker authored Aug 28, 2024
1 parent 03ba36a commit 7944c19
Show file tree
Hide file tree
Showing 6 changed files with 54 additions and 12 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0; you may not use this file except in compliance with the Elastic License
* 2.0.
*/

import { EntityDefinition } from '@kbn/entities-schema';
import moment from 'moment';
import {
ENTITY_DEFAULT_HISTORY_FREQUENCY,
ENTITY_DEFAULT_HISTORY_SYNC_DELAY,
} from '../../../../common/constants_entities';

const durationToSeconds = (dateMath: string) => {
const parts = dateMath.match(/(\d+)([m|s|h|d])/);
if (!parts) {
throw new Error(`Invalid date math supplied: ${dateMath}`);
}
const value = parseInt(parts[1], 10);
const unit = parts[2] as 'm' | 's' | 'h' | 'd';
return moment.duration(value, unit).asSeconds();
};

export function calculateOffset(definition: EntityDefinition) {
const syncDelay = durationToSeconds(
definition.history.settings.syncDelay || ENTITY_DEFAULT_HISTORY_SYNC_DELAY
);
const frequency =
durationToSeconds(definition.history.settings.frequency || ENTITY_DEFAULT_HISTORY_FREQUENCY) *
2;

return syncDelay + frequency;
}
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,11 @@ export const rawEntityDefinition = {
history: {
timestampField: '@timestamp',
interval: '1m',
settings: {
lookbackPeriod: '10m',
frequency: '2m',
syncDelay: '2m',
},
},
identityFields: ['log.logger', { field: 'event.category', optional: true }],
displayNameTemplate: '{{log.logger}}{{#event.category}}:{{.}}{{/event.category}}',
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ describe('Generate Metadata Aggregations for history and latest', () => {
filter: {
range: {
'@timestamp': {
gte: 'now-1m',
gte: 'now-360s',
},
},
},
Expand All @@ -112,7 +112,7 @@ describe('Generate Metadata Aggregations for history and latest', () => {
filter: {
range: {
'@timestamp': {
gte: 'now-1m',
gte: 'now-360s',
},
},
},
Expand All @@ -138,7 +138,7 @@ describe('Generate Metadata Aggregations for history and latest', () => {
filter: {
range: {
'@timestamp': {
gte: 'now-1m',
gte: 'now-360s',
},
},
},
Expand All @@ -164,7 +164,7 @@ describe('Generate Metadata Aggregations for history and latest', () => {
filter: {
range: {
'@timestamp': {
gte: 'now-1m',
gte: 'now-360s',
},
},
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@

import { EntityDefinition } from '@kbn/entities-schema';
import { ENTITY_DEFAULT_METADATA_LIMIT } from '../../../../common/constants_entities';
import { calculateOffset } from '../helpers/calculate_offset';

export function generateHistoryMetadataAggregations(definition: EntityDefinition) {
if (!definition.metadata) {
Expand All @@ -31,14 +32,16 @@ export function generateLatestMetadataAggregations(definition: EntityDefinition)
return {};
}

const offsetInSeconds = calculateOffset(definition);

return definition.metadata.reduce(
(aggs, metadata) => ({
...aggs,
[`entity.metadata.${metadata.destination}`]: {
filter: {
range: {
'@timestamp': {
gte: `now-${definition.history.interval}`,
gte: `now-${offsetInSeconds}s`,
},
},
},
Expand Down

0 comments on commit 7944c19

Please sign in to comment.