@pagerduty/backstage-plugin 0.18.0 → 0.19.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +11 -0
- package/dist/alpha/api.esm.js.map +1 -1
- package/dist/api/client.esm.js +91 -2
- package/dist/api/client.esm.js.map +1 -1
- package/dist/components/PagerDutyPage/AccountContext.esm.js +56 -0
- package/dist/components/PagerDutyPage/AccountContext.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/AutomaticMappingsDialog.esm.js +197 -0
- package/dist/components/PagerDutyPage/AutomaticMappingsDialog.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/MappingsDialog.esm.js +242 -0
- package/dist/components/PagerDutyPage/MappingsDialog.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/MappingsTable/AutoMappingsButton.esm.js +74 -0
- package/dist/components/PagerDutyPage/MappingsTable/AutoMappingsButton.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/MappingsTable/EmptyTableState.esm.js +26 -0
- package/dist/components/PagerDutyPage/MappingsTable/EmptyTableState.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/MappingsTable/FilterRow.esm.js +67 -0
- package/dist/components/PagerDutyPage/MappingsTable/FilterRow.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/MappingsTable/MappingToast.esm.js +69 -0
- package/dist/components/PagerDutyPage/MappingsTable/MappingToast.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/MappingsTable/MappingsTable.esm.js +202 -0
- package/dist/components/PagerDutyPage/MappingsTable/MappingsTable.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/MappingsTable/MappingsTableContent.esm.js +231 -0
- package/dist/components/PagerDutyPage/MappingsTable/MappingsTableContent.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/MappingsTable/ServiceCell.esm.js +31 -0
- package/dist/components/PagerDutyPage/MappingsTable/ServiceCell.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/MappingsTable/StatusCell.esm.js +112 -0
- package/dist/components/PagerDutyPage/MappingsTable/StatusCell.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/MappingsTable/TableSkeleton.esm.js +50 -0
- package/dist/components/PagerDutyPage/MappingsTable/TableSkeleton.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/MappingsTable/hooks/useConfirmMappings.esm.js +70 -0
- package/dist/components/PagerDutyPage/MappingsTable/hooks/useConfirmMappings.esm.js.map +1 -0
- package/dist/components/PagerDutyPage/ServiceMappingComponent.esm.js +67 -44
- package/dist/components/PagerDutyPage/ServiceMappingComponent.esm.js.map +1 -1
- package/dist/components/PagerDutyPage/index.esm.js +27 -12
- package/dist/components/PagerDutyPage/index.esm.js.map +1 -1
- package/dist/components/TriggerButton/index.esm.js +1 -1
- package/dist/components/TriggerButton/index.esm.js.map +1 -1
- package/dist/hooks/useDebounce.esm.js +13 -0
- package/dist/hooks/useDebounce.esm.js.map +1 -0
- package/dist/hooks/{index.esm.js → usePagerDutyEntity.esm.js} +1 -1
- package/dist/hooks/usePagerDutyEntity.esm.js.map +1 -0
- package/dist/index.d.ts +96 -4
- package/dist/package.json.esm.js +1 -1
- package/package.json +13 -13
- package/dist/components/PagerDutyPage/MappingTable.esm.js +0 -282
- package/dist/components/PagerDutyPage/MappingTable.esm.js.map +0 -1
- package/dist/hooks/index.esm.js.map +0 -1
package/dist/index.d.ts
CHANGED
|
@@ -5,7 +5,8 @@ import * as _backstage_core_plugin_api from '@backstage/core-plugin-api';
|
|
|
5
5
|
import { DiscoveryApi, FetchApi, ConfigApi } from '@backstage/core-plugin-api';
|
|
6
6
|
import { ReactNode } from 'react';
|
|
7
7
|
import * as _backstage_frontend_plugin_api from '@backstage/frontend-plugin-api';
|
|
8
|
-
import { PagerDutySetting,
|
|
8
|
+
import { PagerDutySetting, PagerDutyEnhancedEntityMappingsResponse, PagerDutyServiceResponse, PagerDutyIncidentsResponse, PagerDutyChangeEventsResponse, PagerDutyService, PagerDutyTeam, PagerDutyServiceStandardsResponse, PagerDutyServiceMetricsResponse, PagerDutyUser, AutoMatchEntityMappingsResponse } from '@pagerduty/backstage-plugin-common';
|
|
9
|
+
export { AutoMatchBackstageComponent, AutoMatchEntityMapping, AutoMatchEntityMappingsResponse, AutoMatchPagerDutyService, AutoMatchScoreBreakdown, AutoMatchStatistics } from '@pagerduty/backstage-plugin-common';
|
|
9
10
|
|
|
10
11
|
/** @public */
|
|
11
12
|
declare const isPluginApplicableToEntity$1: (entity: Entity) => boolean;
|
|
@@ -78,10 +79,24 @@ interface PagerDutyApi {
|
|
|
78
79
|
*/
|
|
79
80
|
storeSettings(settings: PagerDutySetting[]): Promise<Response>;
|
|
80
81
|
/**
|
|
81
|
-
* Fetches
|
|
82
|
+
* Fetches entity mappings with pagination and search support.
|
|
82
83
|
*
|
|
83
84
|
*/
|
|
84
|
-
|
|
85
|
+
getEntityMappingsWithPagination(options: {
|
|
86
|
+
offset: number;
|
|
87
|
+
limit: number;
|
|
88
|
+
filters?: {
|
|
89
|
+
name?: string;
|
|
90
|
+
serviceName?: string;
|
|
91
|
+
status?: string;
|
|
92
|
+
teamName?: string;
|
|
93
|
+
};
|
|
94
|
+
sort?: {
|
|
95
|
+
column: string;
|
|
96
|
+
direction: 'ascending' | 'descending';
|
|
97
|
+
};
|
|
98
|
+
account?: string;
|
|
99
|
+
}): Promise<PagerDutyEnhancedEntityMappingsResponse>;
|
|
85
100
|
/**
|
|
86
101
|
* Stores the service mapping in the database.
|
|
87
102
|
*
|
|
@@ -105,6 +120,16 @@ interface PagerDutyApi {
|
|
|
105
120
|
*
|
|
106
121
|
*/
|
|
107
122
|
removeServiceMapping(entityRef: string): Promise<boolean>;
|
|
123
|
+
/**
|
|
124
|
+
* Stores multiple service mappings in the database.
|
|
125
|
+
*
|
|
126
|
+
*/
|
|
127
|
+
storeBulkServiceMappings(mappings: Array<{
|
|
128
|
+
serviceId: string;
|
|
129
|
+
integrationKey: string;
|
|
130
|
+
entityRef: string;
|
|
131
|
+
account: string;
|
|
132
|
+
}>): Promise<Response>;
|
|
108
133
|
/**
|
|
109
134
|
* Fetches the service for the provided pager duty Entity.
|
|
110
135
|
*
|
|
@@ -130,6 +155,26 @@ interface PagerDutyApi {
|
|
|
130
155
|
*
|
|
131
156
|
*/
|
|
132
157
|
getChangeEventsByServiceId(serviceId: string, account?: string): Promise<PagerDutyChangeEventsResponse>;
|
|
158
|
+
/**
|
|
159
|
+
* Fetches a list of PagerDuty services.
|
|
160
|
+
*
|
|
161
|
+
*/
|
|
162
|
+
getAllServices(): Promise<PagerDutyService[]>;
|
|
163
|
+
/**
|
|
164
|
+
* Fetches a list of PagerDuty teams.
|
|
165
|
+
*
|
|
166
|
+
* @param account - The account ID to filter teams by
|
|
167
|
+
*/
|
|
168
|
+
getAllTeams(account?: string): Promise<PagerDutyTeam[]>;
|
|
169
|
+
/**
|
|
170
|
+
* Fetches a filtered list of PagerDuty services.
|
|
171
|
+
*
|
|
172
|
+
* @param teamIds - Optional array of team IDs to filter by
|
|
173
|
+
* @param query - Optional search query for service name or ID
|
|
174
|
+
* @param limit - Optional maximum number of results (default: 100)
|
|
175
|
+
* @param account - The account ID to filter services by
|
|
176
|
+
*/
|
|
177
|
+
getFilteredServices(teamIds?: string[], query?: string, limit?: number, account?: string): Promise<PagerDutyService[]>;
|
|
133
178
|
/**
|
|
134
179
|
* Fetches a list of standards for a provided service.
|
|
135
180
|
*
|
|
@@ -149,6 +194,21 @@ interface PagerDutyApi {
|
|
|
149
194
|
* Triggers an incident to whoever is on-call.
|
|
150
195
|
*/
|
|
151
196
|
triggerAlarm(request: PagerDutyTriggerAlarmRequest): Promise<Response>;
|
|
197
|
+
/**
|
|
198
|
+
* Automatically matches unmapped entities to PagerDuty services.
|
|
199
|
+
*/
|
|
200
|
+
autoMatchEntityMappings(options: {
|
|
201
|
+
team?: string;
|
|
202
|
+
threshold: number;
|
|
203
|
+
account?: string;
|
|
204
|
+
}): Promise<AutoMatchEntityMappingsResponse>;
|
|
205
|
+
/**
|
|
206
|
+
* Fetches the list of configured PagerDuty accounts.
|
|
207
|
+
*/
|
|
208
|
+
getAccounts(): Promise<Array<{
|
|
209
|
+
id: string;
|
|
210
|
+
isDefault: boolean;
|
|
211
|
+
}>>;
|
|
152
212
|
}
|
|
153
213
|
/** @public */
|
|
154
214
|
type PagerDutyClientApiDependencies = {
|
|
@@ -173,7 +233,24 @@ declare class PagerDutyClient implements PagerDutyApi {
|
|
|
173
233
|
getServiceByPagerDutyEntity(pagerDutyEntity: PagerDutyEntity): Promise<PagerDutyServiceResponse>;
|
|
174
234
|
getSetting(id: string): Promise<PagerDutySetting>;
|
|
175
235
|
storeSettings(settings: PagerDutySetting[]): Promise<Response>;
|
|
176
|
-
|
|
236
|
+
getEntityMappingsWithPagination(options: {
|
|
237
|
+
offset: number;
|
|
238
|
+
limit: number;
|
|
239
|
+
filters?: {
|
|
240
|
+
name?: string;
|
|
241
|
+
serviceName?: string;
|
|
242
|
+
status?: string;
|
|
243
|
+
teamName?: string;
|
|
244
|
+
};
|
|
245
|
+
sort?: {
|
|
246
|
+
column: string;
|
|
247
|
+
direction: 'ascending' | 'descending';
|
|
248
|
+
};
|
|
249
|
+
account?: string;
|
|
250
|
+
}): Promise<PagerDutyEnhancedEntityMappingsResponse>;
|
|
251
|
+
getAllServices(): Promise<PagerDutyService[]>;
|
|
252
|
+
getAllTeams(account?: string): Promise<PagerDutyTeam[]>;
|
|
253
|
+
getFilteredServices(teamIds?: string[], query?: string, limit?: number, account?: string): Promise<PagerDutyService[]>;
|
|
177
254
|
storeServiceMapping(serviceId: string, integrationKey: string, backstageEntityRef: string, account: string): Promise<Response>;
|
|
178
255
|
getEntityMapping(entityRef: string): Promise<{
|
|
179
256
|
mapping: {
|
|
@@ -183,6 +260,12 @@ declare class PagerDutyClient implements PagerDutyApi {
|
|
|
183
260
|
account: string;
|
|
184
261
|
};
|
|
185
262
|
}>;
|
|
263
|
+
storeBulkServiceMappings(mappings: Array<{
|
|
264
|
+
serviceId: string;
|
|
265
|
+
integrationKey: string;
|
|
266
|
+
entityRef: string;
|
|
267
|
+
account: string;
|
|
268
|
+
}>): Promise<Response>;
|
|
186
269
|
removeServiceMapping(entityRef: string): Promise<boolean>;
|
|
187
270
|
getServiceByEntity(entity: Entity): Promise<PagerDutyServiceResponse>;
|
|
188
271
|
getServiceById(serviceId: string, account?: string): Promise<PagerDutyServiceResponse>;
|
|
@@ -192,6 +275,15 @@ declare class PagerDutyClient implements PagerDutyApi {
|
|
|
192
275
|
getServiceMetricsByServiceId(serviceId: string, account?: string): Promise<PagerDutyServiceMetricsResponse>;
|
|
193
276
|
getOnCallByPolicyId(policyId: string, account?: string): Promise<PagerDutyUser[]>;
|
|
194
277
|
triggerAlarm(request: PagerDutyTriggerAlarmRequest): Promise<Response>;
|
|
278
|
+
autoMatchEntityMappings(options: {
|
|
279
|
+
team?: string;
|
|
280
|
+
threshold: number;
|
|
281
|
+
account?: string;
|
|
282
|
+
}): Promise<AutoMatchEntityMappingsResponse>;
|
|
283
|
+
getAccounts(): Promise<Array<{
|
|
284
|
+
id: string;
|
|
285
|
+
isDefault: boolean;
|
|
286
|
+
}>>;
|
|
195
287
|
private findByUrl;
|
|
196
288
|
private request;
|
|
197
289
|
}
|
package/dist/package.json.esm.js
CHANGED
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@pagerduty/backstage-plugin",
|
|
3
3
|
"description": "A Backstage plugin that integrates towards PagerDuty",
|
|
4
|
-
"version": "0.
|
|
4
|
+
"version": "0.19.0",
|
|
5
5
|
"main": "./dist/index.esm.js",
|
|
6
6
|
"types": "./dist/index.d.ts",
|
|
7
7
|
"license": "Apache-2.0",
|
|
@@ -44,16 +44,16 @@
|
|
|
44
44
|
},
|
|
45
45
|
"dependencies": {
|
|
46
46
|
"@backstage/catalog-model": "^1.7.6",
|
|
47
|
-
"@backstage/core-compat-api": "^0.5.
|
|
48
|
-
"@backstage/core-components": "^0.18.
|
|
49
|
-
"@backstage/core-plugin-api": "^1.12.
|
|
47
|
+
"@backstage/core-compat-api": "^0.5.7",
|
|
48
|
+
"@backstage/core-components": "^0.18.6",
|
|
49
|
+
"@backstage/core-plugin-api": "^1.12.2",
|
|
50
50
|
"@backstage/errors": "^1.2.7",
|
|
51
|
-
"@backstage/frontend-plugin-api": "^0.13.
|
|
52
|
-
"@backstage/plugin-catalog": "^1.32.
|
|
53
|
-
"@backstage/plugin-catalog-react": "^1.21.
|
|
54
|
-
"@backstage/plugin-home-react": "^0.1.
|
|
51
|
+
"@backstage/frontend-plugin-api": "^0.13.4",
|
|
52
|
+
"@backstage/plugin-catalog": "^1.32.2",
|
|
53
|
+
"@backstage/plugin-catalog-react": "^1.21.6",
|
|
54
|
+
"@backstage/plugin-home-react": "^0.1.34",
|
|
55
55
|
"@backstage/theme": "^0.7.1",
|
|
56
|
-
"@backstage/ui": "^0.
|
|
56
|
+
"@backstage/ui": "^0.11.2",
|
|
57
57
|
"@emotion/react": "^11.11.4",
|
|
58
58
|
"@emotion/styled": "^11.11.5",
|
|
59
59
|
"@material-ui/core": "^4.12.2",
|
|
@@ -62,7 +62,7 @@
|
|
|
62
62
|
"@mui/icons-material": "^5.15.19",
|
|
63
63
|
"@mui/material": "^5.15.19",
|
|
64
64
|
"@mui/x-date-pickers": "^7.6.1",
|
|
65
|
-
"@pagerduty/backstage-plugin-common": "~0.
|
|
65
|
+
"@pagerduty/backstage-plugin-common": "~0.3.0",
|
|
66
66
|
"@tanstack/react-query": "^5.40.1",
|
|
67
67
|
"luxon": "^3.4.1",
|
|
68
68
|
"material-react-table": "^2.13.0",
|
|
@@ -75,9 +75,9 @@
|
|
|
75
75
|
"react-router-dom": "^6.3.0"
|
|
76
76
|
},
|
|
77
77
|
"devDependencies": {
|
|
78
|
-
"@backstage/cli": "^0.35.
|
|
79
|
-
"@backstage/core-app-api": "^1.19.
|
|
80
|
-
"@backstage/frontend-defaults": "^0.3.
|
|
78
|
+
"@backstage/cli": "^0.35.3",
|
|
79
|
+
"@backstage/core-app-api": "^1.19.4",
|
|
80
|
+
"@backstage/frontend-defaults": "^0.3.6",
|
|
81
81
|
"@backstage/test-utils": "^1.7.14",
|
|
82
82
|
"@testing-library/jest-dom": "^6.6.3",
|
|
83
83
|
"@types/copyfiles": "^2",
|
|
@@ -1,282 +0,0 @@
|
|
|
1
|
-
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
2
|
-
import { useState, useEffect, useMemo } from 'react';
|
|
3
|
-
import { useMaterialReactTable, MRT_EditActionButtons, MaterialReactTable } from 'material-react-table';
|
|
4
|
-
import { Typography, Box, DialogTitle, DialogContent, DialogActions } from '@material-ui/core';
|
|
5
|
-
import { Flex, TooltipTrigger, ButtonIcon, Tooltip } from '@backstage/ui';
|
|
6
|
-
import { QueryClient, QueryClientProvider, useMutation } from '@tanstack/react-query';
|
|
7
|
-
import { Edit, OpenInBrowser } from '@mui/icons-material';
|
|
8
|
-
import { useApi } from '@backstage/core-plugin-api';
|
|
9
|
-
import { pagerDutyApiRef } from '../../api/client.esm.js';
|
|
10
|
-
|
|
11
|
-
function getColorFromStatus(status) {
|
|
12
|
-
switch (status) {
|
|
13
|
-
case "InSync":
|
|
14
|
-
return "green";
|
|
15
|
-
case "OutOfSync":
|
|
16
|
-
return "red";
|
|
17
|
-
case "NotMapped":
|
|
18
|
-
return "orange";
|
|
19
|
-
default:
|
|
20
|
-
return "gray";
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
function makeReadable(status) {
|
|
24
|
-
switch (status) {
|
|
25
|
-
case "InSync":
|
|
26
|
-
return "In Sync";
|
|
27
|
-
case "OutOfSync":
|
|
28
|
-
return "Out of Sync";
|
|
29
|
-
case "NotMapped":
|
|
30
|
-
return "Not Mapped";
|
|
31
|
-
default:
|
|
32
|
-
return "Refresh to Update";
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
const MappingTable = ({
|
|
36
|
-
mappings,
|
|
37
|
-
catalogEntities
|
|
38
|
-
}) => {
|
|
39
|
-
const DenseTable = () => {
|
|
40
|
-
const [validationErrors, setValidationErrors] = useState({});
|
|
41
|
-
const [entityOptions, setEntityOptions] = useState(
|
|
42
|
-
[]
|
|
43
|
-
);
|
|
44
|
-
const pagerDutyApi = useApi(pagerDutyApiRef);
|
|
45
|
-
useEffect(() => {
|
|
46
|
-
getEntityOptions();
|
|
47
|
-
}, []);
|
|
48
|
-
const columns = useMemo(
|
|
49
|
-
() => [
|
|
50
|
-
{
|
|
51
|
-
id: "serviceId",
|
|
52
|
-
accessorKey: "serviceId",
|
|
53
|
-
header: "Service ID",
|
|
54
|
-
visibleInShowHideMenu: false,
|
|
55
|
-
enableEditing: false,
|
|
56
|
-
Edit: () => null,
|
|
57
|
-
Cell: ({ cell }) => /* @__PURE__ */ jsx(Typography, { variant: "body1", style: { fontWeight: 600 }, children: cell.getValue() })
|
|
58
|
-
},
|
|
59
|
-
{
|
|
60
|
-
id: "integrationKey",
|
|
61
|
-
accessorKey: "integrationKey",
|
|
62
|
-
header: "Integration Key",
|
|
63
|
-
visibleInShowHideMenu: false,
|
|
64
|
-
enableEditing: false,
|
|
65
|
-
Edit: () => null
|
|
66
|
-
},
|
|
67
|
-
{
|
|
68
|
-
id: "serviceName",
|
|
69
|
-
accessorKey: "serviceName",
|
|
70
|
-
header: "PagerDuty Service",
|
|
71
|
-
enableEditing: false
|
|
72
|
-
},
|
|
73
|
-
{
|
|
74
|
-
id: "account",
|
|
75
|
-
accessorKey: "account",
|
|
76
|
-
header: "Account",
|
|
77
|
-
enableEditing: false,
|
|
78
|
-
Edit: () => null
|
|
79
|
-
},
|
|
80
|
-
{
|
|
81
|
-
id: "team",
|
|
82
|
-
accessorKey: "team",
|
|
83
|
-
header: "Team",
|
|
84
|
-
enableEditing: false
|
|
85
|
-
},
|
|
86
|
-
{
|
|
87
|
-
id: "escalationPolicy",
|
|
88
|
-
accessorKey: "escalationPolicy",
|
|
89
|
-
header: "Escalation Policy",
|
|
90
|
-
enableEditing: false
|
|
91
|
-
},
|
|
92
|
-
{
|
|
93
|
-
id: "entityRef",
|
|
94
|
-
accessorKey: "entityRef",
|
|
95
|
-
header: "Mapping",
|
|
96
|
-
visibleInShowHideMenu: false,
|
|
97
|
-
editVariant: "select",
|
|
98
|
-
editSelectOptions: entityOptions,
|
|
99
|
-
muiEditTextFieldProps: {
|
|
100
|
-
select: true,
|
|
101
|
-
error: !!validationErrors?.state,
|
|
102
|
-
helperText: validationErrors?.state,
|
|
103
|
-
multiline: true,
|
|
104
|
-
type: "range"
|
|
105
|
-
}
|
|
106
|
-
},
|
|
107
|
-
{
|
|
108
|
-
id: "entityName",
|
|
109
|
-
accessorKey: "entityName",
|
|
110
|
-
header: "Mapped Entity Name",
|
|
111
|
-
enableEditing: false,
|
|
112
|
-
Edit: () => null
|
|
113
|
-
},
|
|
114
|
-
{
|
|
115
|
-
id: "status",
|
|
116
|
-
accessorKey: "status",
|
|
117
|
-
header: "Status",
|
|
118
|
-
enableEditing: false,
|
|
119
|
-
Edit: () => null,
|
|
120
|
-
Cell: ({ cell }) => /* @__PURE__ */ jsx(
|
|
121
|
-
Box,
|
|
122
|
-
{
|
|
123
|
-
component: "span",
|
|
124
|
-
bgcolor: getColorFromStatus(cell.getValue()),
|
|
125
|
-
borderRadius: "0.25rem",
|
|
126
|
-
color: "white",
|
|
127
|
-
p: "0.25rem",
|
|
128
|
-
children: makeReadable(cell.getValue())
|
|
129
|
-
}
|
|
130
|
-
)
|
|
131
|
-
},
|
|
132
|
-
{
|
|
133
|
-
id: "serviceUrl",
|
|
134
|
-
accessorKey: "serviceUrl",
|
|
135
|
-
header: "Service URL",
|
|
136
|
-
visibleInShowHideMenu: false,
|
|
137
|
-
enableEditing: false,
|
|
138
|
-
Edit: () => null
|
|
139
|
-
}
|
|
140
|
-
],
|
|
141
|
-
[validationErrors, entityOptions]
|
|
142
|
-
);
|
|
143
|
-
function useUpdateMapping() {
|
|
144
|
-
return useMutation({
|
|
145
|
-
mutationFn: async (mapping) => {
|
|
146
|
-
return await pagerDutyApi.storeServiceMapping(
|
|
147
|
-
mapping.serviceId,
|
|
148
|
-
mapping.integrationKey ?? "",
|
|
149
|
-
mapping.entityRef,
|
|
150
|
-
mapping.account ?? ""
|
|
151
|
-
);
|
|
152
|
-
}
|
|
153
|
-
});
|
|
154
|
-
}
|
|
155
|
-
const { mutateAsync: updateMapping, isPending: isUpdatingMapping } = useUpdateMapping();
|
|
156
|
-
const handleSaveMapping = async ({ values, table }) => {
|
|
157
|
-
setValidationErrors({});
|
|
158
|
-
values.entityName = catalogEntities.find(
|
|
159
|
-
(entity) => `${entity.type}:${entity.namespace}/${entity.name}`.toLowerCase() === values.entityRef
|
|
160
|
-
)?.name ?? "";
|
|
161
|
-
values.status = "RefreshToUpdate";
|
|
162
|
-
await updateMapping(values);
|
|
163
|
-
const existingMapping = mappings.find(
|
|
164
|
-
(item) => item.serviceId === values.serviceId
|
|
165
|
-
);
|
|
166
|
-
if (existingMapping) {
|
|
167
|
-
existingMapping.entityRef = values.entityRef;
|
|
168
|
-
existingMapping.entityName = values.entityName;
|
|
169
|
-
}
|
|
170
|
-
table.setEditingRow(null);
|
|
171
|
-
};
|
|
172
|
-
const openInBrowser = (url) => {
|
|
173
|
-
window.open(url, "_blank", "noreferrer");
|
|
174
|
-
};
|
|
175
|
-
const dataTable = useMaterialReactTable({
|
|
176
|
-
columns,
|
|
177
|
-
data: mappings,
|
|
178
|
-
editDisplayMode: "modal",
|
|
179
|
-
enableEditing: true,
|
|
180
|
-
positionActionsColumn: "last",
|
|
181
|
-
enableStickyHeader: true,
|
|
182
|
-
enableFilters: true,
|
|
183
|
-
getRowId: (row) => row.serviceId,
|
|
184
|
-
muiToolbarAlertBannerProps: mappings === void 0 ? {
|
|
185
|
-
color: "error",
|
|
186
|
-
children: "Error loading data"
|
|
187
|
-
} : void 0,
|
|
188
|
-
muiTableContainerProps: {
|
|
189
|
-
sx: {
|
|
190
|
-
minHeight: "500px"
|
|
191
|
-
}
|
|
192
|
-
},
|
|
193
|
-
onEditingRowCancel: () => setValidationErrors({}),
|
|
194
|
-
onEditingRowSave: handleSaveMapping,
|
|
195
|
-
renderEditRowDialogContent: ({ table, row, internalEditComponents }) => /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
196
|
-
/* @__PURE__ */ jsx(DialogTitle, { children: "Update Entity Mapping" }),
|
|
197
|
-
/* @__PURE__ */ jsx(
|
|
198
|
-
DialogContent,
|
|
199
|
-
{
|
|
200
|
-
style: { display: "flex", flexDirection: "column", gap: "1rem" },
|
|
201
|
-
children: internalEditComponents
|
|
202
|
-
}
|
|
203
|
-
),
|
|
204
|
-
/* @__PURE__ */ jsx(DialogActions, { children: /* @__PURE__ */ jsx(MRT_EditActionButtons, { variant: "text", table, row }) })
|
|
205
|
-
] }),
|
|
206
|
-
renderRowActions: ({ row, table }) => /* @__PURE__ */ jsxs(Flex, { children: [
|
|
207
|
-
/* @__PURE__ */ jsxs(TooltipTrigger, { children: [
|
|
208
|
-
/* @__PURE__ */ jsx(
|
|
209
|
-
ButtonIcon,
|
|
210
|
-
{
|
|
211
|
-
"aria-label": "Edit",
|
|
212
|
-
variant: "tertiary",
|
|
213
|
-
onClick: () => {
|
|
214
|
-
getEntityOptions();
|
|
215
|
-
table.setEditingRow(row);
|
|
216
|
-
},
|
|
217
|
-
icon: /* @__PURE__ */ jsx(Edit, {})
|
|
218
|
-
}
|
|
219
|
-
),
|
|
220
|
-
/* @__PURE__ */ jsx(Tooltip, { children: "Edit" })
|
|
221
|
-
] }),
|
|
222
|
-
/* @__PURE__ */ jsxs(TooltipTrigger, { children: [
|
|
223
|
-
/* @__PURE__ */ jsx(
|
|
224
|
-
ButtonIcon,
|
|
225
|
-
{
|
|
226
|
-
"aria-label": "Open in PagerDuty",
|
|
227
|
-
variant: "tertiary",
|
|
228
|
-
onClick: () => openInBrowser(row.getValue("serviceUrl")),
|
|
229
|
-
icon: /* @__PURE__ */ jsx(OpenInBrowser, {})
|
|
230
|
-
}
|
|
231
|
-
),
|
|
232
|
-
/* @__PURE__ */ jsx(Tooltip, { children: " Open in PagerDuty" })
|
|
233
|
-
] })
|
|
234
|
-
] }),
|
|
235
|
-
state: {
|
|
236
|
-
isLoading: mappings.length === 0 || catalogEntities.length === 0,
|
|
237
|
-
isSaving: isUpdatingMapping,
|
|
238
|
-
showAlertBanner: mappings === void 0 || catalogEntities === void 0,
|
|
239
|
-
showProgressBars: mappings.length === 0 || catalogEntities.length === 0
|
|
240
|
-
},
|
|
241
|
-
initialState: {
|
|
242
|
-
columnVisibility: {
|
|
243
|
-
serviceId: false,
|
|
244
|
-
entityRef: false,
|
|
245
|
-
serviceUrl: false,
|
|
246
|
-
integrationKey: false
|
|
247
|
-
}
|
|
248
|
-
}
|
|
249
|
-
});
|
|
250
|
-
function getEntityOptions() {
|
|
251
|
-
const options = [];
|
|
252
|
-
options.push({ value: "", label: "None" });
|
|
253
|
-
catalogEntities.forEach((entity) => {
|
|
254
|
-
const foundServiceAnnotation = entity.annotations["pagerduty.com/service-id"];
|
|
255
|
-
const foundIntegrationKeyAnnotation = entity.annotations["pagerduty.com/integration-key"];
|
|
256
|
-
let foundServiceMapping;
|
|
257
|
-
if (foundServiceAnnotation || foundIntegrationKeyAnnotation) {
|
|
258
|
-
foundServiceMapping = mappings.find(
|
|
259
|
-
(item) => item.serviceId === foundServiceAnnotation || item.integrationKey === foundIntegrationKeyAnnotation
|
|
260
|
-
);
|
|
261
|
-
}
|
|
262
|
-
const entityRef = `${entity.type}:${entity.namespace}/${entity.name}`.toLowerCase();
|
|
263
|
-
const foundEntityMapping = mappings.find(
|
|
264
|
-
(item) => item.entityRef === entityRef
|
|
265
|
-
);
|
|
266
|
-
if (!foundEntityMapping && (!foundServiceAnnotation || !foundIntegrationKeyAnnotation) || (foundServiceAnnotation || foundIntegrationKeyAnnotation) && foundServiceMapping && !foundEntityMapping) {
|
|
267
|
-
options.push({
|
|
268
|
-
value: entityRef,
|
|
269
|
-
label: entity.name
|
|
270
|
-
});
|
|
271
|
-
}
|
|
272
|
-
});
|
|
273
|
-
setEntityOptions(options);
|
|
274
|
-
}
|
|
275
|
-
return /* @__PURE__ */ jsx(MaterialReactTable, { table: dataTable });
|
|
276
|
-
};
|
|
277
|
-
const queryClient = new QueryClient();
|
|
278
|
-
return /* @__PURE__ */ jsx(QueryClientProvider, { client: queryClient, children: /* @__PURE__ */ jsx(DenseTable, {}) });
|
|
279
|
-
};
|
|
280
|
-
|
|
281
|
-
export { MappingTable };
|
|
282
|
-
//# sourceMappingURL=MappingTable.esm.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MappingTable.esm.js","sources":["../../../src/components/PagerDutyPage/MappingTable.tsx"],"sourcesContent":["import { useEffect, useMemo, useState } from 'react';\nimport { PagerDutyEntityMapping } from '@pagerduty/backstage-plugin-common';\nimport {\n MRT_ColumnDef,\n MRT_EditActionButtons,\n MRT_TableOptions,\n MaterialReactTable,\n useMaterialReactTable,\n} from 'material-react-table';\nimport {\n Box,\n DialogActions,\n DialogContent,\n DialogTitle,\n Typography,\n} from '@material-ui/core';\nimport { Flex, Tooltip, TooltipTrigger, ButtonIcon } from '@backstage/ui';\nimport {\n QueryClient,\n QueryClientProvider,\n useMutation,\n} from '@tanstack/react-query';\nimport { Edit, OpenInBrowser } from '@mui/icons-material';\nimport { useApi } from '@backstage/core-plugin-api';\nimport { pagerDutyApiRef } from '../../api';\n\ntype BackstageEntity = {\n id: string;\n name: string;\n namespace: string;\n type: string;\n system: string;\n owner: string;\n lifecycle: string;\n annotations: Annotations;\n};\n\nexport type Annotations = {\n 'pagerduty.com/integration-key': string;\n 'pagerduty.com/service-id': string;\n};\n\nfunction getColorFromStatus(status?: string) {\n switch (status) {\n case 'InSync':\n return 'green';\n case 'OutOfSync':\n return 'red';\n case 'NotMapped':\n return 'orange';\n default:\n return 'gray';\n }\n}\n\nfunction makeReadable(status?: string) {\n switch (status) {\n case 'InSync':\n return 'In Sync';\n case 'OutOfSync':\n return 'Out of Sync';\n case 'NotMapped':\n return 'Not Mapped';\n default:\n return 'Refresh to Update';\n }\n}\n\ntype CatalogEntityOptions = {\n value: string;\n label: string;\n};\n\ntype MappingTableProps = {\n mappings: PagerDutyEntityMapping[];\n catalogEntities: BackstageEntity[];\n};\n\nexport const MappingTable = ({\n mappings,\n catalogEntities,\n}: MappingTableProps) => {\n const DenseTable = () => {\n const [validationErrors, setValidationErrors] = useState<\n Record<string, string | undefined>\n >({});\n const [entityOptions, setEntityOptions] = useState<CatalogEntityOptions[]>(\n [],\n );\n const pagerDutyApi = useApi(pagerDutyApiRef);\n\n useEffect(() => {\n getEntityOptions();\n }, []);\n\n const columns = useMemo<MRT_ColumnDef<PagerDutyEntityMapping>[]>(\n () => [\n {\n id: 'serviceId',\n accessorKey: 'serviceId',\n header: 'Service ID',\n visibleInShowHideMenu: false,\n enableEditing: false,\n Edit: () => null,\n Cell: ({ cell }) => (\n <Typography variant=\"body1\" style={{ fontWeight: 600 }}>\n {cell.getValue<string>()}\n </Typography>\n ),\n },\n {\n id: 'integrationKey',\n accessorKey: 'integrationKey',\n header: 'Integration Key',\n visibleInShowHideMenu: false,\n enableEditing: false,\n Edit: () => null,\n },\n {\n id: 'serviceName',\n accessorKey: 'serviceName',\n header: 'PagerDuty Service',\n enableEditing: false,\n },\n {\n id: 'account',\n accessorKey: 'account',\n header: 'Account',\n enableEditing: false,\n Edit: () => null,\n },\n {\n id: 'team',\n accessorKey: 'team',\n header: 'Team',\n enableEditing: false,\n },\n {\n id: 'escalationPolicy',\n accessorKey: 'escalationPolicy',\n header: 'Escalation Policy',\n enableEditing: false,\n },\n {\n id: 'entityRef',\n accessorKey: 'entityRef',\n header: 'Mapping',\n visibleInShowHideMenu: false,\n editVariant: 'select',\n editSelectOptions: entityOptions,\n muiEditTextFieldProps: {\n select: true,\n error: !!validationErrors?.state,\n helperText: validationErrors?.state,\n multiline: true,\n type: 'range',\n },\n },\n {\n id: 'entityName',\n accessorKey: 'entityName',\n header: 'Mapped Entity Name',\n enableEditing: false,\n Edit: () => null,\n },\n {\n id: 'status',\n accessorKey: 'status',\n header: 'Status',\n enableEditing: false,\n Edit: () => null,\n Cell: ({ cell }) => (\n <Box\n component=\"span\"\n bgcolor={getColorFromStatus(cell.getValue<string>())}\n borderRadius=\"0.25rem\"\n color=\"white\"\n p=\"0.25rem\"\n >\n {makeReadable(cell.getValue<string>())}\n </Box>\n ),\n },\n {\n id: 'serviceUrl',\n accessorKey: 'serviceUrl',\n header: 'Service URL',\n visibleInShowHideMenu: false,\n enableEditing: false,\n Edit: () => null,\n },\n ],\n [validationErrors, entityOptions],\n );\n\n // UPDATE hook (put mapping in api)\n function useUpdateMapping() {\n return useMutation({\n mutationFn: async (mapping: PagerDutyEntityMapping) => {\n return await pagerDutyApi.storeServiceMapping(\n mapping.serviceId,\n mapping.integrationKey ?? '',\n mapping.entityRef,\n mapping.account ?? '',\n );\n },\n });\n }\n\n // call UPDATE hook\n const { mutateAsync: updateMapping, isPending: isUpdatingMapping } =\n useUpdateMapping();\n\n // UPDATE action\n const handleSaveMapping: MRT_TableOptions<PagerDutyEntityMapping>['onEditingRowSave'] =\n async ({ values, table }) => {\n setValidationErrors({});\n\n values.entityName =\n catalogEntities.find(\n entity =>\n `${entity.type}:${entity.namespace}/${entity.name}`.toLowerCase() ===\n values.entityRef,\n )?.name ?? '';\n values.status = 'RefreshToUpdate';\n\n await updateMapping(values);\n\n // find corresponding mapping in mappings array\n // and update it with new values\n const existingMapping = mappings.find(\n item => item.serviceId === values.serviceId,\n );\n if (existingMapping) {\n existingMapping.entityRef = values.entityRef;\n existingMapping.entityName = values.entityName;\n }\n\n table.setEditingRow(null); // exit editing mode\n };\n\n const openInBrowser = (url: string) => {\n window.open(url, '_blank', 'noreferrer');\n };\n\n const dataTable = useMaterialReactTable({\n columns,\n data: mappings,\n editDisplayMode: 'modal',\n enableEditing: true,\n positionActionsColumn: 'last',\n enableStickyHeader: true,\n enableFilters: true,\n getRowId: row => row.serviceId,\n muiToolbarAlertBannerProps:\n mappings === undefined\n ? {\n color: 'error',\n children: 'Error loading data',\n }\n : undefined,\n muiTableContainerProps: {\n sx: {\n minHeight: '500px',\n },\n },\n onEditingRowCancel: () => setValidationErrors({}),\n onEditingRowSave: handleSaveMapping,\n renderEditRowDialogContent: ({ table, row, internalEditComponents }) => (\n <>\n <DialogTitle>Update Entity Mapping</DialogTitle>\n <DialogContent\n style={{ display: 'flex', flexDirection: 'column', gap: '1rem' }}\n >\n {internalEditComponents}\n </DialogContent>\n <DialogActions>\n <MRT_EditActionButtons variant=\"text\" table={table} row={row} />\n </DialogActions>\n </>\n ),\n renderRowActions: ({ row, table }) => (\n <Flex>\n <TooltipTrigger>\n <ButtonIcon\n aria-label=\"Edit\"\n variant=\"tertiary\"\n onClick={() => {\n getEntityOptions();\n table.setEditingRow(row);\n }}\n icon={<Edit />}\n />\n <Tooltip>Edit</Tooltip>\n </TooltipTrigger>\n <TooltipTrigger>\n <ButtonIcon\n aria-label=\"Open in PagerDuty\"\n variant=\"tertiary\"\n onClick={() => openInBrowser(row.getValue('serviceUrl'))}\n icon={<OpenInBrowser />}\n />\n <Tooltip> Open in PagerDuty</Tooltip>\n </TooltipTrigger>\n </Flex>\n ),\n state: {\n isLoading: mappings.length === 0 || catalogEntities.length === 0,\n isSaving: isUpdatingMapping,\n showAlertBanner:\n mappings === undefined || catalogEntities === undefined,\n showProgressBars: mappings.length === 0 || catalogEntities.length === 0,\n },\n initialState: {\n columnVisibility: {\n serviceId: false,\n entityRef: false,\n serviceUrl: false,\n integrationKey: false,\n },\n },\n });\n\n function getEntityOptions() {\n const options: CatalogEntityOptions[] = [];\n // initialize with empty object\n options.push({ value: '', label: 'None' });\n\n catalogEntities.forEach(entity => {\n // find service-id annotation in entity\n const foundServiceAnnotation =\n entity.annotations['pagerduty.com/service-id'];\n\n // find integration-key annotation in entity\n const foundIntegrationKeyAnnotation =\n entity.annotations['pagerduty.com/integration-key'];\n\n // find entity with service-id in mappings array if service-id is found in entity\n let foundServiceMapping: PagerDutyEntityMapping | undefined;\n if (foundServiceAnnotation || foundIntegrationKeyAnnotation) {\n foundServiceMapping = mappings.find(\n item =>\n item.serviceId === foundServiceAnnotation ||\n item.integrationKey === foundIntegrationKeyAnnotation,\n );\n }\n\n const entityRef =\n `${entity.type}:${entity.namespace}/${entity.name}`.toLowerCase();\n // find entity with entity.id in entityMappings array\n const foundEntityMapping = mappings.find(\n item => item.entityRef === entityRef,\n );\n\n if (\n (!foundEntityMapping &&\n (!foundServiceAnnotation || !foundIntegrationKeyAnnotation)) ||\n ((foundServiceAnnotation || foundIntegrationKeyAnnotation) &&\n foundServiceMapping &&\n !foundEntityMapping)\n ) {\n options.push({\n value: entityRef,\n label: entity.name,\n });\n }\n });\n\n setEntityOptions(options);\n }\n\n return <MaterialReactTable table={dataTable} />;\n };\n\n const queryClient = new QueryClient();\n\n return (\n <QueryClientProvider client={queryClient}>\n <DenseTable />\n </QueryClientProvider>\n );\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.esm.js","sources":["../../src/hooks/index.ts"],"sourcesContent":["/*\n * Copyright 2020 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { useEntity } from '@backstage/plugin-catalog-react';\nimport { PagerDutyEntity } from '../types';\nimport { getPagerDutyEntity } from '../components/pagerDutyEntity';\n\nexport function usePagerdutyEntity(): PagerDutyEntity {\n const { entity } = useEntity();\n\n return getPagerDutyEntity(entity);\n}\n"],"names":[],"mappings":";;;AAoBO,SAAS,kBAAA,GAAsC;AACpD,EAAA,MAAM,EAAE,MAAA,EAAO,GAAI,SAAA,EAAU;AAE7B,EAAA,OAAO,mBAAmB,MAAM,CAAA;AAClC;;;;"}
|