Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
132 changes: 70 additions & 62 deletions web/console-extensions.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,11 +7,7 @@
"href": "/monitoring/alerts",
"perspective": "admin",
"section": "observe",
"startsWith": [
"monitoring/alertrules",
"monitoring/silences",
"monitoring/incidents"
]
"startsWith": ["monitoring/alertrules", "monitoring/silences", "monitoring/incidents"]
}
},
{
Expand All @@ -20,10 +16,7 @@
"data-quickstart-id": "qs-nav-monitoring"
},
"id": "observe-virt-perspective",
"insertBefore": [
"compute-virt-perspective",
"usermanagement-virt-perspective"
],
"insertBefore": ["compute-virt-perspective", "usermanagement-virt-perspective"],
"name": "%console-app~Observe%",
"perspective": "virtualization-perspective"
},
Expand Down Expand Up @@ -163,10 +156,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/monitoring/targets",
"/monitoring/targets/:scrapeUrl"
],
"path": ["/monitoring/targets", "/monitoring/targets/:scrapeUrl"],
"component": {
"$codeRef": "TargetsPage.MpCmoTargetsPage"
}
Expand All @@ -176,9 +166,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/monitoring/query-browser"
],
"path": ["/monitoring/query-browser"],
"component": {
"$codeRef": "MetricsPage.MpCmoMetricsPage"
}
Expand All @@ -188,9 +176,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/monitoring/graph"
],
"path": ["/monitoring/graph"],
"component": {
"$codeRef": "PrometheusRedirectPage"
}
Expand All @@ -200,10 +186,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/monitoring/dashboards",
"/monitoring/dashboards/:dashboardName"
],
"path": ["/monitoring/dashboards", "/monitoring/dashboards/:dashboardName"],
"component": {
"$codeRef": "LegacyDashboardsPage.MpCmoLegacyDashboardsPage"
}
Expand All @@ -213,9 +196,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/monitoring/alertrules/:id"
],
"path": ["/monitoring/alertrules/:id"],
"component": {
"$codeRef": "AlertRulesDetailsPage.MpCmoAlertRulesDetailsPage"
}
Expand All @@ -225,9 +206,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/monitoring/alerts/:ruleID"
],
"path": ["/monitoring/alerts/:ruleID"],
"component": {
"$codeRef": "AlertsDetailsPage.MpCmoAlertsDetailsPage"
}
Expand All @@ -237,9 +216,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/virt-monitoring"
],
"path": ["/virt-monitoring"],
"component": {
"$codeRef": "AlertingPage.MpCmoAlertingPage"
}
Expand Down Expand Up @@ -279,10 +256,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/virt-monitoring/targets",
"/virt-monitoring/targets/:scrapeUrl"
],
"path": ["/virt-monitoring/targets", "/virt-monitoring/targets/:scrapeUrl"],
"component": {
"$codeRef": "TargetsPage.MpCmoTargetsPage"
}
Expand All @@ -292,9 +266,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/virt-monitoring/query-browser"
],
"path": ["/virt-monitoring/query-browser"],
"component": {
"$codeRef": "MetricsPage.MpCmoMetricsPage"
}
Expand All @@ -304,9 +276,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/virt-monitoring/graph"
],
"path": ["/virt-monitoring/graph"],
"component": {
"$codeRef": "PrometheusRedirectPage"
}
Expand All @@ -316,10 +286,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/virt-monitoring/dashboards",
"/virt-monitoring/dashboards/:dashboardName"
],
"path": ["/virt-monitoring/dashboards", "/virt-monitoring/dashboards/:dashboardName"],
"component": {
"$codeRef": "LegacyDashboardsPage.MpCmoLegacyDashboardsPage"
}
Expand All @@ -329,9 +296,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/virt-monitoring/alertrules/:id"
],
"path": ["/virt-monitoring/alertrules/:id"],
"component": {
"$codeRef": "AlertRulesDetailsPage.MpCmoAlertRulesDetailsPage"
}
Expand All @@ -341,9 +306,7 @@
"type": "console.page/route",
"properties": {
"exact": false,
"path": [
"/virt-monitoring/alerts/:ruleID"
],
"path": ["/virt-monitoring/alerts/:ruleID"],
"component": {
"$codeRef": "AlertsDetailsPage.MpCmoAlertsDetailsPage"
}
Expand All @@ -355,7 +318,7 @@
"exact": false,
"path": "/dev-monitoring/ns/:ns/alerts/:ruleID",
"component": {
"$codeRef": "DevRedirects.AlertRedirect"
"$codeRef": "AlertsDetailsPage.MpCmoAlertsDetailsPage"
}
}
},
Expand All @@ -365,7 +328,7 @@
"exact": false,
"path": "/dev-monitoring/ns/:ns/rules/:id",
"component": {
"$codeRef": "DevRedirects.RulesRedirect"
"$codeRef": "AlertRulesDetailsPage.MpCmoAlertRulesDetailsPage"
}
}
},
Expand All @@ -375,7 +338,7 @@
"exact": false,
"path": "/dev-monitoring/ns/:ns/silences/:id",
"component": {
"$codeRef": "DevRedirects.SilenceRedirect"
"$codeRef": "SilencesDetailsPage.MpCmoSilencesDetailsPage"
}
}
},
Expand All @@ -385,7 +348,7 @@
"exact": false,
"path": "/dev-monitoring/ns/:ns/silences/:id/edit",
"component": {
"$codeRef": "DevRedirects.SilenceEditRedirect"
"$codeRef": "SilenceEditPage.MpCmoSilenceEditPage"
}
}
},
Expand All @@ -395,18 +358,63 @@
"exact": false,
"path": "/dev-monitoring/ns/:ns/silences/~new",
"component": {
"$codeRef": "DevRedirects.SilenceNewRedirect"
"$codeRef": "SilenceCreatePage.MpCmoCreateSilencePage"
}
}
},
{
"type": "console.page/route",
"type": "console.tab",
"properties": {
"exact": false,
"path": "/dev-monitoring/ns/:ns/metrics",
"contextId": "dev-console-observe",
"name": "%plugin__monitoring-plugin~Silences%",
"href": "silences",
"component": {
"$codeRef": "SilencesPage.MpCmoSilencesPage"
}
}
},
{
"type": "console.tab",
"properties": {
"contextId": "dev-console-observe",
"name": "%plugin__monitoring-plugin~Metrics%",
"href": "metrics",
"component": {
"$codeRef": "MetricsPage.MpCmoDevMetricsPage"
}
}
},
{
"type": "console.tab",
"properties": {
"contextId": "dev-console-observe",
"name": "%plugin__monitoring-plugin~Alerts%",
"href": "alerts",
"component": {
"$codeRef": "AlertsPage.MpCmoAlertsPage"
}
}
},
{
"type": "console.tab",
"properties": {
"contextId": "dev-console-observe",
"name": "%plugin__monitoring-plugin~Alerting rules%",
"href": "alertrules",
"component": {
"$codeRef": "AlertRulesPage.MpCmoAlertRulesPage"
}
}
},
{
"type": "console.tab",
"properties": {
"contextId": "dev-console-observe",
"name": "%plugin__monitoring-plugin~Dashboards%",
"href": "",
"component": {
"$codeRef": "DevRedirects.MetricsRedirect"
"$codeRef": "LegacyDashboardsPage.MpCmoLegacyDevDashboardsPage"
}
}
}
]
]
1 change: 0 additions & 1 deletion web/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -182,7 +182,6 @@
"IncidentsPage": "./components/Incidents/IncidentsPage",
"TargetsPage": "./components/targets-page",
"PrometheusRedirectPage": "./components/redirects/prometheus-redirect-page",
"DevRedirects": "./components/redirects/dev-redirects",
"MonitoringContext": "./contexts/MonitoringContext"
},
"dependencies": {
Expand Down
2 changes: 1 addition & 1 deletion web/src/components/Incidents/IncidentsDetailsRowTable.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { Table, Thead, Tr, Th, Tbody, Td } from '@patternfly/react-table';
import { ResourceIcon, Timestamp, useActiveNamespace } from '@openshift-console/dynamic-plugin-sdk';
import { Bullseye, Spinner } from '@patternfly/react-core';
import { Link } from 'react-router-dom';
import { Link } from 'react-router-dom-v5-compat';
import { ALL_NAMESPACES_KEY, RuleResource } from '../utils';
import { useTranslation } from 'react-i18next';
import { getRuleUrl, usePerspective } from '../hooks/usePerspective';
Expand Down
2 changes: 1 addition & 1 deletion web/src/components/Incidents/IncidentsPage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ import {
setIncidentsActiveFilters,
setIncidentsLastRefreshTime,
} from '../../store/actions';
import { useLocation } from 'react-router-dom';
import { useLocation } from 'react-router-dom-v5-compat';
import { changeDaysFilter } from './utils';
import { parsePrometheusDuration } from '../console/console-shared/src/datetime/prometheus';
import withFallback from '../console/console-shared/error/fallbacks/withFallback';
Expand Down
5 changes: 4 additions & 1 deletion web/src/components/Incidents/api.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,9 @@ import {
import { getPrometheusBasePath, buildPrometheusUrl } from '../utils';
import { PROMETHEUS_QUERY_INTERVAL_SECONDS } from './utils';

// Disable client-side timeout (-1) to let the backend control query timeouts
const NO_TIMEOUT = -1;

const MAX_URL_LENGTH = 2048;

/**
Expand Down Expand Up @@ -136,7 +139,7 @@ export const fetchDataForIncidentsAndAlerts = async (
} as PrometheusResponse);
}

return consoleFetchJSON(url);
return consoleFetchJSON(url, 'GET', {}, NO_TIMEOUT);
});

const responses = await Promise.all(promises);
Expand Down
39 changes: 29 additions & 10 deletions web/src/components/MetricsPage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,7 @@ import { ALL_NAMESPACES_KEY } from './utils';
import { MonitoringProvider } from '../contexts/MonitoringContext';
import { DataTestIDs } from './data-test';
import { useMonitoring } from '../hooks/useMonitoring';
import { useQueryNamespace } from './hooks/useQueryNamespace';
import { useMonitoringNamespace } from './hooks/useMonitoringNamespace';

// Stores information about the currently focused query input
let focusedQuery;
Expand Down Expand Up @@ -1323,7 +1323,8 @@ const GraphUnitsDropDown: FC = () => {
const MetricsPage_: FC = () => {
const { t } = useTranslation(process.env.I18N_NAMESPACE);
const [units, setUnits] = useQueryParam(QueryParams.Units, StringParam);
const { setNamespace } = useQueryNamespace();
const { setNamespace } = useMonitoringNamespace();
const { displayNamespaceSelector } = useMonitoring();

const dispatch = useDispatch();

Expand Down Expand Up @@ -1402,14 +1403,18 @@ const MetricsPage_: FC = () => {

return (
<>
<DocumentTitle>{t('Metrics')}</DocumentTitle>
<NamespaceBar
onNamespaceChange={(namespace) => {
dispatch(queryBrowserDeleteAllQueries());
setNamespace(namespace);
}}
/>
<ListPageHeader title={t('Metrics')}>
{displayNamespaceSelector && (
<>
<DocumentTitle>{t('Metrics')}</DocumentTitle>
<NamespaceBar
onNamespaceChange={(namespace) => {
dispatch(queryBrowserDeleteAllQueries());
setNamespace(namespace);
}}
/>
</>
)}
<ListPageHeader title={displayNamespaceSelector ? t('Metrics') : ' '}>
<Split hasGutter>
<SplitItem data-test={DataTestIDs.MetricGraphUnitsDropDown}>
<Tooltip content={<>{t('This dropdown only formats results.')}</>}>
Expand Down Expand Up @@ -1470,6 +1475,20 @@ export const MpCmoMetricsPage: React.FC = () => {
);
};

export const MpCmoDevMetricsPage: React.FC = () => {
return (
<MonitoringProvider
monitoringContext={{
plugin: 'monitoring-plugin',
prometheus: 'cmo',
displayNamespaceSelector: false,
}}
>
<MetricsPage />
</MonitoringProvider>
);
};

type QueryTableProps = {
index: number;
namespace?: string;
Expand Down
Loading