@awell-health/awell-extensions 2.0.288 → 2.0.290
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/dist/extensions/freshdesk/actions/addNoteToTicket/addNoteToTicket.js +33 -12
- package/dist/extensions/freshdesk/actions/addNoteToTicket/addNoteToTicket.js.map +1 -1
- package/dist/extensions/freshdesk/actions/getTicket/getTicket.js +43 -22
- package/dist/extensions/freshdesk/actions/getTicket/getTicket.js.map +1 -1
- package/dist/extensions/freshdesk/actions/updateTicket/config/fields.d.ts +2 -2
- package/dist/extensions/freshdesk/actions/updateTicket/config/fields.js +1 -1
- package/dist/extensions/freshdesk/actions/updateTicket/config/fields.js.map +1 -1
- package/dist/extensions/freshdesk/actions/updateTicket/updateTicket.js +46 -26
- package/dist/extensions/freshdesk/actions/updateTicket/updateTicket.js.map +1 -1
- package/dist/extensions/freshdesk/lib/api/client.js +1 -1
- package/dist/extensions/freshdesk/lib/api/client.js.map +1 -1
- package/dist/extensions/freshdesk/lib/api/schema/GetTicket.schema.d.ts +6 -6
- package/dist/extensions/freshdesk/lib/api/schema/UpdateTicket.schema.d.ts +6 -6
- package/dist/extensions/freshdesk/lib/api/schema/atoms/Ticket.Schema.d.ts +6 -6
- package/dist/extensions/freshdesk/lib/api/schema/atoms/Ticket.Schema.js +5 -2
- package/dist/extensions/freshdesk/lib/api/schema/atoms/Ticket.Schema.js.map +1 -1
- package/dist/extensions/freshdesk/webhooks/TicketCreated/types.d.ts +2 -2
- package/dist/extensions/medplum/constants.d.ts +1 -0
- package/dist/extensions/medplum/constants.js +5 -0
- package/dist/extensions/medplum/constants.js.map +1 -0
- package/dist/extensions/medplum/webhooks/ObservationCreated/ObservationCreated.d.ts +16 -0
- package/dist/extensions/medplum/webhooks/ObservationCreated/ObservationCreated.js +53 -0
- package/dist/extensions/medplum/webhooks/ObservationCreated/ObservationCreated.js.map +1 -0
- package/dist/extensions/medplum/webhooks/ObservationCreated/__testdata__/payloadExample.d.ts +28 -0
- package/dist/extensions/medplum/webhooks/ObservationCreated/__testdata__/payloadExample.js +39 -0
- package/dist/extensions/medplum/webhooks/ObservationCreated/__testdata__/payloadExample.js.map +1 -0
- package/dist/extensions/medplum/webhooks/ObservationCreated/index.d.ts +1 -0
- package/dist/extensions/medplum/webhooks/ObservationCreated/index.js +18 -0
- package/dist/extensions/medplum/webhooks/ObservationCreated/index.js.map +1 -0
- package/dist/extensions/medplum/webhooks/index.d.ts +23 -1
- package/dist/extensions/medplum/webhooks/index.js +2 -1
- package/dist/extensions/medplum/webhooks/index.js.map +1 -1
- package/package.json +1 -1
@@ -4,6 +4,8 @@ exports.addNoteToTicket = void 0;
|
|
4
4
|
const extensions_core_1 = require("@awell-health/extensions-core");
|
5
5
|
const validatePayloadAndCreateSdk_1 = require("../../lib/validatePayloadAndCreateSdk");
|
6
6
|
const config_1 = require("./config");
|
7
|
+
const axios_1 = require("axios");
|
8
|
+
const addEventLog_1 = require("../../../../src/lib/awell/addEventLog");
|
7
9
|
exports.addNoteToTicket = {
|
8
10
|
key: 'addNoteToTicket',
|
9
11
|
category: extensions_core_1.Category.CUSTOMER_SUPPORT,
|
@@ -12,22 +14,41 @@ exports.addNoteToTicket = {
|
|
12
14
|
fields: config_1.fields,
|
13
15
|
previewable: false,
|
14
16
|
dataPoints: config_1.dataPoints,
|
15
|
-
onEvent: async ({ payload, onComplete }) => {
|
17
|
+
onEvent: async ({ payload, onComplete, onError }) => {
|
16
18
|
const { fields, freshdeskSdk } = await (0, validatePayloadAndCreateSdk_1.validatePayloadAndCreateSdk)({
|
17
19
|
fieldsSchema: config_1.FieldsValidationSchema,
|
18
20
|
payload,
|
19
21
|
});
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
22
|
+
try {
|
23
|
+
await freshdeskSdk.addNote({
|
24
|
+
ticketId: fields.ticketId,
|
25
|
+
input: {
|
26
|
+
body: fields.body,
|
27
|
+
incoming: fields.incoming,
|
28
|
+
notify_emails: fields.notifyEmails,
|
29
|
+
private: fields.private,
|
30
|
+
user_id: fields.userId,
|
31
|
+
},
|
32
|
+
});
|
33
|
+
await onComplete();
|
34
|
+
}
|
35
|
+
catch (error) {
|
36
|
+
// Some errors we want to handle explicitly for more human-readable logging
|
37
|
+
if (error instanceof axios_1.AxiosError) {
|
38
|
+
const err = error;
|
39
|
+
if (err.status === 404)
|
40
|
+
await onError({
|
41
|
+
events: [
|
42
|
+
(0, addEventLog_1.addActivityEventLog)({
|
43
|
+
message: 'Ticket to add note to not found (404)',
|
44
|
+
}),
|
45
|
+
],
|
46
|
+
});
|
47
|
+
return;
|
48
|
+
}
|
49
|
+
// Throw all other errors
|
50
|
+
throw error;
|
51
|
+
}
|
31
52
|
},
|
32
53
|
};
|
33
54
|
//# sourceMappingURL=addNoteToTicket.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"addNoteToTicket.js","sourceRoot":"","sources":["../../../../../extensions/freshdesk/actions/addNoteToTicket/addNoteToTicket.ts"],"names":[],"mappings":";;;AACA,mEAAwD;AACxD,uFAAmF;AAEnF,qCAAqE;
|
1
|
+
{"version":3,"file":"addNoteToTicket.js","sourceRoot":"","sources":["../../../../../extensions/freshdesk/actions/addNoteToTicket/addNoteToTicket.ts"],"names":[],"mappings":";;;AACA,mEAAwD;AACxD,uFAAmF;AAEnF,qCAAqE;AACrE,iCAAkC;AAClC,uEAA2E;AAE9D,QAAA,eAAe,GAIxB;IACF,GAAG,EAAE,iBAAiB;IACtB,QAAQ,EAAE,0BAAQ,CAAC,gBAAgB;IACnC,KAAK,EAAE,oBAAoB;IAC3B,WAAW,EAAE,sCAAsC;IACnD,MAAM,EAAN,eAAM;IACN,WAAW,EAAE,KAAK;IAClB,UAAU,EAAV,mBAAU;IACV,OAAO,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,EAAiB,EAAE;QACjE,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,MAAM,IAAA,yDAA2B,EAAC;YACjE,YAAY,EAAE,+BAAsB;YACpC,OAAO;SACR,CAAC,CAAA;QAEF,IAAI,CAAC;YACH,MAAM,YAAY,CAAC,OAAO,CAAC;gBACzB,QAAQ,EAAE,MAAM,CAAC,QAAQ;gBACzB,KAAK,EAAE;oBACL,IAAI,EAAE,MAAM,CAAC,IAAI;oBACjB,QAAQ,EAAE,MAAM,CAAC,QAAQ;oBACzB,aAAa,EAAE,MAAM,CAAC,YAAY;oBAClC,OAAO,EAAE,MAAM,CAAC,OAAO;oBACvB,OAAO,EAAE,MAAM,CAAC,MAAM;iBACvB;aACF,CAAC,CAAA;YAEF,MAAM,UAAU,EAAE,CAAA;QACpB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,2EAA2E;YAC3E,IAAI,KAAK,YAAY,kBAAU,EAAE,CAAC;gBAChC,MAAM,GAAG,GAAG,KAAmB,CAAA;gBAE/B,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG;oBACpB,MAAM,OAAO,CAAC;wBACZ,MAAM,EAAE;4BACN,IAAA,iCAAmB,EAAC;gCAClB,OAAO,EAAE,uCAAuC;6BACjD,CAAC;yBACH;qBACF,CAAC,CAAA;gBACJ,OAAM;YACR,CAAC;YAED,yBAAyB;YACzB,MAAM,KAAK,CAAA;QACb,CAAC;IACH,CAAC;CACF,CAAA"}
|
@@ -5,6 +5,8 @@ const extensions_core_1 = require("@awell-health/extensions-core");
|
|
5
5
|
const validatePayloadAndCreateSdk_1 = require("../../lib/validatePayloadAndCreateSdk");
|
6
6
|
const config_1 = require("./config");
|
7
7
|
const atoms_1 = require("../../lib/api/schema/atoms");
|
8
|
+
const axios_1 = require("axios");
|
9
|
+
const addEventLog_1 = require("../../../../src/lib/awell/addEventLog");
|
8
10
|
exports.getTicket = {
|
9
11
|
key: 'getTicket',
|
10
12
|
category: extensions_core_1.Category.CUSTOMER_SUPPORT,
|
@@ -13,33 +15,52 @@ exports.getTicket = {
|
|
13
15
|
fields: config_1.fields,
|
14
16
|
previewable: false,
|
15
17
|
dataPoints: config_1.dataPoints,
|
16
|
-
onEvent: async ({ payload, onComplete }) => {
|
18
|
+
onEvent: async ({ payload, onComplete, onError }) => {
|
17
19
|
var _a, _b, _c;
|
18
20
|
const { fields, freshdeskSdk } = await (0, validatePayloadAndCreateSdk_1.validatePayloadAndCreateSdk)({
|
19
21
|
fieldsSchema: config_1.FieldsValidationSchema,
|
20
22
|
payload,
|
21
23
|
});
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
24
|
+
try {
|
25
|
+
const { data } = await freshdeskSdk.getTicket(fields.ticketId);
|
26
|
+
const priorityLabel = (_a = Object.entries(atoms_1.TicketPriority).find(([, value]) => value === data.priority)) === null || _a === void 0 ? void 0 : _a[0];
|
27
|
+
const statusLabel = (_b = Object.entries(atoms_1.TicketStatus).find(([, value]) => value === data.status)) === null || _b === void 0 ? void 0 : _b[0];
|
28
|
+
const sourceLabel = (_c = Object.entries(atoms_1.TicketSource).find(([, value]) => value === data.source)) === null || _c === void 0 ? void 0 : _c[0];
|
29
|
+
await onComplete({
|
30
|
+
data_points: {
|
31
|
+
ticketData: JSON.stringify(data),
|
32
|
+
subject: data.subject,
|
33
|
+
type: data.type,
|
34
|
+
priorityValue: String(data.priority),
|
35
|
+
priorityLabel,
|
36
|
+
statusValue: String(data.status),
|
37
|
+
statusLabel,
|
38
|
+
sourceValue: String(data.source),
|
39
|
+
sourceLabel,
|
40
|
+
descriptionText: data.description_text,
|
41
|
+
descriptionHtml: data.description,
|
42
|
+
customFields: JSON.stringify(data.custom_fields),
|
43
|
+
tags: JSON.stringify(data.tags),
|
44
|
+
},
|
45
|
+
});
|
46
|
+
}
|
47
|
+
catch (error) {
|
48
|
+
// Some errors we want to handle explicitly for more human-readable logging
|
49
|
+
if (error instanceof axios_1.AxiosError) {
|
50
|
+
const err = error;
|
51
|
+
if (err.status === 404)
|
52
|
+
await onError({
|
53
|
+
events: [
|
54
|
+
(0, addEventLog_1.addActivityEventLog)({
|
55
|
+
message: 'Ticket not found (404)',
|
56
|
+
}),
|
57
|
+
],
|
58
|
+
});
|
59
|
+
return;
|
60
|
+
}
|
61
|
+
// Throw all other errors
|
62
|
+
throw error;
|
63
|
+
}
|
43
64
|
},
|
44
65
|
};
|
45
66
|
//# sourceMappingURL=getTicket.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"getTicket.js","sourceRoot":"","sources":["../../../../../extensions/freshdesk/actions/getTicket/getTicket.ts"],"names":[],"mappings":";;;AACA,mEAAwD;AACxD,uFAAmF;AAEnF,qCAAqE;AACrE,sDAImC;
|
1
|
+
{"version":3,"file":"getTicket.js","sourceRoot":"","sources":["../../../../../extensions/freshdesk/actions/getTicket/getTicket.ts"],"names":[],"mappings":";;;AACA,mEAAwD;AACxD,uFAAmF;AAEnF,qCAAqE;AACrE,sDAImC;AACnC,iCAAkC;AAClC,uEAA2E;AAE9D,QAAA,SAAS,GAIlB;IACF,GAAG,EAAE,WAAW;IAChB,QAAQ,EAAE,0BAAQ,CAAC,gBAAgB;IACnC,KAAK,EAAE,YAAY;IACnB,WAAW,EAAE,8BAA8B;IAC3C,MAAM,EAAN,eAAM;IACN,WAAW,EAAE,KAAK;IAClB,UAAU,EAAV,mBAAU;IACV,OAAO,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,EAAiB,EAAE;;QACjE,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,MAAM,IAAA,yDAA2B,EAAC;YACjE,YAAY,EAAE,+BAAsB;YACpC,OAAO;SACR,CAAC,CAAA;QAEF,IAAI,CAAC;YACH,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;YAE9D,MAAM,aAAa,GAAG,MAAA,MAAM,CAAC,OAAO,CAAC,sBAAc,CAAC,CAAC,IAAI,CACvD,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,IAAI,CAAC,QAAQ,CACvC,0CAAG,CAAC,CAAC,CAAA;YACN,MAAM,WAAW,GAAG,MAAA,MAAM,CAAC,OAAO,CAAC,oBAAY,CAAC,CAAC,IAAI,CACnD,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,CACrC,0CAAG,CAAC,CAAC,CAAA;YACN,MAAM,WAAW,GAAG,MAAA,MAAM,CAAC,OAAO,CAAC,oBAAY,CAAC,CAAC,IAAI,CACnD,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,CACrC,0CAAG,CAAC,CAAC,CAAA;YAEN,MAAM,UAAU,CAAC;gBACf,WAAW,EAAE;oBACX,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;oBAChC,OAAO,EAAE,IAAI,CAAC,OAAO;oBACrB,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,aAAa,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;oBACpC,aAAa;oBACb,WAAW,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC;oBAChC,WAAW;oBACX,WAAW,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC;oBAChC,WAAW;oBACX,eAAe,EAAE,IAAI,CAAC,gBAAgB;oBACtC,eAAe,EAAE,IAAI,CAAC,WAAW;oBACjC,YAAY,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC;oBAChD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC;iBAChC;aACF,CAAC,CAAA;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,2EAA2E;YAC3E,IAAI,KAAK,YAAY,kBAAU,EAAE,CAAC;gBAChC,MAAM,GAAG,GAAG,KAAmB,CAAA;gBAE/B,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG;oBACpB,MAAM,OAAO,CAAC;wBACZ,MAAM,EAAE;4BACN,IAAA,iCAAmB,EAAC;gCAClB,OAAO,EAAE,wBAAwB;6BAClC,CAAC;yBACH;qBACF,CAAC,CAAA;gBACJ,OAAM;YACR,CAAC;YAED,yBAAyB;YACzB,MAAM,KAAK,CAAA;QACb,CAAC;IACH,CAAC;CACF,CAAA"}
|
@@ -86,9 +86,8 @@ export declare const FieldsValidationSchema: z.ZodObject<{
|
|
86
86
|
description: z.ZodOptional<z.ZodEffects<z.ZodString, string | undefined, string>>;
|
87
87
|
dueBy: z.ZodOptional<z.ZodEffects<z.ZodString, string | undefined, string>>;
|
88
88
|
tags: z.ZodEffects<z.ZodOptional<z.ZodEffects<z.ZodString, string | undefined, string>>, string[] | undefined, string | undefined>;
|
89
|
-
customFields: z.ZodEffects<z.ZodOptional<z.ZodString>, Record<string, string
|
89
|
+
customFields: z.ZodEffects<z.ZodOptional<z.ZodString>, Record<string, string> | undefined, string | undefined>;
|
90
90
|
}, "strip", z.ZodTypeAny, {
|
91
|
-
customFields: Record<string, string>;
|
92
91
|
ticketId: string;
|
93
92
|
type?: string | undefined;
|
94
93
|
status?: 2 | 3 | 5 | 4 | undefined;
|
@@ -96,6 +95,7 @@ export declare const FieldsValidationSchema: z.ZodObject<{
|
|
96
95
|
subject?: string | undefined;
|
97
96
|
description?: string | undefined;
|
98
97
|
tags?: string[] | undefined;
|
98
|
+
customFields?: Record<string, string> | undefined;
|
99
99
|
dueBy?: string | undefined;
|
100
100
|
}, {
|
101
101
|
ticketId: string;
|
@@ -109,7 +109,7 @@ exports.FieldsValidationSchema = zod_1.default.object({
|
|
109
109
|
.optional()
|
110
110
|
.transform((str, ctx) => {
|
111
111
|
if ((0, lodash_1.isNil)(str) || (0, lodash_1.isEmpty)(str))
|
112
|
-
return
|
112
|
+
return undefined;
|
113
113
|
try {
|
114
114
|
const parsedJson = JSON.parse(str);
|
115
115
|
const allValuesAreStrings = Object.values(parsedJson).every((value) => typeof value === 'string');
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"fields.js","sourceRoot":"","sources":["../../../../../../extensions/freshdesk/actions/updateTicket/config/fields.ts"],"names":[],"mappings":"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
|
1
|
+
{"version":3,"file":"fields.js","sourceRoot":"","sources":["../../../../../../extensions/freshdesk/actions/updateTicket/config/fields.ts"],"names":[],"mappings":"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"}
|
@@ -5,6 +5,7 @@ const extensions_core_1 = require("@awell-health/extensions-core");
|
|
5
5
|
const validatePayloadAndCreateSdk_1 = require("../../lib/validatePayloadAndCreateSdk");
|
6
6
|
const config_1 = require("./config");
|
7
7
|
const addEventLog_1 = require("../../../../src/lib/awell/addEventLog");
|
8
|
+
const axios_1 = require("axios");
|
8
9
|
exports.updateTicket = {
|
9
10
|
key: 'updateTicket',
|
10
11
|
category: extensions_core_1.Category.CUSTOMER_SUPPORT,
|
@@ -13,36 +14,55 @@ exports.updateTicket = {
|
|
13
14
|
fields: config_1.fields,
|
14
15
|
previewable: false,
|
15
16
|
dataPoints: config_1.dataPoints,
|
16
|
-
onEvent: async ({ payload, onComplete }) => {
|
17
|
+
onEvent: async ({ payload, onComplete, onError }) => {
|
17
18
|
const { fields, freshdeskSdk } = await (0, validatePayloadAndCreateSdk_1.validatePayloadAndCreateSdk)({
|
18
19
|
fieldsSchema: config_1.FieldsValidationSchema,
|
19
20
|
payload,
|
20
21
|
});
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
22
|
+
try {
|
23
|
+
const ticketToUpdate = await freshdeskSdk.getTicket(fields.ticketId);
|
24
|
+
const requestBody = {
|
25
|
+
subject: fields.subject,
|
26
|
+
type: fields.type,
|
27
|
+
status: fields.status,
|
28
|
+
priority: fields.priority,
|
29
|
+
description: fields.description,
|
30
|
+
due_by: fields.dueBy,
|
31
|
+
tags: fields.tags,
|
32
|
+
custom_fields: fields.customFields,
|
33
|
+
};
|
34
|
+
await freshdeskSdk.updateTicket({
|
35
|
+
ticketId: fields.ticketId,
|
36
|
+
input: requestBody,
|
37
|
+
});
|
38
|
+
await onComplete({
|
39
|
+
events: [
|
40
|
+
(0, addEventLog_1.addActivityEventLog)({
|
41
|
+
message: `Ticket to update:\n${JSON.stringify(ticketToUpdate.data, null, 2)}`,
|
42
|
+
}),
|
43
|
+
(0, addEventLog_1.addActivityEventLog)({
|
44
|
+
message: `Ticket updated successfully with the following fields:\n${JSON.stringify(requestBody, null, 2)}`,
|
45
|
+
}),
|
46
|
+
],
|
47
|
+
});
|
48
|
+
}
|
49
|
+
catch (error) {
|
50
|
+
// Some errors we want to handle explicitly for more human-readable logging
|
51
|
+
if (error instanceof axios_1.AxiosError) {
|
52
|
+
const err = error;
|
53
|
+
if (err.status === 404)
|
54
|
+
await onError({
|
55
|
+
events: [
|
56
|
+
(0, addEventLog_1.addActivityEventLog)({
|
57
|
+
message: 'Ticket to update not found (404)',
|
58
|
+
}),
|
59
|
+
],
|
60
|
+
});
|
61
|
+
return;
|
62
|
+
}
|
63
|
+
// Throw all other errors
|
64
|
+
throw error;
|
65
|
+
}
|
46
66
|
},
|
47
67
|
};
|
48
68
|
//# sourceMappingURL=updateTicket.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"updateTicket.js","sourceRoot":"","sources":["../../../../../extensions/freshdesk/actions/updateTicket/updateTicket.ts"],"names":[],"mappings":";;;AACA,mEAAwD;AACxD,uFAAmF;AAEnF,qCAAqE;AACrE,uEAA2E;
|
1
|
+
{"version":3,"file":"updateTicket.js","sourceRoot":"","sources":["../../../../../extensions/freshdesk/actions/updateTicket/updateTicket.ts"],"names":[],"mappings":";;;AACA,mEAAwD;AACxD,uFAAmF;AAEnF,qCAAqE;AACrE,uEAA2E;AAC3E,iCAAkC;AAErB,QAAA,YAAY,GAIrB;IACF,GAAG,EAAE,cAAc;IACnB,QAAQ,EAAE,0BAAQ,CAAC,gBAAgB;IACnC,KAAK,EAAE,eAAe;IACtB,WAAW,EAAE,+BAA+B;IAC5C,MAAM,EAAN,eAAM;IACN,WAAW,EAAE,KAAK;IAClB,UAAU,EAAV,mBAAU;IACV,OAAO,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,EAAiB,EAAE;QACjE,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,MAAM,IAAA,yDAA2B,EAAC;YACjE,YAAY,EAAE,+BAAsB;YACpC,OAAO;SACR,CAAC,CAAA;QAEF,IAAI,CAAC;YACH,MAAM,cAAc,GAAG,MAAM,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;YAEpE,MAAM,WAAW,GAAG;gBAClB,OAAO,EAAE,MAAM,CAAC,OAAO;gBACvB,IAAI,EAAE,MAAM,CAAC,IAAI;gBACjB,MAAM,EAAE,MAAM,CAAC,MAAM;gBACrB,QAAQ,EAAE,MAAM,CAAC,QAAQ;gBACzB,WAAW,EAAE,MAAM,CAAC,WAAW;gBAC/B,MAAM,EAAE,MAAM,CAAC,KAAK;gBACpB,IAAI,EAAE,MAAM,CAAC,IAAI;gBACjB,aAAa,EAAE,MAAM,CAAC,YAAY;aACnC,CAAA;YAED,MAAM,YAAY,CAAC,YAAY,CAAC;gBAC9B,QAAQ,EAAE,MAAM,CAAC,QAAQ;gBACzB,KAAK,EAAE,WAAW;aACnB,CAAC,CAAA;YAEF,MAAM,UAAU,CAAC;gBACf,MAAM,EAAE;oBACN,IAAA,iCAAmB,EAAC;wBAClB,OAAO,EAAE,sBAAsB,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE;qBAC9E,CAAC;oBACF,IAAA,iCAAmB,EAAC;wBAClB,OAAO,EAAE,2DAA2D,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE;qBAC3G,CAAC;iBACH;aACF,CAAC,CAAA;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,2EAA2E;YAC3E,IAAI,KAAK,YAAY,kBAAU,EAAE,CAAC;gBAChC,MAAM,GAAG,GAAG,KAAmB,CAAA;gBAE/B,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG;oBACpB,MAAM,OAAO,CAAC;wBACZ,MAAM,EAAE;4BACN,IAAA,iCAAmB,EAAC;gCAClB,OAAO,EAAE,kCAAkC;6BAC5C,CAAC;yBACH;qBACF,CAAC,CAAA;gBACJ,OAAM;YACR,CAAC;YAED,yBAAyB;YACzB,MAAM,KAAK,CAAA;QACb,CAAC;IACH,CAAC;CACF,CAAA"}
|
@@ -25,7 +25,7 @@ class FreshdeskApiClient {
|
|
25
25
|
return response;
|
26
26
|
}
|
27
27
|
async updateTicket({ ticketId, input, }) {
|
28
|
-
const response = await this.client.
|
28
|
+
const response = await this.client.put(`/tickets/${ticketId}`, input);
|
29
29
|
return response;
|
30
30
|
}
|
31
31
|
async addNote({ ticketId, input, }) {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../../../../extensions/freshdesk/lib/api/client.ts"],"names":[],"mappings":";;;;;;AAAA,kDAAqE;AASrE,MAAa,kBAAkB;IAG7B,YAAY,EAAE,OAAO,EAAE,MAAM,EAAuC;QAClE;;WAEG;QACH,MAAM,mBAAmB,GAAG,GAAG,CAAA;QAC/B,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,IAAI,mBAAmB,EAAE,CAAC,CAAC,QAAQ,CACpE,QAAQ,CACT,CAAA;QAED,IAAI,CAAC,MAAM,GAAG,eAAK,CAAC,MAAM,CAAC;YACzB,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE;gBACP,aAAa,EAAE,SAAS,KAAK,EAAE;gBAC/B,cAAc,EAAE,kBAAkB;aACnC;SACF,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,SAAS,CACb,QAAgB;QAEhB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CACpC,YAAY,QAAQ,EAAE,CACvB,CAAA;QAED,OAAO,QAAQ,CAAA;IACjB,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,EACjB,QAAQ,EACR,KAAK,GAIN;QACC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../../../../extensions/freshdesk/lib/api/client.ts"],"names":[],"mappings":";;;;;;AAAA,kDAAqE;AASrE,MAAa,kBAAkB;IAG7B,YAAY,EAAE,OAAO,EAAE,MAAM,EAAuC;QAClE;;WAEG;QACH,MAAM,mBAAmB,GAAG,GAAG,CAAA;QAC/B,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,IAAI,mBAAmB,EAAE,CAAC,CAAC,QAAQ,CACpE,QAAQ,CACT,CAAA;QAED,IAAI,CAAC,MAAM,GAAG,eAAK,CAAC,MAAM,CAAC;YACzB,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE;gBACP,aAAa,EAAE,SAAS,KAAK,EAAE;gBAC/B,cAAc,EAAE,kBAAkB;aACnC;SACF,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,SAAS,CACb,QAAgB;QAEhB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CACpC,YAAY,QAAQ,EAAE,CACvB,CAAA;QAED,OAAO,QAAQ,CAAA;IACjB,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,EACjB,QAAQ,EACR,KAAK,GAIN;QACC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CACpC,YAAY,QAAQ,EAAE,EACtB,KAAK,CACN,CAAA;QAED,OAAO,QAAQ,CAAA;IACjB,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,EACZ,QAAQ,EACR,KAAK,GAIN;QACC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CACrC,YAAY,QAAQ,QAAQ,EAC5B,KAAK,CACN,CAAA;QAED,OAAO,QAAQ,CAAA;IACjB,CAAC;CACF;AA5DD,gDA4DC"}
|
@@ -13,7 +13,7 @@ export declare const GetTicketResponseSchema: z.ZodObject<{
|
|
13
13
|
spam: z.ZodBoolean;
|
14
14
|
status: z.ZodUnion<[z.ZodLiteral<2>, z.ZodLiteral<3>, z.ZodLiteral<4>, z.ZodLiteral<5>]>;
|
15
15
|
subject: z.ZodNullable<z.ZodString>;
|
16
|
-
company_id: z.ZodOptional<z.ZodNumber
|
16
|
+
company_id: z.ZodNullable<z.ZodOptional<z.ZodNumber>>;
|
17
17
|
id: z.ZodNumber;
|
18
18
|
type: z.ZodNullable<z.ZodString>;
|
19
19
|
to_emails: z.ZodNullable<z.ZodArray<z.ZodString, "many">>;
|
@@ -26,7 +26,7 @@ export declare const GetTicketResponseSchema: z.ZodObject<{
|
|
26
26
|
association_type: z.ZodNullable<z.ZodUnknown>;
|
27
27
|
description_text: z.ZodString;
|
28
28
|
description: z.ZodString;
|
29
|
-
custom_fields: z.ZodNullable<z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString
|
29
|
+
custom_fields: z.ZodNullable<z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnion<[z.ZodString, z.ZodNull]>>>>;
|
30
30
|
tags: z.ZodArray<z.ZodString, "many">;
|
31
31
|
attachments: z.ZodArray<z.ZodUnknown, "many">;
|
32
32
|
}, "strip", z.ZodTypeAny, {
|
@@ -56,9 +56,9 @@ export declare const GetTicketResponseSchema: z.ZodObject<{
|
|
56
56
|
is_escalated: boolean;
|
57
57
|
description_text: string;
|
58
58
|
attachments: unknown[];
|
59
|
-
company_id?: number | undefined;
|
59
|
+
company_id?: number | null | undefined;
|
60
60
|
association_type?: unknown;
|
61
|
-
custom_fields?: Record<string, string> | null | undefined;
|
61
|
+
custom_fields?: Record<string, string | null> | null | undefined;
|
62
62
|
}, {
|
63
63
|
type: string | null;
|
64
64
|
status: 2 | 3 | 5 | 4;
|
@@ -86,8 +86,8 @@ export declare const GetTicketResponseSchema: z.ZodObject<{
|
|
86
86
|
is_escalated: boolean;
|
87
87
|
description_text: string;
|
88
88
|
attachments: unknown[];
|
89
|
-
company_id?: number | undefined;
|
89
|
+
company_id?: number | null | undefined;
|
90
90
|
association_type?: unknown;
|
91
|
-
custom_fields?: Record<string, string> | null | undefined;
|
91
|
+
custom_fields?: Record<string, string | null> | null | undefined;
|
92
92
|
}>;
|
93
93
|
export type GetTicketResponseType = z.infer<typeof GetTicketResponseSchema>;
|
@@ -99,7 +99,7 @@ export declare const UpdateTicketResponseSchema: z.ZodObject<{
|
|
99
99
|
spam: z.ZodBoolean;
|
100
100
|
status: z.ZodUnion<[z.ZodLiteral<2>, z.ZodLiteral<3>, z.ZodLiteral<4>, z.ZodLiteral<5>]>;
|
101
101
|
subject: z.ZodNullable<z.ZodString>;
|
102
|
-
company_id: z.ZodOptional<z.ZodNumber
|
102
|
+
company_id: z.ZodNullable<z.ZodOptional<z.ZodNumber>>;
|
103
103
|
id: z.ZodNumber;
|
104
104
|
type: z.ZodNullable<z.ZodString>;
|
105
105
|
to_emails: z.ZodNullable<z.ZodArray<z.ZodString, "many">>;
|
@@ -112,7 +112,7 @@ export declare const UpdateTicketResponseSchema: z.ZodObject<{
|
|
112
112
|
association_type: z.ZodNullable<z.ZodUnknown>;
|
113
113
|
description_text: z.ZodString;
|
114
114
|
description: z.ZodString;
|
115
|
-
custom_fields: z.ZodNullable<z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString
|
115
|
+
custom_fields: z.ZodNullable<z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnion<[z.ZodString, z.ZodNull]>>>>;
|
116
116
|
tags: z.ZodArray<z.ZodString, "many">;
|
117
117
|
attachments: z.ZodArray<z.ZodUnknown, "many">;
|
118
118
|
}, "strip", z.ZodTypeAny, {
|
@@ -142,9 +142,9 @@ export declare const UpdateTicketResponseSchema: z.ZodObject<{
|
|
142
142
|
is_escalated: boolean;
|
143
143
|
description_text: string;
|
144
144
|
attachments: unknown[];
|
145
|
-
company_id?: number | undefined;
|
145
|
+
company_id?: number | null | undefined;
|
146
146
|
association_type?: unknown;
|
147
|
-
custom_fields?: Record<string, string> | null | undefined;
|
147
|
+
custom_fields?: Record<string, string | null> | null | undefined;
|
148
148
|
}, {
|
149
149
|
type: string | null;
|
150
150
|
status: 2 | 3 | 5 | 4;
|
@@ -172,8 +172,8 @@ export declare const UpdateTicketResponseSchema: z.ZodObject<{
|
|
172
172
|
is_escalated: boolean;
|
173
173
|
description_text: string;
|
174
174
|
attachments: unknown[];
|
175
|
-
company_id?: number | undefined;
|
175
|
+
company_id?: number | null | undefined;
|
176
176
|
association_type?: unknown;
|
177
|
-
custom_fields?: Record<string, string> | null | undefined;
|
177
|
+
custom_fields?: Record<string, string | null> | null | undefined;
|
178
178
|
}>;
|
179
179
|
export type UpdateTicketResponseType = z.infer<typeof UpdateTicketResponseSchema>;
|
@@ -13,7 +13,7 @@ export declare const TicketSchema: z.ZodObject<{
|
|
13
13
|
spam: z.ZodBoolean;
|
14
14
|
status: z.ZodUnion<[z.ZodLiteral<2>, z.ZodLiteral<3>, z.ZodLiteral<4>, z.ZodLiteral<5>]>;
|
15
15
|
subject: z.ZodNullable<z.ZodString>;
|
16
|
-
company_id: z.ZodOptional<z.ZodNumber
|
16
|
+
company_id: z.ZodNullable<z.ZodOptional<z.ZodNumber>>;
|
17
17
|
id: z.ZodNumber;
|
18
18
|
type: z.ZodNullable<z.ZodString>;
|
19
19
|
to_emails: z.ZodNullable<z.ZodArray<z.ZodString, "many">>;
|
@@ -26,7 +26,7 @@ export declare const TicketSchema: z.ZodObject<{
|
|
26
26
|
association_type: z.ZodNullable<z.ZodUnknown>;
|
27
27
|
description_text: z.ZodString;
|
28
28
|
description: z.ZodString;
|
29
|
-
custom_fields: z.ZodNullable<z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString
|
29
|
+
custom_fields: z.ZodNullable<z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnion<[z.ZodString, z.ZodNull]>>>>;
|
30
30
|
tags: z.ZodArray<z.ZodString, "many">;
|
31
31
|
attachments: z.ZodArray<z.ZodUnknown, "many">;
|
32
32
|
}, "strip", z.ZodTypeAny, {
|
@@ -56,9 +56,9 @@ export declare const TicketSchema: z.ZodObject<{
|
|
56
56
|
is_escalated: boolean;
|
57
57
|
description_text: string;
|
58
58
|
attachments: unknown[];
|
59
|
-
company_id?: number | undefined;
|
59
|
+
company_id?: number | null | undefined;
|
60
60
|
association_type?: unknown;
|
61
|
-
custom_fields?: Record<string, string> | null | undefined;
|
61
|
+
custom_fields?: Record<string, string | null> | null | undefined;
|
62
62
|
}, {
|
63
63
|
type: string | null;
|
64
64
|
status: 2 | 3 | 5 | 4;
|
@@ -86,7 +86,7 @@ export declare const TicketSchema: z.ZodObject<{
|
|
86
86
|
is_escalated: boolean;
|
87
87
|
description_text: string;
|
88
88
|
attachments: unknown[];
|
89
|
-
company_id?: number | undefined;
|
89
|
+
company_id?: number | null | undefined;
|
90
90
|
association_type?: unknown;
|
91
|
-
custom_fields?: Record<string, string> | null | undefined;
|
91
|
+
custom_fields?: Record<string, string | null> | null | undefined;
|
92
92
|
}>;
|
@@ -17,7 +17,7 @@ exports.TicketSchema = zod_1.z.object({
|
|
17
17
|
spam: zod_1.z.boolean(),
|
18
18
|
status: _1.TicketStatusSchema,
|
19
19
|
subject: zod_1.z.string().nullable(),
|
20
|
-
company_id: zod_1.z.number().optional(),
|
20
|
+
company_id: zod_1.z.number().optional().nullable(),
|
21
21
|
id: zod_1.z.number(),
|
22
22
|
type: zod_1.z.string().nullable(),
|
23
23
|
to_emails: zod_1.z.array(zod_1.z.string()).nullable(),
|
@@ -30,7 +30,10 @@ exports.TicketSchema = zod_1.z.object({
|
|
30
30
|
association_type: zod_1.z.unknown().nullable(),
|
31
31
|
description_text: zod_1.z.string(),
|
32
32
|
description: zod_1.z.string(),
|
33
|
-
custom_fields: zod_1.z
|
33
|
+
custom_fields: zod_1.z
|
34
|
+
.record(zod_1.z.string(), zod_1.z.union([zod_1.z.string(), zod_1.z.null()]))
|
35
|
+
.optional()
|
36
|
+
.nullable(),
|
34
37
|
tags: zod_1.z.array(zod_1.z.string()),
|
35
38
|
attachments: zod_1.z.array(zod_1.z.unknown()),
|
36
39
|
});
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"Ticket.Schema.js","sourceRoot":"","sources":["../../../../../../../extensions/freshdesk/lib/api/schema/atoms/Ticket.Schema.ts"],"names":[],"mappings":";;;AAAA,6BAAuB;AACvB,wBAAgF;AAEnE,QAAA,YAAY,GAAG,OAAC,CAAC,MAAM,CAAC;IACnC,SAAS,EAAE,OAAC,CAAC,KAAK,CAAC,OAAC,CAAC,MAAM,EAAE,CAAC;IAC9B,UAAU,EAAE,OAAC,CAAC,KAAK,CAAC,OAAC,CAAC,MAAM,EAAE,CAAC;IAC/B,eAAe,EAAE,OAAC,CAAC,KAAK,CAAC,OAAC,CAAC,MAAM,EAAE,CAAC;IACpC,eAAe,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACtC,YAAY,EAAE,OAAC,CAAC,OAAO,EAAE;IACzB,QAAQ,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC/B,QAAQ,EAAE,uBAAoB;IAC9B,YAAY,EAAE,OAAC,CAAC,MAAM,EAAE;IACxB,YAAY,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACnC,MAAM,EAAE,qBAAkB;IAC1B,IAAI,EAAE,OAAC,CAAC,OAAO,EAAE;IACjB,MAAM,EAAE,qBAAkB;IAC1B,OAAO,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC9B,UAAU,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;
|
1
|
+
{"version":3,"file":"Ticket.Schema.js","sourceRoot":"","sources":["../../../../../../../extensions/freshdesk/lib/api/schema/atoms/Ticket.Schema.ts"],"names":[],"mappings":";;;AAAA,6BAAuB;AACvB,wBAAgF;AAEnE,QAAA,YAAY,GAAG,OAAC,CAAC,MAAM,CAAC;IACnC,SAAS,EAAE,OAAC,CAAC,KAAK,CAAC,OAAC,CAAC,MAAM,EAAE,CAAC;IAC9B,UAAU,EAAE,OAAC,CAAC,KAAK,CAAC,OAAC,CAAC,MAAM,EAAE,CAAC;IAC/B,eAAe,EAAE,OAAC,CAAC,KAAK,CAAC,OAAC,CAAC,MAAM,EAAE,CAAC;IACpC,eAAe,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACtC,YAAY,EAAE,OAAC,CAAC,OAAO,EAAE;IACzB,QAAQ,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC/B,QAAQ,EAAE,uBAAoB;IAC9B,YAAY,EAAE,OAAC,CAAC,MAAM,EAAE;IACxB,YAAY,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACnC,MAAM,EAAE,qBAAkB;IAC1B,IAAI,EAAE,OAAC,CAAC,OAAO,EAAE;IACjB,MAAM,EAAE,qBAAkB;IAC1B,OAAO,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC9B,UAAU,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE;IAC5C,EAAE,EAAE,OAAC,CAAC,MAAM,EAAE;IACd,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC3B,SAAS,EAAE,OAAC,CAAC,KAAK,CAAC,OAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE;IACzC,UAAU,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACjC,UAAU,EAAE,OAAC,CAAC,MAAM,EAAE;IACtB,UAAU,EAAE,OAAC,CAAC,MAAM,EAAE;IACtB,MAAM,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC7B,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAChC,YAAY,EAAE,OAAC,CAAC,OAAO,EAAE;IACzB,gBAAgB,EAAE,OAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE;IACxC,gBAAgB,EAAE,OAAC,CAAC,MAAM,EAAE;IAC5B,WAAW,EAAE,OAAC,CAAC,MAAM,EAAE;IACvB,aAAa,EAAE,OAAC;SACb,MAAM,CAAC,OAAC,CAAC,MAAM,EAAE,EAAE,OAAC,CAAC,KAAK,CAAC,CAAC,OAAC,CAAC,MAAM,EAAE,EAAE,OAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;SACnD,QAAQ,EAAE;SACV,QAAQ,EAAE;IACb,IAAI,EAAE,OAAC,CAAC,KAAK,CAAC,OAAC,CAAC,MAAM,EAAE,CAAC;IACzB,WAAW,EAAE,OAAC,CAAC,KAAK,CAAC,OAAC,CAAC,OAAO,EAAE,CAAC;CAClC,CAAC,CAAA"}
|
@@ -1,11 +1,11 @@
|
|
1
1
|
/**
|
2
2
|
* Problem:
|
3
3
|
* Freshdesk allows their users to define a custom webhook payload.
|
4
|
-
* This means there's no "standard" webhook payload and it's not possible to define a schema for it.
|
4
|
+
* This means there's no "standard" webhook payload and it's not possible to define a "standard" schema for it.
|
5
5
|
*
|
6
6
|
* Alternative 1:
|
7
7
|
* If a customer wants to use a webhook-based integration with Freshdesk, we register the webhook
|
8
|
-
* in a private extension and define a custom contract
|
8
|
+
* in a private extension and define a custom contract/schema together with the customer and use that instead.
|
9
9
|
*
|
10
10
|
* Alternative 2:
|
11
11
|
* We try to define a schema for the webhook payload that is flexible enough to handle all possible payloads.
|
@@ -0,0 +1 @@
|
|
1
|
+
export declare const MEDPLUM_IDENTIFIER = "https://www.medplum.com/docs/api/fhir/resources/patient";
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../extensions/medplum/constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,kBAAkB,GAC7B,yDAAyD,CAAA"}
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import { type Webhook } from '@awell-health/extensions-core';
|
2
|
+
import { type settings } from '../../settings';
|
3
|
+
import { type Observation } from '@medplum/fhirtypes';
|
4
|
+
declare const dataPoints: {
|
5
|
+
observation: {
|
6
|
+
key: string;
|
7
|
+
valueType: "json";
|
8
|
+
};
|
9
|
+
observationId: {
|
10
|
+
key: string;
|
11
|
+
valueType: "string";
|
12
|
+
};
|
13
|
+
};
|
14
|
+
export declare const observationCreated: Webhook<keyof typeof dataPoints, Observation, typeof settings>;
|
15
|
+
export type ObservationCreated = typeof observationCreated;
|
16
|
+
export {};
|
@@ -0,0 +1,53 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.observationCreated = void 0;
|
4
|
+
const lodash_1 = require("lodash");
|
5
|
+
const constants_1 = require("../../constants");
|
6
|
+
const dataPoints = {
|
7
|
+
observation: {
|
8
|
+
key: 'observation',
|
9
|
+
valueType: 'json',
|
10
|
+
},
|
11
|
+
observationId: {
|
12
|
+
key: 'observationId',
|
13
|
+
valueType: 'string',
|
14
|
+
},
|
15
|
+
};
|
16
|
+
exports.observationCreated = {
|
17
|
+
key: 'observationCreated',
|
18
|
+
dataPoints,
|
19
|
+
onEvent: async ({ payload: { payload, rawBody, headers, settings }, onSuccess, onError, }) => {
|
20
|
+
var _a, _b, _c, _d;
|
21
|
+
const observation = payload;
|
22
|
+
const subject = observation === null || observation === void 0 ? void 0 : observation.subject;
|
23
|
+
const isPatientSubject = (_b = (_a = subject === null || subject === void 0 ? void 0 : subject.reference) === null || _a === void 0 ? void 0 : _a.startsWith('Patient/')) !== null && _b !== void 0 ? _b : false;
|
24
|
+
/**
|
25
|
+
* Observations not attached to a patient don't make much sense to us.
|
26
|
+
* So I'm discarding them.
|
27
|
+
*/
|
28
|
+
if ((0, lodash_1.isNil)(subject) || !isPatientSubject) {
|
29
|
+
await onError({
|
30
|
+
response: {
|
31
|
+
statusCode: 400,
|
32
|
+
message: 'Missing patient subject reference in Observation payload. Only observations attached to a patient are processed.',
|
33
|
+
},
|
34
|
+
});
|
35
|
+
return;
|
36
|
+
}
|
37
|
+
const subjectAsPatient = subject;
|
38
|
+
const patientId = (_c = subjectAsPatient.reference) === null || _c === void 0 ? void 0 : _c.split('/')[1];
|
39
|
+
await onSuccess({
|
40
|
+
data_points: {
|
41
|
+
observation: JSON.stringify(observation),
|
42
|
+
observationId: (_d = observation.id) !== null && _d !== void 0 ? _d : '',
|
43
|
+
},
|
44
|
+
...(!(0, lodash_1.isNil)(patientId) && {
|
45
|
+
patient_identifier: {
|
46
|
+
system: constants_1.MEDPLUM_IDENTIFIER,
|
47
|
+
value: patientId,
|
48
|
+
},
|
49
|
+
}),
|
50
|
+
});
|
51
|
+
},
|
52
|
+
};
|
53
|
+
//# sourceMappingURL=ObservationCreated.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ObservationCreated.js","sourceRoot":"","sources":["../../../../../extensions/medplum/webhooks/ObservationCreated/ObservationCreated.ts"],"names":[],"mappings":";;;AAUA,mCAA8B;AAC9B,+CAAoD;AAEpD,MAAM,UAAU,GAAG;IACjB,WAAW,EAAE;QACX,GAAG,EAAE,aAAa;QAClB,SAAS,EAAE,MAAM;KAClB;IACD,aAAa,EAAE;QACb,GAAG,EAAE,eAAe;QACpB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,kBAAkB,GAI3B;IACF,GAAG,EAAE,oBAAoB;IACzB,UAAU;IACV,OAAO,EAAE,KAAK,EAAE,EACd,OAAO,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,EAChD,SAAS,EACT,OAAO,GACR,EAAE,EAAE;;QACH,MAAM,WAAW,GAAG,OAAO,CAAA;QAC3B,MAAM,OAAO,GAAG,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,OAAO,CAAA;QACpC,MAAM,gBAAgB,GAAG,MAAA,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,SAAS,0CAAE,UAAU,CAAC,UAAU,CAAC,mCAAI,KAAK,CAAA;QAE5E;;;WAGG;QACH,IAAI,IAAA,cAAK,EAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxC,MAAM,OAAO,CAAC;gBACZ,QAAQ,EAAE;oBACR,UAAU,EAAE,GAAG;oBACf,OAAO,EACL,kHAAkH;iBACrH;aACF,CAAC,CAAA;YACF,OAAM;QACR,CAAC;QAED,MAAM,gBAAgB,GAAG,OAA6B,CAAA;QACtD,MAAM,SAAS,GAAG,MAAA,gBAAgB,CAAC,SAAS,0CAAE,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,CAAA;QAE3D,MAAM,SAAS,CAAC;YACd,WAAW,EAAE;gBACX,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;gBACxC,aAAa,EAAE,MAAA,WAAW,CAAC,EAAE,mCAAI,EAAE;aACpC;YACD,GAAG,CAAC,CAAC,IAAA,cAAK,EAAC,SAAS,CAAC,IAAI;gBACvB,kBAAkB,EAAE;oBAClB,MAAM,EAAE,8BAAkB;oBAC1B,KAAK,EAAE,SAAS;iBACjB;aACF,CAAC;SACH,CAAC,CAAA;IACJ,CAAC;CACF,CAAA"}
|
@@ -0,0 +1,28 @@
|
|
1
|
+
export declare const ObservationCreatedPayloadExample: {
|
2
|
+
resourceType: "Observation";
|
3
|
+
status: "final";
|
4
|
+
code: {
|
5
|
+
coding: {
|
6
|
+
system: string;
|
7
|
+
code: string;
|
8
|
+
display: string;
|
9
|
+
}[];
|
10
|
+
};
|
11
|
+
subject: {
|
12
|
+
reference: string;
|
13
|
+
display: string;
|
14
|
+
};
|
15
|
+
id: string;
|
16
|
+
meta: {
|
17
|
+
versionId: string;
|
18
|
+
lastUpdated: string;
|
19
|
+
author: {
|
20
|
+
reference: string;
|
21
|
+
display: string;
|
22
|
+
};
|
23
|
+
project: string;
|
24
|
+
compartment: {
|
25
|
+
reference: string;
|
26
|
+
}[];
|
27
|
+
};
|
28
|
+
};
|
@@ -0,0 +1,39 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.ObservationCreatedPayloadExample = void 0;
|
4
|
+
exports.ObservationCreatedPayloadExample = {
|
5
|
+
resourceType: 'Observation',
|
6
|
+
status: 'final',
|
7
|
+
code: {
|
8
|
+
coding: [
|
9
|
+
{
|
10
|
+
system: 'http://loinc.org',
|
11
|
+
code: '2708-6',
|
12
|
+
display: 'Oxygen saturation in Arterial blood',
|
13
|
+
},
|
14
|
+
],
|
15
|
+
},
|
16
|
+
subject: {
|
17
|
+
reference: 'Patient/9385c25c-1b28-477e-a986-4f8e008caa14',
|
18
|
+
display: 'John Ceena',
|
19
|
+
},
|
20
|
+
id: '0197eafb-19a2-71ad-b368-912ed2ed92fd',
|
21
|
+
meta: {
|
22
|
+
versionId: '0197eafb-19a2-71ad-b368-9584b8ecee5d',
|
23
|
+
lastUpdated: '2025-07-08T17:00:14.114Z',
|
24
|
+
author: {
|
25
|
+
reference: 'Practitioner/f1fe291d-c035-47e3-aaec-613b794f5502',
|
26
|
+
display: 'Nick Hellemans',
|
27
|
+
},
|
28
|
+
project: 'c87cc95a-849d-48b5-9a1c-8a51b66defb7',
|
29
|
+
compartment: [
|
30
|
+
{
|
31
|
+
reference: 'Project/c87cc95a-849d-48b5-9a1c-8a51b66defb7',
|
32
|
+
},
|
33
|
+
{
|
34
|
+
reference: 'Patient/9385c25c-1b28-477e-a986-4f8e008caa14',
|
35
|
+
},
|
36
|
+
],
|
37
|
+
},
|
38
|
+
};
|
39
|
+
//# sourceMappingURL=payloadExample.js.map
|
package/dist/extensions/medplum/webhooks/ObservationCreated/__testdata__/payloadExample.js.map
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"payloadExample.js","sourceRoot":"","sources":["../../../../../../extensions/medplum/webhooks/ObservationCreated/__testdata__/payloadExample.ts"],"names":[],"mappings":";;;AAEa,QAAA,gCAAgC,GAAG;IAC9C,YAAY,EAAE,aAAa;IAC3B,MAAM,EAAE,OAAO;IACf,IAAI,EAAE;QACJ,MAAM,EAAE;YACN;gBACE,MAAM,EAAE,kBAAkB;gBAC1B,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,qCAAqC;aAC/C;SACF;KACF;IACD,OAAO,EAAE;QACP,SAAS,EAAE,8CAA8C;QACzD,OAAO,EAAE,YAAY;KACtB;IACD,EAAE,EAAE,sCAAsC;IAC1C,IAAI,EAAE;QACJ,SAAS,EAAE,sCAAsC;QACjD,WAAW,EAAE,0BAA0B;QACvC,MAAM,EAAE;YACN,SAAS,EAAE,mDAAmD;YAC9D,OAAO,EAAE,gBAAgB;SAC1B;QACD,OAAO,EAAE,sCAAsC;QAC/C,WAAW,EAAE;YACX;gBACE,SAAS,EAAE,8CAA8C;aAC1D;YACD;gBACE,SAAS,EAAE,8CAA8C;aAC1D;SACF;KACF;CACoB,CAAA"}
|
@@ -0,0 +1 @@
|
|
1
|
+
export * from './ObservationCreated';
|
@@ -0,0 +1,18 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
|
+
};
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
+
__exportStar(require("./ObservationCreated"), exports);
|
18
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../extensions/medplum/webhooks/ObservationCreated/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uDAAoC"}
|
@@ -1 +1,23 @@
|
|
1
|
-
export declare const webhooks: import("@awell-health/extensions-core").Webhook<"patientId", import("@medplum/fhirtypes").Patient, Record<string, import("@awell-health/extensions-core").Setting>>
|
1
|
+
export declare const webhooks: (import("@awell-health/extensions-core").Webhook<"patientId", import("@medplum/fhirtypes").Patient, Record<string, import("@awell-health/extensions-core").Setting>> | import("@awell-health/extensions-core").Webhook<"observationId" | "observation", import("@medplum/fhirtypes").Observation, {
|
2
|
+
clientId: {
|
3
|
+
key: string;
|
4
|
+
label: string;
|
5
|
+
obfuscated: true;
|
6
|
+
required: true;
|
7
|
+
description: string;
|
8
|
+
};
|
9
|
+
clientSecret: {
|
10
|
+
key: string;
|
11
|
+
label: string;
|
12
|
+
obfuscated: true;
|
13
|
+
required: true;
|
14
|
+
description: string;
|
15
|
+
};
|
16
|
+
baseUrl: {
|
17
|
+
key: string;
|
18
|
+
label: string;
|
19
|
+
obfuscated: false;
|
20
|
+
required: false;
|
21
|
+
description: string;
|
22
|
+
};
|
23
|
+
}>)[];
|
@@ -2,5 +2,6 @@
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.webhooks = void 0;
|
4
4
|
const patientCreated_1 = require("./patientCreated");
|
5
|
-
|
5
|
+
const ObservationCreated_1 = require("./ObservationCreated/ObservationCreated");
|
6
|
+
exports.webhooks = [patientCreated_1.patientCreated, ObservationCreated_1.observationCreated];
|
6
7
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../extensions/medplum/webhooks/index.ts"],"names":[],"mappings":";;;AAAA,qDAAiD;
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../extensions/medplum/webhooks/index.ts"],"names":[],"mappings":";;;AAAA,qDAAiD;AACjD,gFAA4E;AAE/D,QAAA,QAAQ,GAAG,CAAC,+BAAc,EAAE,uCAAkB,CAAC,CAAA"}
|