Skip to content

Commit

Permalink
[8.x] [Synthetics] Add labels field !! (#193250) (#193536)
Browse files Browse the repository at this point in the history
# Backport

This will backport the following commits from `main` to `8.x`:
- [[Synthetics] Add labels field !!
(#193250)](#193250)

<!--- Backport version: 9.4.3 -->

### Questions ?
Please refer to the [Backport tool
documentation](https://github.com/sqren/backport)

<!--BACKPORT
[{"author":{"name":"Shahzad","email":"[email protected]"},"sourceCommit":{"committedDate":"2024-09-20T10:50:41Z","message":"[Synthetics]
Add labels field !! (#193250)\n\n## Summary\r\n\r\nPart of
https://github.com/elastic/synthetics/issues/729\r\n\r\nAdd labels
fields !!\r\n\r\nShow them in details \r\n\r\n<img width=\"1520\"
alt=\"image\"\r\nsrc=\"https://github.com/user-attachments/assets/36050903-d2bc-458e-9f10-a912be76a9e9\">\r\n\r\nFrom
add/edit configs \r\n\r\n<img width=\"1718\"
alt=\"image\"\r\nsrc=\"https://github.com/user-attachments/assets/c3ed615e-cf0f-47f5-93f4-da9464add031\">\r\n\r\nas
part of es docs\r\n\r\n<img width=\"1728\"
alt=\"image\"\r\nsrc=\"https://github.com/user-attachments/assets/35a2c4d3-a1b1-4712-a45b-19750543e82d\">","sha":"ca018a7c890c6e297d1314d9fc4cef6a7f8f741a","branchLabelMapping":{"^v9.0.0$":"main","^v8.16.0$":"8.x","^v(\\d+).(\\d+).\\d+$":"$1.$2"}},"sourcePullRequest":{"labels":["v9.0.0","release_note:feature","backport:prev-minor","ci:project-deploy-observability","Team:obs-ux-management"],"title":"[Synthetics]
Add labels field
!!","number":193250,"url":"https://github.com/elastic/kibana/pull/193250","mergeCommit":{"message":"[Synthetics]
Add labels field !! (#193250)\n\n## Summary\r\n\r\nPart of
https://github.com/elastic/synthetics/issues/729\r\n\r\nAdd labels
fields !!\r\n\r\nShow them in details \r\n\r\n<img width=\"1520\"
alt=\"image\"\r\nsrc=\"https://github.com/user-attachments/assets/36050903-d2bc-458e-9f10-a912be76a9e9\">\r\n\r\nFrom
add/edit configs \r\n\r\n<img width=\"1718\"
alt=\"image\"\r\nsrc=\"https://github.com/user-attachments/assets/c3ed615e-cf0f-47f5-93f4-da9464add031\">\r\n\r\nas
part of es docs\r\n\r\n<img width=\"1728\"
alt=\"image\"\r\nsrc=\"https://github.com/user-attachments/assets/35a2c4d3-a1b1-4712-a45b-19750543e82d\">","sha":"ca018a7c890c6e297d1314d9fc4cef6a7f8f741a"}},"sourceBranch":"main","suggestedTargetBranches":[],"targetPullRequestStates":[{"branch":"main","label":"v9.0.0","branchLabelMappingKey":"^v9.0.0$","isSourceBranch":true,"state":"MERGED","url":"https://github.com/elastic/kibana/pull/193250","number":193250,"mergeCommit":{"message":"[Synthetics]
Add labels field !! (#193250)\n\n## Summary\r\n\r\nPart of
https://github.com/elastic/synthetics/issues/729\r\n\r\nAdd labels
fields !!\r\n\r\nShow them in details \r\n\r\n<img width=\"1520\"
alt=\"image\"\r\nsrc=\"https://github.com/user-attachments/assets/36050903-d2bc-458e-9f10-a912be76a9e9\">\r\n\r\nFrom
add/edit configs \r\n\r\n<img width=\"1718\"
alt=\"image\"\r\nsrc=\"https://github.com/user-attachments/assets/c3ed615e-cf0f-47f5-93f4-da9464add031\">\r\n\r\nas
part of es docs\r\n\r\n<img width=\"1728\"
alt=\"image\"\r\nsrc=\"https://github.com/user-attachments/assets/35a2c4d3-a1b1-4712-a45b-19750543e82d\">","sha":"ca018a7c890c6e297d1314d9fc4cef6a7f8f741a"}}]}]
BACKPORT-->

Co-authored-by: Shahzad <[email protected]>
  • Loading branch information
kibanamachine and shahzad31 authored Sep 20, 2024
1 parent 5eb5c27 commit 774f7bd
Show file tree
Hide file tree
Showing 17 changed files with 97 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -152,6 +152,7 @@ export const DEFAULT_COMMON_FIELDS: CommonFields = {
[ConfigKey.CONFIG_HASH]: '',
[ConfigKey.MONITOR_QUERY_ID]: '',
[ConfigKey.PARAMS]: '',
[ConfigKey.LABELS]: {},
[ConfigKey.MAX_ATTEMPTS]: 2,
revision: 1,
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ export enum ConfigKey {
JOURNEY_ID = 'journey_id',
MAX_REDIRECTS = 'max_redirects',
METADATA = '__ui',
LABELS = 'labels',
MODE = 'mode',
MONITOR_TYPE = 'type',
NAME = 'name',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,7 @@ export const CommonFieldsCodec = t.intersection([
[ConfigKey.CUSTOM_HEARTBEAT_ID]: t.string,
[ConfigKey.ALERT_CONFIG]: AlertConfigsCodec,
[ConfigKey.PARAMS]: t.string,
[ConfigKey.LABELS]: t.record(t.string, t.string),
retest_on_failure: t.boolean,
}),
]);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,7 @@ export const ProjectMonitorCodec = t.intersection([
hash: t.string,
namespace: t.string,
retestOnFailure: t.boolean,
labels: t.record(t.string, t.string),
}),
]);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import {
import { i18n } from '@kbn/i18n';
import { useDispatch } from 'react-redux';
import { TagsList } from '@kbn/observability-shared-plugin/public';
import { isEmpty } from 'lodash';
import { PanelWithTitle } from './panel_with_title';
import { MonitorEnabled } from '../../monitors_page/management/monitor_list_table/monitor_enabled';
import { getMonitorAction } from '../../../state';
Expand Down Expand Up @@ -57,6 +58,7 @@ export const MonitorDetailsPanel = ({
}

const url = latestPing?.url?.full ?? (monitor as unknown as MonitorFields)[ConfigKey.URLS];
const labels = monitor[ConfigKey.LABELS];

return (
<PanelWithTitle
Expand Down Expand Up @@ -145,6 +147,19 @@ export const MonitorDetailsPanel = ({
<EuiDescriptionListDescription>
<TagsList tags={monitor[ConfigKey.TAGS]} />
</EuiDescriptionListDescription>

{!isEmpty(labels) ? (
<>
<EuiDescriptionListTitle>{LABELS_LABEL}</EuiDescriptionListTitle>
<EuiDescriptionListDescription>
{Object.entries(labels ?? {}).map(([key, value]) => (
<div key={key}>
<strong>{key}</strong>: {value}
</div>
))}
</EuiDescriptionListDescription>
</>
) : null}
</EuiDescriptionList>
</PanelWithTitle>
);
Expand Down Expand Up @@ -225,6 +240,10 @@ const TAGS_LABEL = i18n.translate('xpack.synthetics.management.monitorList.tags'
defaultMessage: 'Tags',
});

const LABELS_LABEL = i18n.translate('xpack.synthetics.management.monitorList.labels', {
defaultMessage: 'Labels',
});

const ENABLED_LABEL = i18n.translate('xpack.synthetics.detailsPanel.monitorDetails.enabled', {
defaultMessage: 'Enabled (all locations)',
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1092,6 +1092,55 @@ export const FIELD = (readOnly?: boolean): FieldMap => ({
},
}),
},
[ConfigKey.LABELS]: {
fieldKey: ConfigKey.LABELS,
label: i18n.translate('xpack.synthetics.monitorConfig.meta.label', {
defaultMessage: 'Label fields',
}),
controlled: true,
component: KeyValuePairsField,
helpText: i18n.translate('xpack.synthetics.monitorConfig.meta.helpText', {
defaultMessage:
'List of key-value pairs that will be sent with each monitor event. Useful for adding custom metadata to your monitor.',
}),
props: ({ field, setValue, trigger }): KeyValuePairsFieldProps => ({
readOnly,
keyLabel: i18n.translate('xpack.synthetics.monitorConfig.field.key.label', {
defaultMessage: 'Field',
}),
valueLabel: i18n.translate('xpack.synthetics.monitorConfig.field.value.label', {
defaultMessage: 'Value',
}),
addPairControlLabel: i18n.translate('xpack.synthetics.monitorConfig.metaField.label', {
defaultMessage: 'Add label field',
}),
onChange: async (pairs) => {
const value: Record<string, string> = {};
pairs.forEach((pair) => {
const [fieldKey, fieldValue] = pair;
value[fieldKey] = String(fieldValue);
});
if (!isEqual(value, field?.value)) {
setValue(ConfigKey.LABELS, value);
await trigger(ConfigKey.LABELS);
}
},
defaultPairs: Object.entries(field?.value || {}),
}),
validation: () => ({
validate: {
validBodyJSON: (value: Record<string, string>) => {
if (Object.entries(value).some((check) => !check[0] || !check[1])) {
return i18n.translate('xpack.synthetics.monitorConfig.metaFields.error', {
defaultMessage:
'This meta fields is not valid. Make sure that both the field and value are defined.',
});
}
return true;
},
},
}),
},
isTLSEnabled: {
fieldKey: 'isTLSEnabled',
component: Switch,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ const DEFAULT_DATA_OPTIONS = (readOnly: boolean) => ({
}),
components: [
FIELD(readOnly)[ConfigKey.TAGS],
FIELD(readOnly)[ConfigKey.LABELS],
FIELD(readOnly)[ConfigKey.APM_SERVICE_NAME],
FIELD(readOnly)[ConfigKey.NAMESPACE],
],
Expand Down Expand Up @@ -247,6 +248,7 @@ export const FORM_CONFIG = (readOnly: boolean): FieldConfig => ({
...DEFAULT_DATA_OPTIONS(readOnly),
components: [
FIELD(readOnly)[ConfigKey.TAGS],
FIELD(readOnly)[ConfigKey.LABELS],
FIELD(readOnly)[ConfigKey.APM_SERVICE_NAME],
FIELD(readOnly)[ConfigKey.SCREENSHOTS],
FIELD(readOnly)[ConfigKey.NAMESPACE],
Expand All @@ -272,6 +274,7 @@ export const FORM_CONFIG = (readOnly: boolean): FieldConfig => ({
...DEFAULT_DATA_OPTIONS(readOnly),
components: [
FIELD(readOnly)[ConfigKey.TAGS],
FIELD(readOnly)[ConfigKey.LABELS],
FIELD(readOnly)[ConfigKey.APM_SERVICE_NAME],
FIELD(readOnly)[ConfigKey.SCREENSHOTS],
FIELD(readOnly)[ConfigKey.NAMESPACE],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -165,4 +165,5 @@ export interface FieldMap {
[ConfigKey.MODE]: FieldMeta<ConfigKey.MODE>;
[ConfigKey.IPV4]: FieldMeta<ConfigKey.IPV4>;
[ConfigKey.MAX_ATTEMPTS]: FieldMeta<ConfigKey.MAX_ATTEMPTS>;
[ConfigKey.LABELS]: FieldMeta<ConfigKey.LABELS>;
}
Original file line number Diff line number Diff line change
Expand Up @@ -107,6 +107,7 @@ describe('AddNewMonitorsPublicAPI', () => {
type: 'tcp',
'url.port': null,
urls: '',
labels: {},
});
});
it('should normalize icmp', async () => {
Expand Down Expand Up @@ -143,6 +144,7 @@ describe('AddNewMonitorsPublicAPI', () => {
timeout: '16',
type: 'icmp',
wait: '1',
labels: {},
});
});
it('should normalize http', async () => {
Expand Down Expand Up @@ -201,6 +203,7 @@ describe('AddNewMonitorsPublicAPI', () => {
'url.port': null,
urls: '',
username: '',
labels: {},
});
});
it('should normalize browser', async () => {
Expand Down Expand Up @@ -255,6 +258,7 @@ describe('AddNewMonitorsPublicAPI', () => {
type: 'browser',
'url.port': null,
urls: '',
labels: {},
});
});
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -163,6 +163,7 @@ describe('Monitor migrations v8.7.0 -> v8.8.0', () => {
type: 'browser',
'url.port': null,
urls: 'https://elastic.co',
labels: {},
},
coreMigrationVersion: '8.8.0',
created_at: '2023-03-31T20:31:24.177Z',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ export const commonFormatters: CommonFormatMap = {
[ConfigKey.REVISION]: null,
[ConfigKey.MONITOR_SOURCE_TYPE]: null,
[ConfigKey.FORM_MONITOR_TYPE]: null,
[ConfigKey.LABELS]: null,
[ConfigKey.JOURNEY_ID]: stringToJsonFormatter,
[ConfigKey.PROJECT_ID]: stringToJsonFormatter,
[ConfigKey.CUSTOM_HEARTBEAT_ID]: stringToJsonFormatter,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,9 @@
* 2.0.
*/

import { isEmpty } from 'lodash';
import { ProcessorFields } from './format_synthetics_policy';
import { HeartbeatFields, MonitorFields } from '../../../../common/runtime_types';
import { ConfigKey, HeartbeatFields, MonitorFields } from '../../../../common/runtime_types';

interface FieldProcessor {
add_fields: {
Expand All @@ -16,6 +17,7 @@ interface FieldProcessor {
}

export const processorsFormatter = (config: MonitorFields & ProcessorFields) => {
const labels = config[ConfigKey.LABELS] ?? {};
const processors: FieldProcessor[] = [
{
add_fields: {
Expand All @@ -30,6 +32,7 @@ export const processorsFormatter = (config: MonitorFields & ProcessorFields) =>
meta: {
space_id: config.space_id,
},
...(isEmpty(labels) ? {} : { labels }),
},
target: '',
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,4 +55,5 @@ export const commonFormatters: CommonFormatMap = {
[ConfigKey.SCHEDULE]: (fields) =>
`@every ${fields[ConfigKey.SCHEDULE]?.number}${fields[ConfigKey.SCHEDULE]?.unit}`,
[ConfigKey.TAGS]: arrayFormatter,
[ConfigKey.LABELS]: null,
};
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ const UI_KEYS_TO_SKIP = [
ConfigKey.TEXT_ASSERTION,
ConfigKey.CONFIG_HASH,
ConfigKey.ALERT_CONFIG,
ConfigKey.LABELS,
'secrets',
];

Expand Down Expand Up @@ -97,6 +98,7 @@ export const formatHeartbeatRequest = (
const heartbeatIdT = heartbeatId ?? monitor[ConfigKey.MONITOR_QUERY_ID];

const paramsString = params ?? (monitor as BrowserFields)[ConfigKey.PARAMS];
const { labels } = monitor;

return {
...monitor,
Expand All @@ -110,6 +112,7 @@ export const formatHeartbeatRequest = (
meta: {
space_id: spaceId,
},
...(isEmpty(labels) ? {} : { labels }),
},
fields_under_root: true,
params: monitor.type === 'browser' ? paramsString : '',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -241,6 +241,7 @@ export default function ({ getService }: FtrProviderContext) {
id: `${journeyId}-${project}-default`,
hash: 'ekrjelkjrelkjre',
max_attempts: 2,
labels: {},
});
}
} finally {
Expand Down Expand Up @@ -425,6 +426,7 @@ export default function ({ getService }: FtrProviderContext) {
ipv6: true,
ipv4: true,
max_attempts: 2,
labels: {},
});
}
} finally {
Expand Down Expand Up @@ -542,6 +544,7 @@ export default function ({ getService }: FtrProviderContext) {
ipv4: true,
params: '',
max_attempts: 2,
labels: {},
});
}
} finally {
Expand Down Expand Up @@ -656,6 +659,7 @@ export default function ({ getService }: FtrProviderContext) {
ipv6: true,
params: '',
max_attempts: 2,
labels: {},
});
}
} finally {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -78,5 +78,6 @@
"mode": "any",
"ipv4": true,
"ipv6": true,
"params": ""
"params": "",
"labels": {}
}
1 change: 1 addition & 0 deletions x-pack/test/api_integration/apis/synthetics/get_monitor.ts
Original file line number Diff line number Diff line change
Expand Up @@ -203,6 +203,7 @@ export default function ({ getService }: FtrProviderContext) {
revision: 1,
locations: [LOCAL_LOCATION],
name: 'Test HTTP Monitor 044',
labels: {},
});
});

Expand Down

0 comments on commit 774f7bd

Please sign in to comment.