diff --git a/x-pack/plugins/uptime/common/graphql/introspection.json b/x-pack/plugins/uptime/common/graphql/introspection.json index d71c749aab56..d17a16e9d806 100644 --- a/x-pack/plugins/uptime/common/graphql/introspection.json +++ b/x-pack/plugins/uptime/common/graphql/introspection.json @@ -505,6 +505,14 @@ "type": { "kind": "OBJECT", "name": "TLS", "ofType": null }, "isDeprecated": false, "deprecationReason": null + }, + { + "name": "url", + "description": "", + "args": [], + "type": { "kind": "OBJECT", "name": "URL", "ofType": null }, + "isDeprecated": false, + "deprecationReason": null } ], "inputFields": null, @@ -1322,6 +1330,25 @@ "enumValues": null, "possibleTypes": null }, + { + "kind": "OBJECT", + "name": "URL", + "description": "", + "fields": [ + { + "name": "full", + "description": "", + "args": [], + "type": { "kind": "SCALAR", "name": "String", "ofType": null }, + "isDeprecated": false, + "deprecationReason": null + } + ], + "inputFields": null, + "interfaces": [], + "enumValues": null, + "possibleTypes": null + }, { "kind": "OBJECT", "name": "DocCount", diff --git a/x-pack/plugins/uptime/common/graphql/types.ts b/x-pack/plugins/uptime/common/graphql/types.ts index 988aedbc265e..7b4cc41392b9 100644 --- a/x-pack/plugins/uptime/common/graphql/types.ts +++ b/x-pack/plugins/uptime/common/graphql/types.ts @@ -70,6 +70,8 @@ export interface Ping { tcp?: Tcp | null; tls?: Tls | null; + + url?: Url | null; } /** An agent for recording a beat */ export interface Beat { @@ -258,6 +260,10 @@ export interface Tls { rtt?: Rtt | null; } +export interface Url { + full?: string | null; +} + export interface DocCount { count: UnsignedInteger; } diff --git a/x-pack/plugins/uptime/public/components/queries/filter_bar/filter_bar.tsx b/x-pack/plugins/uptime/public/components/queries/filter_bar/filter_bar.tsx index b83970e47cea..b9306428d0d5 100644 --- a/x-pack/plugins/uptime/public/components/queries/filter_bar/filter_bar.tsx +++ b/x-pack/plugins/uptime/public/components/queries/filter_bar/filter_bar.tsx @@ -67,8 +67,8 @@ export const FilterBar = ({ dateRangeEnd, dateRangeStart, updateQuery }: FilterB { type: 'field_value_selection', field: 'monitor.id', - name: i18n.translate('xpack.uptime.filterBar.options.hostLabel', { - defaultMessage: 'Host', + name: i18n.translate('xpack.uptime.filterBar.options.idLabel', { + defaultMessage: 'ID', }), multiSelect: false, options: take(id, MAX_SELECTION_LENGTH).map((idValue: any) => ({ diff --git a/x-pack/plugins/uptime/public/components/queries/monitor_list/get_monitor_list.ts b/x-pack/plugins/uptime/public/components/queries/monitor_list/get_monitor_list.ts index ed93ef8ef45a..41462fe7fb44 100644 --- a/x-pack/plugins/uptime/public/components/queries/monitor_list/get_monitor_list.ts +++ b/x-pack/plugins/uptime/public/components/queries/monitor_list/get_monitor_list.ts @@ -25,14 +25,16 @@ export const getMonitorListQuery = gql` ping { timestamp monitor { + id status - type - host ip duration { us } } + url { + full + } } upSeries { x diff --git a/x-pack/plugins/uptime/public/components/queries/monitor_list/monitor_list.tsx b/x-pack/plugins/uptime/public/components/queries/monitor_list/monitor_list.tsx index a612f342b3b5..a5e95a14d186 100644 --- a/x-pack/plugins/uptime/public/components/queries/monitor_list/monitor_list.tsx +++ b/x-pack/plugins/uptime/public/components/queries/monitor_list/monitor_list.tsx @@ -10,6 +10,7 @@ import { EuiInMemoryTable, // @ts-ignore missing type definition EuiLineSeries, + EuiLink, EuiPanel, // @ts-ignore missing type definition EuiSeriesChart, @@ -65,25 +66,22 @@ const monitorListColumns = [ sortable: true, }, { - field: 'ping.monitor.host', - name: i18n.translate('xpack.uptime.monitorList.hostColumnLabel', { - defaultMessage: 'Host', + field: 'ping.monitor.id', + name: i18n.translate('xpack.uptime.monitorList.idColumnLabel', { + defaultMessage: 'ID', }), - render: (host: string, monitor: any) => {host}, + render: (id: string, monitor: any) => {id}, }, { - field: 'key.port', - name: i18n.translate('xpack.uptime.monitorList.portColumnLabel', { - defaultMessage: 'Port', + field: 'ping.url.full', + name: i18n.translate('xpack.uptime.monitorList.urlColumnLabel', { + defaultMessage: 'URL', }), - sortable: true, - }, - { - field: 'ping.monitor.type', - name: i18n.translate('xpack.uptime.monitorList.typeColumnLabel', { - defaultMessage: 'Type', - }), - sortable: true, + render: (url: string, monitor: any) => ( + + {url} + + ), }, { field: 'ping.monitor.ip', diff --git a/x-pack/plugins/uptime/public/components/queries/monitor_status_bar/get_monitor_status_bar.ts b/x-pack/plugins/uptime/public/components/queries/monitor_status_bar/get_monitor_status_bar.ts index 12fd1a09985d..0eca6693ac84 100644 --- a/x-pack/plugins/uptime/public/components/queries/monitor_status_bar/get_monitor_status_bar.ts +++ b/x-pack/plugins/uptime/public/components/queries/monitor_status_bar/get_monitor_status_bar.ts @@ -25,10 +25,9 @@ export const createGetMonitorStatusBarQuery = gql` duration { us } - scheme } - tcp { - port + url { + full } } } diff --git a/x-pack/plugins/uptime/public/components/queries/monitor_status_bar/monitor_status_bar.tsx b/x-pack/plugins/uptime/public/components/queries/monitor_status_bar/monitor_status_bar.tsx index 5d3f766b7b90..53f9577306ad 100644 --- a/x-pack/plugins/uptime/public/components/queries/monitor_status_bar/monitor_status_bar.tsx +++ b/x-pack/plugins/uptime/public/components/queries/monitor_status_bar/monitor_status_bar.tsx @@ -4,7 +4,7 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EuiFlexGroup, EuiFlexItem, EuiHealth, EuiPanel } from '@elastic/eui'; +import { EuiFlexGroup, EuiFlexItem, EuiHealth, EuiLink, EuiPanel } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import { FormattedMessage } from '@kbn/i18n/react'; import moment from 'moment'; @@ -55,11 +55,10 @@ export const MonitorStatusBar = ({ monitor: { status, timestamp, - host, + ip, duration: { us }, - scheme, }, - tcp: { port }, + url: { full: fullURL }, } = monitorStatus[0]; return ( @@ -99,17 +98,16 @@ export const MonitorStatusBar = ({ /> - + + {fullURL} + @@ -120,13 +118,6 @@ export const MonitorStatusBar = ({ defaultMessage="Duration: {duration} ms" /> - - - ); diff --git a/x-pack/plugins/uptime/server/graphql/pings/schema.gql.ts b/x-pack/plugins/uptime/server/graphql/pings/schema.gql.ts index 33796c25e783..b0ca434da881 100644 --- a/x-pack/plugins/uptime/server/graphql/pings/schema.gql.ts +++ b/x-pack/plugins/uptime/server/graphql/pings/schema.gql.ts @@ -180,6 +180,15 @@ export const pingsSchema = gql` rtt: RTT } + type URL { + full: String + scheme: String + domain: String + port: Int + path: String + query: String + } + "A request sent from a monitor to a host" type Ping { "The timestamp of the ping's creation" @@ -199,5 +208,6 @@ export const pingsSchema = gql` tags: String tcp: TCP tls: TLS + url: URL } `; diff --git a/x-pack/plugins/uptime/server/lib/adapters/monitors/elasticsearch_monitors_adapter.ts b/x-pack/plugins/uptime/server/lib/adapters/monitors/elasticsearch_monitors_adapter.ts index 99b8f88f0f0f..b5d988d2c188 100644 --- a/x-pack/plugins/uptime/server/lib/adapters/monitors/elasticsearch_monitors_adapter.ts +++ b/x-pack/plugins/uptime/server/lib/adapters/monitors/elasticsearch_monitors_adapter.ts @@ -152,7 +152,7 @@ export class ElasticsearchMonitorsAdapter implements UMMonitorsAdapter { body: { query: getFilteredQuery(dateRangeStart, dateRangeEnd, filters), aggs: { - hosts: { + urls: { composite: { sources: [ { @@ -165,7 +165,7 @@ export class ElasticsearchMonitorsAdapter implements UMMonitorsAdapter { { port: { terms: { - field: 'tcp.port', + field: 'url.full', }, }, },