@awell-health/awell-extensions 1.1.43 → 1.1.44

Sign up to get free protection for your applications and to get access to all the features.
Files changed (184) hide show
  1. package/dist/extensions/athenahealth/actions/index.d.ts +1 -1
  2. package/dist/extensions/athenahealth/settings.d.ts +2 -2
  3. package/dist/extensions/awell/v1/actions/updatePatient/config/fields.d.ts +2 -2
  4. package/dist/extensions/awell/v1/webhooks/index.d.ts +1 -1
  5. package/dist/extensions/awell/v1/webhooks/pathwayStart.d.ts +3 -1
  6. package/dist/extensions/awell/v1/webhooks/pathwayStart.js +13 -3
  7. package/dist/extensions/awell/v1/webhooks/pathwayStart.js.map +1 -1
  8. package/dist/extensions/calDotCom/actions/createBooking/config/fields.d.ts +12 -12
  9. package/dist/extensions/calDotCom/actions/updateBooking/config/fields.d.ts +6 -6
  10. package/dist/extensions/calDotCom/schema.d.ts +70 -70
  11. package/dist/extensions/calDotCom/webhooks/index.d.ts +1 -1
  12. package/dist/extensions/calendly/schema.d.ts +262 -262
  13. package/dist/extensions/calendly/webhooks/index.d.ts +1 -1
  14. package/dist/extensions/canvasMedical/v1/actions/createClaim/config/fields.d.ts +2 -2
  15. package/dist/extensions/canvasMedical/v1/actions/createCoverage/config/fields.d.ts +2 -2
  16. package/dist/extensions/canvasMedical/v1/actions/createQuestionnaireResponses/config/fields.d.ts +2 -2
  17. package/dist/extensions/canvasMedical/v1/actions/updateCoverage/config/fields.d.ts +4 -4
  18. package/dist/extensions/canvasMedical/v1/validation/address.zod.d.ts +4 -4
  19. package/dist/extensions/canvasMedical/v1/validation/appointment.zod.d.ts +48 -48
  20. package/dist/extensions/canvasMedical/v1/validation/claim.d.ts +6 -6
  21. package/dist/extensions/canvasMedical/v1/validation/coding.zod.d.ts +2 -2
  22. package/dist/extensions/canvasMedical/v1/validation/coverage.zod.d.ts +6 -6
  23. package/dist/extensions/canvasMedical/v1/validation/identifier.zod.d.ts +8 -8
  24. package/dist/extensions/canvasMedical/v1/validation/patient.zod.d.ts +148 -148
  25. package/dist/extensions/canvasMedical/v1/validation/questionnaireResponses.zod.d.ts +30 -30
  26. package/dist/extensions/canvasMedical/v1/validation/settings.zod.d.ts +4 -4
  27. package/dist/extensions/canvasMedical/v1/validation/task.zod.d.ts +12 -12
  28. package/dist/extensions/collectData/v1/actions/remoteSingleSelect/config/fields.d.ts +2 -2
  29. package/dist/extensions/dockHealth/api/schema/atoms/patientReference.schema.d.ts +2 -2
  30. package/dist/extensions/dockHealth/api/schema/atoms/taskGroup.schema.d.ts +2 -2
  31. package/dist/extensions/dockHealth/api/schema/atoms/taskListReference.schema.d.ts +2 -2
  32. package/dist/extensions/dockHealth/api/schema/atoms/taskReference.schema.d.ts +2 -2
  33. package/dist/extensions/dockHealth/api/schema/atoms/taskWorkflowStatusReference.schema.d.ts +2 -2
  34. package/dist/extensions/dockHealth/api/schema/atoms/userReference.schema.d.ts +2 -2
  35. package/dist/extensions/dockHealth/api/schema/patient.schema.d.ts +10 -10
  36. package/dist/extensions/dockHealth/api/schema/task.schema.d.ts +77 -77
  37. package/dist/extensions/dockHealth/lib/dock.types.d.ts +2 -2
  38. package/dist/extensions/elation/actions/index.d.ts +2 -2
  39. package/dist/extensions/elation/validation/appointment.zod.d.ts +18 -18
  40. package/dist/extensions/elation/validation/labOrder.zod.d.ts +2 -2
  41. package/dist/extensions/elation/validation/nonVisitNote.zod.d.ts +6 -6
  42. package/dist/extensions/elation/validation/patient.zod.d.ts +116 -116
  43. package/dist/extensions/elation/validation/physician.zod.d.ts +2 -2
  44. package/dist/extensions/elation/validation/settings.zod.d.ts +6 -6
  45. package/dist/extensions/elation/webhooks/index.d.ts +1 -1
  46. package/dist/extensions/formsort/settings.d.ts +3 -3
  47. package/dist/extensions/healthie/lib/helpers.d.ts +8 -0
  48. package/dist/extensions/healthie/lib/helpers.js +6 -1
  49. package/dist/extensions/healthie/lib/helpers.js.map +1 -1
  50. package/dist/extensions/healthie/lib/sdk/createSdk.d.ts +10 -0
  51. package/dist/extensions/healthie/lib/sdk/createSdk.js +17 -0
  52. package/dist/extensions/healthie/lib/sdk/createSdk.js.map +1 -0
  53. package/dist/extensions/healthie/lib/sdk/errors.d.ts +1 -0
  54. package/dist/extensions/healthie/lib/sdk/errors.js +46 -1
  55. package/dist/extensions/healthie/lib/sdk/errors.js.map +1 -1
  56. package/dist/extensions/healthie/lib/sdk/generated/sdk.d.ts +373 -9
  57. package/dist/extensions/healthie/lib/sdk/generated/sdk.js +110 -3
  58. package/dist/extensions/healthie/lib/sdk/generated/sdk.js.map +1 -1
  59. package/dist/extensions/healthie/lib/sdk/validatePayloadAndCreateSdk.js.map +1 -1
  60. package/dist/extensions/healthie/lib/types.d.ts +2 -1
  61. package/dist/extensions/healthie/lib/types.js +2 -0
  62. package/dist/extensions/healthie/lib/types.js.map +1 -1
  63. package/dist/extensions/healthie/lib/validation/createTask.zod.d.ts +1 -1
  64. package/dist/extensions/healthie/lib/validation/sendFormCompletionRequest.zod.d.ts +4 -4
  65. package/dist/extensions/healthie/webhooks/appliedTagCreated.d.ts +2 -1
  66. package/dist/extensions/healthie/webhooks/appliedTagCreated.js +20 -7
  67. package/dist/extensions/healthie/webhooks/appliedTagCreated.js.map +1 -1
  68. package/dist/extensions/healthie/webhooks/appliedTagDeleted.d.ts +2 -1
  69. package/dist/extensions/healthie/webhooks/appliedTagDeleted.js +20 -7
  70. package/dist/extensions/healthie/webhooks/appliedTagDeleted.js.map +1 -1
  71. package/dist/extensions/healthie/webhooks/appointmentCreated.d.ts +6 -1
  72. package/dist/extensions/healthie/webhooks/appointmentCreated.js +26 -6
  73. package/dist/extensions/healthie/webhooks/appointmentCreated.js.map +1 -1
  74. package/dist/extensions/healthie/webhooks/appointmentCreated.test.d.ts +1 -0
  75. package/dist/extensions/healthie/webhooks/appointmentCreated.test.js +61 -0
  76. package/dist/extensions/healthie/webhooks/appointmentCreated.test.js.map +1 -0
  77. package/dist/extensions/healthie/webhooks/appointmentDeleted.d.ts +2 -1
  78. package/dist/extensions/healthie/webhooks/appointmentDeleted.js +22 -6
  79. package/dist/extensions/healthie/webhooks/appointmentDeleted.js.map +1 -1
  80. package/dist/extensions/healthie/webhooks/appointmentUpdated.d.ts +6 -1
  81. package/dist/extensions/healthie/webhooks/appointmentUpdated.js +26 -6
  82. package/dist/extensions/healthie/webhooks/appointmentUpdated.js.map +1 -1
  83. package/dist/extensions/healthie/webhooks/formAnswerGroupCreated.d.ts +6 -1
  84. package/dist/extensions/healthie/webhooks/formAnswerGroupCreated.js +27 -7
  85. package/dist/extensions/healthie/webhooks/formAnswerGroupCreated.js.map +1 -1
  86. package/dist/extensions/healthie/webhooks/formAnswerGroupDeleted.d.ts +2 -1
  87. package/dist/extensions/healthie/webhooks/formAnswerGroupDeleted.js +21 -6
  88. package/dist/extensions/healthie/webhooks/formAnswerGroupDeleted.js.map +1 -1
  89. package/dist/extensions/healthie/webhooks/formAnswerGroupLocked.d.ts +6 -1
  90. package/dist/extensions/healthie/webhooks/formAnswerGroupLocked.js +26 -6
  91. package/dist/extensions/healthie/webhooks/formAnswerGroupLocked.js.map +1 -1
  92. package/dist/extensions/healthie/webhooks/formAnswerGroupSigned.d.ts +6 -1
  93. package/dist/extensions/healthie/webhooks/formAnswerGroupSigned.js +26 -6
  94. package/dist/extensions/healthie/webhooks/formAnswerGroupSigned.js.map +1 -1
  95. package/dist/extensions/healthie/webhooks/goalCreated.d.ts +3 -2
  96. package/dist/extensions/healthie/webhooks/goalCreated.js +22 -9
  97. package/dist/extensions/healthie/webhooks/goalCreated.js.map +1 -1
  98. package/dist/extensions/healthie/webhooks/goalCreated.test.d.ts +1 -0
  99. package/dist/extensions/healthie/webhooks/goalCreated.test.js +35 -0
  100. package/dist/extensions/healthie/webhooks/goalCreated.test.js.map +1 -0
  101. package/dist/extensions/healthie/webhooks/goalUpdated.d.ts +2 -1
  102. package/dist/extensions/healthie/webhooks/goalUpdated.js +21 -8
  103. package/dist/extensions/healthie/webhooks/goalUpdated.js.map +1 -1
  104. package/dist/extensions/healthie/webhooks/index.d.ts +316 -5
  105. package/dist/extensions/healthie/webhooks/index.js +0 -8
  106. package/dist/extensions/healthie/webhooks/index.js.map +1 -1
  107. package/dist/extensions/healthie/webhooks/labOrderCreated.d.ts +2 -1
  108. package/dist/extensions/healthie/webhooks/labOrderCreated.js +20 -7
  109. package/dist/extensions/healthie/webhooks/labOrderCreated.js.map +1 -1
  110. package/dist/extensions/healthie/webhooks/labOrderUpdated.d.ts +2 -1
  111. package/dist/extensions/healthie/webhooks/labOrderUpdated.js +20 -7
  112. package/dist/extensions/healthie/webhooks/labOrderUpdated.js.map +1 -1
  113. package/dist/extensions/healthie/webhooks/messageCreated.d.ts +2 -1
  114. package/dist/extensions/healthie/webhooks/messageCreated.js +21 -7
  115. package/dist/extensions/healthie/webhooks/messageCreated.js.map +1 -1
  116. package/dist/extensions/healthie/webhooks/messageDeleted.d.ts +2 -1
  117. package/dist/extensions/healthie/webhooks/messageDeleted.js +21 -7
  118. package/dist/extensions/healthie/webhooks/messageDeleted.js.map +1 -1
  119. package/dist/extensions/healthie/webhooks/metricEntryCreated.d.ts +2 -1
  120. package/dist/extensions/healthie/webhooks/metricEntryCreated.js +20 -7
  121. package/dist/extensions/healthie/webhooks/metricEntryCreated.js.map +1 -1
  122. package/dist/extensions/healthie/webhooks/metricEntryUpdated.d.ts +2 -1
  123. package/dist/extensions/healthie/webhooks/metricEntryUpdated.js +20 -7
  124. package/dist/extensions/healthie/webhooks/metricEntryUpdated.js.map +1 -1
  125. package/dist/extensions/healthie/webhooks/patientCreated.js +8 -1
  126. package/dist/extensions/healthie/webhooks/patientCreated.js.map +1 -1
  127. package/dist/extensions/healthie/webhooks/patientUpdated.js +8 -1
  128. package/dist/extensions/healthie/webhooks/patientUpdated.js.map +1 -1
  129. package/dist/extensions/healthie/webhooks/requestedFormCompletionCreated.d.ts +2 -1
  130. package/dist/extensions/healthie/webhooks/requestedFormCompletionCreated.js +20 -7
  131. package/dist/extensions/healthie/webhooks/requestedFormCompletionCreated.js.map +1 -1
  132. package/dist/extensions/healthie/webhooks/requestedFormCompletionUpdated.d.ts +2 -1
  133. package/dist/extensions/healthie/webhooks/requestedFormCompletionUpdated.js +20 -7
  134. package/dist/extensions/healthie/webhooks/requestedFormCompletionUpdated.js.map +1 -1
  135. package/dist/extensions/healthie/webhooks/taskCreated.d.ts +2 -1
  136. package/dist/extensions/healthie/webhooks/taskCreated.js +20 -7
  137. package/dist/extensions/healthie/webhooks/taskCreated.js.map +1 -1
  138. package/dist/extensions/healthie/webhooks/taskUpdated.d.ts +2 -1
  139. package/dist/extensions/healthie/webhooks/taskUpdated.js +21 -8
  140. package/dist/extensions/healthie/webhooks/taskUpdated.js.map +1 -1
  141. package/dist/extensions/hello-world/webhooks/index.d.ts +1 -1
  142. package/dist/extensions/infobip/v1/actions/sendEmail/config/fields.d.ts +2 -2
  143. package/dist/extensions/mailgun/settings.d.ts +1 -1
  144. package/dist/extensions/mailgun/v1/actions/sendEmailWithTemplate/config/fields.d.ts +2 -2
  145. package/dist/extensions/math/v1/actions/calculateDateDifference/config/fields.d.ts +2 -2
  146. package/dist/extensions/math/v1/actions/generateRandomNumber/config/fields.d.ts +2 -2
  147. package/dist/extensions/medplum/actions/createPatient/config/fields.d.ts +4 -4
  148. package/dist/extensions/medplum/actions/createServiceRequest/config/fields.d.ts +4 -4
  149. package/dist/extensions/medplum/actions/createTask/config/fields.d.ts +6 -6
  150. package/dist/extensions/medplum/fhir/schemas/atoms/PeriodSchema.d.ts +2 -2
  151. package/dist/extensions/medplum/fhir/schemas/resources/patient.schema.d.ts +4 -4
  152. package/dist/extensions/medplum/fhir/schemas/resources/serviceRequest.schema.d.ts +4 -4
  153. package/dist/extensions/medplum/fhir/schemas/resources/task.schema.d.ts +6 -6
  154. package/dist/extensions/metriport/actions/index.d.ts +1 -1
  155. package/dist/extensions/metriport/actions/patient/validation.d.ts +4 -4
  156. package/dist/extensions/stripe/actions/createCustomer/config/fields.d.ts +2 -2
  157. package/dist/extensions/stripe/actions/embeddedCheckout/config/fields.d.ts +2 -2
  158. package/dist/extensions/talkDesk/settings.d.ts +1 -1
  159. package/dist/extensions/textline/client/schema.d.ts +10 -10
  160. package/dist/extensions/westFax/actions/sendFax/sendFax.test.js +13 -3
  161. package/dist/extensions/westFax/actions/sendFax/sendFax.test.js.map +1 -1
  162. package/dist/extensions/westFax/settings.d.ts +2 -2
  163. package/dist/extensions/zendesk/v1/actions/createTask/config/fields.d.ts +2 -2
  164. package/dist/extensions/zusHealth/validation/settings.zod.d.ts +6 -6
  165. package/dist/extensions/zusHealth/webhooks/index.d.ts +37 -1
  166. package/dist/extensions/zusHealth/webhooks/patientAdmitted.d.ts +2 -1
  167. package/dist/extensions/zusHealth/webhooks/patientAdmitted.js.map +1 -1
  168. package/dist/extensions/zusHealth/webhooks/patientDischarged.d.ts +2 -1
  169. package/dist/extensions/zusHealth/webhooks/patientDischarged.js.map +1 -1
  170. package/dist/src/test-server.js +4 -0
  171. package/dist/src/test-server.js.map +1 -1
  172. package/package.json +4 -3
  173. package/dist/extensions/healthie/webhooks/goalDeleted.d.ts +0 -11
  174. package/dist/extensions/healthie/webhooks/goalDeleted.js +0 -30
  175. package/dist/extensions/healthie/webhooks/goalDeleted.js.map +0 -1
  176. package/dist/extensions/healthie/webhooks/metricEntryDeleted.d.ts +0 -11
  177. package/dist/extensions/healthie/webhooks/metricEntryDeleted.js +0 -30
  178. package/dist/extensions/healthie/webhooks/metricEntryDeleted.js.map +0 -1
  179. package/dist/extensions/healthie/webhooks/requestedFormCompletionDeleted.d.ts +0 -11
  180. package/dist/extensions/healthie/webhooks/requestedFormCompletionDeleted.js +0 -30
  181. package/dist/extensions/healthie/webhooks/requestedFormCompletionDeleted.js.map +0 -1
  182. package/dist/extensions/healthie/webhooks/taskDeleted.d.ts +0 -11
  183. package/dist/extensions/healthie/webhooks/taskDeleted.js +0 -30
  184. package/dist/extensions/healthie/webhooks/taskDeleted.js.map +0 -1
@@ -2,6 +2,10 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.messageCreated = void 0;
4
4
  const lodash_1 = require("lodash");
5
+ const types_1 = require("../lib/types");
6
+ const errors_1 = require("../lib/sdk/errors");
7
+ const createSdk_1 = require("../lib/sdk/createSdk");
8
+ const helpers_1 = require("../lib/helpers");
5
9
  const dataPoints = {
6
10
  createdMessageId: {
7
11
  key: 'createdMessageId',
@@ -12,19 +16,29 @@ exports.messageCreated = {
12
16
  key: 'messageCreated',
13
17
  dataPoints,
14
18
  onWebhookReceived: async ({ payload, settings }, onSuccess, onError) => {
15
- const { resource_id: createdMessageId } = payload;
16
- if ((0, lodash_1.isNil)(createdMessageId)) {
17
- await onError({
18
- // We should automatically send a 400 here, so no need to provide info
19
- });
20
- }
21
- else {
19
+ var _a, _b, _c, _d;
20
+ try {
21
+ const { sdk } = await (0, createSdk_1.createSdk)({ settings });
22
+ const validatedPayload = helpers_1.webhookPayloadSchema.parse(payload);
23
+ const createdMessageId = validatedPayload.resource_id.toString();
24
+ const messageResponse = await sdk.getMessage({ id: createdMessageId });
25
+ const conversationResponse = await sdk.getConversation({ id: (_b = (_a = messageResponse === null || messageResponse === void 0 ? void 0 : messageResponse.data) === null || _a === void 0 ? void 0 : _a.note) === null || _b === void 0 ? void 0 : _b.conversation_id });
26
+ const healthiePatientId = (_d = (_c = conversationResponse === null || conversationResponse === void 0 ? void 0 : conversationResponse.data) === null || _c === void 0 ? void 0 : _c.conversation) === null || _d === void 0 ? void 0 : _d.patient_id;
22
27
  await onSuccess({
23
28
  data_points: {
24
29
  createdMessageId,
25
30
  },
31
+ ...(!(0, lodash_1.isNil)(healthiePatientId) && {
32
+ patient_identifier: {
33
+ system: types_1.HEALTHIE_IDENTIFIER,
34
+ value: healthiePatientId,
35
+ }
36
+ })
26
37
  });
27
38
  }
39
+ catch (error) {
40
+ await onError((0, errors_1.formatError)(error));
41
+ }
28
42
  },
29
43
  };
30
44
  //# sourceMappingURL=messageCreated.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"messageCreated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/messageCreated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAO9B,MAAM,UAAU,GAAG;IACjB,gBAAgB,EAAE;QAChB,GAAG,EAAE,kBAAkB;QACvB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,cAAc,GAGvB;IACF,GAAG,EAAE,gBAAgB;IACrB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;QACrE,MAAM,EAAE,WAAW,EAAE,gBAAgB,EAAE,GAAG,OAAO,CAAA;QAEjD,IAAI,IAAA,cAAK,EAAC,gBAAgB,CAAC,EAAE;YAC3B,MAAM,OAAO,CAAC;YACZ,sEAAsE;aACvE,CAAC,CAAA;SACH;aAAM;YACL,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,gBAAgB;iBACjB;aACF,CAAC,CAAA;SACH;IACH,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"messageCreated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/messageCreated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAK9B,wCAA+E;AAE/E,8CAA+C;AAC/C,oDAAgD;AAChD,4CAAqD;AAErD,MAAM,UAAU,GAAG;IACjB,gBAAgB,EAAE;QAChB,GAAG,EAAE,kBAAkB;QACvB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,cAAc,GAIvB;IACF,GAAG,EAAE,gBAAgB;IACrB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;;QACrE,IAAI;YACF,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,IAAA,qBAAS,EAAC,EAAE,QAAQ,EAAE,CAAC,CAAA;YAE7C,MAAM,gBAAgB,GAAG,8BAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YAC5D,MAAM,gBAAgB,GAAG,gBAAgB,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAA;YAEhE,MAAM,eAAe,GAAG,MAAM,GAAG,CAAC,UAAU,CAAC,EAAE,EAAE,EAAE,gBAAgB,EAAE,CAAC,CAAA;YACtE,MAAM,oBAAoB,GAAG,MAAM,GAAG,CAAC,eAAe,CAAC,EAAE,EAAE,EAAE,MAAA,MAAA,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAE,IAAI,0CAAE,IAAI,0CAAE,eAAe,EAAE,CAAC,CAAA;YAC5G,MAAM,iBAAiB,GAAG,MAAA,MAAA,oBAAoB,aAApB,oBAAoB,uBAApB,oBAAoB,CAAE,IAAI,0CAAE,YAAY,0CAAE,UAAU,CAAA;YAC9E,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,gBAAgB;iBACjB;gBACD,GAAG,CAAC,CAAC,IAAA,cAAK,EAAC,iBAAiB,CAAC,IAAI;oBAC/B,kBAAkB,EAAE;wBAClB,MAAM,EAAE,2BAAmB;wBAC3B,KAAK,EAAE,iBAAiB;qBACzB;iBACF,CAAC;aACH,CAAC,CAAA;SACH;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,OAAO,CAAC,IAAA,oBAAW,EAAC,KAAK,CAAC,CAAC,CAAA;SAClC;IACH,CAAC;CACF,CAAA"}
@@ -1,11 +1,12 @@
1
1
  import { type Webhook } from '@awell-health/extensions-core';
2
2
  import { type HealthieWebhookPayload } from '../lib/types';
3
+ import { type settings } from '../settings';
3
4
  declare const dataPoints: {
4
5
  deletedMessageId: {
5
6
  key: string;
6
7
  valueType: "string";
7
8
  };
8
9
  };
9
- export declare const messageDeleted: Webhook<keyof typeof dataPoints, HealthieWebhookPayload>;
10
+ export declare const messageDeleted: Webhook<keyof typeof dataPoints, HealthieWebhookPayload, typeof settings>;
10
11
  export type MessageDeleted = typeof messageDeleted;
11
12
  export {};
@@ -2,6 +2,10 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.messageDeleted = void 0;
4
4
  const lodash_1 = require("lodash");
5
+ const types_1 = require("../lib/types");
6
+ const errors_1 = require("../lib/sdk/errors");
7
+ const createSdk_1 = require("../lib/sdk/createSdk");
8
+ const helpers_1 = require("../lib/helpers");
5
9
  const dataPoints = {
6
10
  deletedMessageId: {
7
11
  key: 'deletedMessageId',
@@ -12,19 +16,29 @@ exports.messageDeleted = {
12
16
  key: 'messageDeleted',
13
17
  dataPoints,
14
18
  onWebhookReceived: async ({ payload, settings }, onSuccess, onError) => {
15
- const { resource_id: deletedMessageId } = payload;
16
- if ((0, lodash_1.isNil)(deletedMessageId)) {
17
- await onError({
18
- // We should automatically send a 400 here, so no need to provide info
19
- });
20
- }
21
- else {
19
+ var _a, _b, _c, _d;
20
+ try {
21
+ const { sdk } = await (0, createSdk_1.createSdk)({ settings });
22
+ const validatedPayload = helpers_1.webhookPayloadSchema.parse(payload);
23
+ const deletedMessageId = validatedPayload.resource_id.toString();
24
+ const messageResponse = await sdk.getMessage({ id: deletedMessageId });
25
+ const conversationResponse = await sdk.getConversation({ id: (_b = (_a = messageResponse === null || messageResponse === void 0 ? void 0 : messageResponse.data) === null || _a === void 0 ? void 0 : _a.note) === null || _b === void 0 ? void 0 : _b.conversation_id });
26
+ const healthiePatientId = (_d = (_c = conversationResponse === null || conversationResponse === void 0 ? void 0 : conversationResponse.data) === null || _c === void 0 ? void 0 : _c.conversation) === null || _d === void 0 ? void 0 : _d.patient_id;
22
27
  await onSuccess({
23
28
  data_points: {
24
29
  deletedMessageId,
25
30
  },
31
+ ...(!(0, lodash_1.isNil)(healthiePatientId) && {
32
+ patient_identifier: {
33
+ system: types_1.HEALTHIE_IDENTIFIER,
34
+ value: healthiePatientId,
35
+ }
36
+ }),
26
37
  });
27
38
  }
39
+ catch (error) {
40
+ await onError((0, errors_1.formatError)(error));
41
+ }
28
42
  },
29
43
  };
30
44
  //# sourceMappingURL=messageDeleted.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"messageDeleted.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/messageDeleted.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAO9B,MAAM,UAAU,GAAG;IACjB,gBAAgB,EAAE;QAChB,GAAG,EAAE,kBAAkB;QACvB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,cAAc,GAGvB;IACF,GAAG,EAAE,gBAAgB;IACrB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;QACrE,MAAM,EAAE,WAAW,EAAE,gBAAgB,EAAE,GAAG,OAAO,CAAA;QAEjD,IAAI,IAAA,cAAK,EAAC,gBAAgB,CAAC,EAAE;YAC3B,MAAM,OAAO,CAAC;YACZ,sEAAsE;aACvE,CAAC,CAAA;SACH;aAAM;YACL,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,gBAAgB;iBACjB;aACF,CAAC,CAAA;SACH;IACH,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"messageDeleted.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/messageDeleted.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAK9B,wCAA+E;AAE/E,8CAA+C;AAC/C,oDAAgD;AAChD,4CAAqD;AAErD,MAAM,UAAU,GAAG;IACjB,gBAAgB,EAAE;QAChB,GAAG,EAAE,kBAAkB;QACvB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,cAAc,GAIvB;IACF,GAAG,EAAE,gBAAgB;IACrB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;;QACrE,IAAI;YACF,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,IAAA,qBAAS,EAAC,EAAE,QAAQ,EAAE,CAAC,CAAA;YAE7C,MAAM,gBAAgB,GAAG,8BAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YAC5D,MAAM,gBAAgB,GAAG,gBAAgB,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAA;YAEhE,MAAM,eAAe,GAAG,MAAM,GAAG,CAAC,UAAU,CAAC,EAAE,EAAE,EAAE,gBAAgB,EAAE,CAAC,CAAA;YACtE,MAAM,oBAAoB,GAAG,MAAM,GAAG,CAAC,eAAe,CAAC,EAAE,EAAE,EAAE,MAAA,MAAA,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAE,IAAI,0CAAE,IAAI,0CAAE,eAAe,EAAE,CAAC,CAAA;YAC5G,MAAM,iBAAiB,GAAG,MAAA,MAAA,oBAAoB,aAApB,oBAAoB,uBAApB,oBAAoB,CAAE,IAAI,0CAAE,YAAY,0CAAE,UAAU,CAAA;YAC9E,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,gBAAgB;iBACjB;gBACD,GAAG,CAAC,CAAC,IAAA,cAAK,EAAC,iBAAiB,CAAC,IAAI;oBAC/B,kBAAkB,EAAE;wBAClB,MAAM,EAAE,2BAAmB;wBAC3B,KAAK,EAAE,iBAAiB;qBACzB;iBACF,CAAC;aACH,CAAC,CAAA;SACH;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,OAAO,CAAC,IAAA,oBAAW,EAAC,KAAK,CAAC,CAAC,CAAA;SAClC;IACH,CAAC;CACF,CAAA"}
@@ -1,11 +1,12 @@
1
1
  import { type Webhook } from '@awell-health/extensions-core';
2
2
  import { type HealthieWebhookPayload } from '../lib/types';
3
+ import { type settings } from '../settings';
3
4
  declare const dataPoints: {
4
5
  createdMetricId: {
5
6
  key: string;
6
7
  valueType: "string";
7
8
  };
8
9
  };
9
- export declare const metricEntryCreated: Webhook<keyof typeof dataPoints, HealthieWebhookPayload>;
10
+ export declare const metricEntryCreated: Webhook<keyof typeof dataPoints, HealthieWebhookPayload, typeof settings>;
10
11
  export type MetricEntryCreated = typeof metricEntryCreated;
11
12
  export {};
@@ -2,6 +2,10 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.metricEntryCreated = void 0;
4
4
  const lodash_1 = require("lodash");
5
+ const types_1 = require("../lib/types");
6
+ const errors_1 = require("../lib/sdk/errors");
7
+ const createSdk_1 = require("../lib/sdk/createSdk");
8
+ const helpers_1 = require("../lib/helpers");
5
9
  const dataPoints = {
6
10
  createdMetricId: {
7
11
  key: 'createdMetricId',
@@ -12,19 +16,28 @@ exports.metricEntryCreated = {
12
16
  key: 'metricEntryCreated',
13
17
  dataPoints,
14
18
  onWebhookReceived: async ({ payload, settings }, onSuccess, onError) => {
15
- const { resource_id: createdMetricId } = payload;
16
- if ((0, lodash_1.isNil)(createdMetricId)) {
17
- await onError({
18
- // We should automatically send a 400 here, so no need to provide info
19
- });
20
- }
21
- else {
19
+ var _a, _b, _c;
20
+ try {
21
+ const { sdk } = await (0, createSdk_1.createSdk)({ settings });
22
+ const validatedPayload = helpers_1.webhookPayloadSchema.parse(payload);
23
+ const createdMetricId = validatedPayload.resource_id.toString();
24
+ const response = await sdk.getMetricEntry({ id: createdMetricId });
25
+ const healthiePatientId = (_c = (_b = (_a = response === null || response === void 0 ? void 0 : response.data) === null || _a === void 0 ? void 0 : _a.entry) === null || _b === void 0 ? void 0 : _b.poster) === null || _c === void 0 ? void 0 : _c.id;
22
26
  await onSuccess({
23
27
  data_points: {
24
28
  createdMetricId,
25
29
  },
30
+ ...(!(0, lodash_1.isNil)(healthiePatientId) && {
31
+ patient_identifier: {
32
+ system: types_1.HEALTHIE_IDENTIFIER,
33
+ value: healthiePatientId,
34
+ },
35
+ }),
26
36
  });
27
37
  }
38
+ catch (error) {
39
+ await onError((0, errors_1.formatError)(error));
40
+ }
28
41
  },
29
42
  };
30
43
  //# sourceMappingURL=metricEntryCreated.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"metricEntryCreated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/metricEntryCreated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAO9B,MAAM,UAAU,GAAG;IACjB,eAAe,EAAE;QACf,GAAG,EAAE,iBAAiB;QACtB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,kBAAkB,GAG3B;IACF,GAAG,EAAE,oBAAoB;IACzB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;QACrE,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,OAAO,CAAA;QAEhD,IAAI,IAAA,cAAK,EAAC,eAAe,CAAC,EAAE;YAC1B,MAAM,OAAO,CAAC;YACZ,sEAAsE;aACvE,CAAC,CAAA;SACH;aAAM;YACL,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,eAAe;iBAChB;aACF,CAAC,CAAA;SACH;IACH,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"metricEntryCreated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/metricEntryCreated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAK9B,wCAA+E;AAE/E,8CAA+C;AAC/C,oDAAgD;AAChD,4CAAqD;AAErD,MAAM,UAAU,GAAG;IACjB,eAAe,EAAE;QACf,GAAG,EAAE,iBAAiB;QACtB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,kBAAkB,GAI3B;IACF,GAAG,EAAE,oBAAoB;IACzB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;;QACrE,IAAI;YACF,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,IAAA,qBAAS,EAAC,EAAE,QAAQ,EAAE,CAAC,CAAA;YAE7C,MAAM,gBAAgB,GAAG,8BAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YAC5D,MAAM,eAAe,GAAG,gBAAgB,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAA;YAE/D,MAAM,QAAQ,GAAG,MAAM,GAAG,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,eAAe,EAAE,CAAC,CAAA;YAClE,MAAM,iBAAiB,GAAG,MAAA,MAAA,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,IAAI,0CAAE,KAAK,0CAAE,MAAM,0CAAE,EAAE,CAAA;YAC3D,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,eAAe;iBAChB;gBACD,GAAG,CAAC,CAAC,IAAA,cAAK,EAAC,iBAAiB,CAAC,IAAI;oBAC/B,kBAAkB,EAAE;wBAClB,MAAM,EAAE,2BAAmB;wBAC3B,KAAK,EAAE,iBAAiB;qBACzB;iBACF,CAAC;aACH,CAAC,CAAA;SACH;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,OAAO,CAAC,IAAA,oBAAW,EAAC,KAAK,CAAC,CAAC,CAAA;SAClC;IACH,CAAC;CACF,CAAA"}
@@ -1,11 +1,12 @@
1
1
  import { type Webhook } from '@awell-health/extensions-core';
2
2
  import { type HealthieWebhookPayload } from '../lib/types';
3
+ import { type settings } from '../settings';
3
4
  declare const dataPoints: {
4
5
  updatedMetricId: {
5
6
  key: string;
6
7
  valueType: "string";
7
8
  };
8
9
  };
9
- export declare const metricEntryUpdated: Webhook<keyof typeof dataPoints, HealthieWebhookPayload>;
10
+ export declare const metricEntryUpdated: Webhook<keyof typeof dataPoints, HealthieWebhookPayload, typeof settings>;
10
11
  export type MetricEntryUpdated = typeof metricEntryUpdated;
11
12
  export {};
@@ -2,6 +2,10 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.metricEntryUpdated = void 0;
4
4
  const lodash_1 = require("lodash");
5
+ const types_1 = require("../lib/types");
6
+ const createSdk_1 = require("../lib/sdk/createSdk");
7
+ const errors_1 = require("../lib/sdk/errors");
8
+ const helpers_1 = require("../lib/helpers");
5
9
  const dataPoints = {
6
10
  updatedMetricId: {
7
11
  key: 'updatedMetricId',
@@ -12,19 +16,28 @@ exports.metricEntryUpdated = {
12
16
  key: 'metricEntryUpdated',
13
17
  dataPoints,
14
18
  onWebhookReceived: async ({ payload, settings }, onSuccess, onError) => {
15
- const { resource_id: updatedMetricId } = payload;
16
- if ((0, lodash_1.isNil)(updatedMetricId)) {
17
- await onError({
18
- // We should automatically send a 400 here, so no need to provide info
19
- });
20
- }
21
- else {
19
+ var _a, _b, _c;
20
+ try {
21
+ const { sdk } = await (0, createSdk_1.createSdk)({ settings });
22
+ const validatedPayload = helpers_1.webhookPayloadSchema.parse(payload);
23
+ const updatedMetricId = validatedPayload.resource_id.toString();
24
+ const response = await sdk.getMetricEntry({ id: updatedMetricId });
25
+ const healthiePatientId = (_c = (_b = (_a = response === null || response === void 0 ? void 0 : response.data) === null || _a === void 0 ? void 0 : _a.entry) === null || _b === void 0 ? void 0 : _b.poster) === null || _c === void 0 ? void 0 : _c.id;
22
26
  await onSuccess({
23
27
  data_points: {
24
28
  updatedMetricId,
25
29
  },
30
+ ...(!(0, lodash_1.isNil)(healthiePatientId) && {
31
+ patient_identifier: {
32
+ system: types_1.HEALTHIE_IDENTIFIER,
33
+ value: healthiePatientId,
34
+ },
35
+ }),
26
36
  });
27
37
  }
38
+ catch (error) {
39
+ await onError((0, errors_1.formatError)(error));
40
+ }
28
41
  },
29
42
  };
30
43
  //# sourceMappingURL=metricEntryUpdated.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"metricEntryUpdated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/metricEntryUpdated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAO9B,MAAM,UAAU,GAAG;IACjB,eAAe,EAAE;QACf,GAAG,EAAE,iBAAiB;QACtB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,kBAAkB,GAG3B;IACF,GAAG,EAAE,oBAAoB;IACzB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;QACrE,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,OAAO,CAAA;QAEhD,IAAI,IAAA,cAAK,EAAC,eAAe,CAAC,EAAE;YAC1B,MAAM,OAAO,CAAC;YACZ,sEAAsE;aACvE,CAAC,CAAA;SACH;aAAM;YACL,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,eAAe;iBAChB;aACF,CAAC,CAAA;SACH;IACH,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"metricEntryUpdated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/metricEntryUpdated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAK9B,wCAA+E;AAE/E,oDAAgD;AAChD,8CAA+C;AAC/C,4CAAqD;AAErD,MAAM,UAAU,GAAG;IACjB,eAAe,EAAE;QACf,GAAG,EAAE,iBAAiB;QACtB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,kBAAkB,GAI3B;IACF,GAAG,EAAE,oBAAoB;IACzB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;;QACrE,IAAI;YACF,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,IAAA,qBAAS,EAAC,EAAE,QAAQ,EAAE,CAAC,CAAA;YAE7C,MAAM,gBAAgB,GAAG,8BAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YAC5D,MAAM,eAAe,GAAG,gBAAgB,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAA;YAE/D,MAAM,QAAQ,GAAG,MAAM,GAAG,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,eAAe,EAAE,CAAC,CAAA;YAClE,MAAM,iBAAiB,GAAG,MAAA,MAAA,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,IAAI,0CAAE,KAAK,0CAAE,MAAM,0CAAE,EAAE,CAAA;YAE3D,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,eAAe;iBAChB;gBACD,GAAG,CAAC,CAAC,IAAA,cAAK,EAAC,iBAAiB,CAAC,IAAI;oBAC/B,kBAAkB,EAAE;wBAClB,MAAM,EAAE,2BAAmB;wBAC3B,KAAK,EAAE,iBAAiB;qBACzB;iBACF,CAAC;aACH,CAAC,CAAA;SACH;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,OAAO,CAAC,IAAA,oBAAW,EAAC,KAAK,CAAC,CAAC,CAAA;SAClC;IACH,CAAC;CACF,CAAA"}
@@ -2,6 +2,8 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.patientCreated = void 0;
4
4
  const lodash_1 = require("lodash");
5
+ const types_1 = require("../lib/types");
6
+ const helpers_1 = require("../lib/helpers");
5
7
  const dataPoints = {
6
8
  patientId: {
7
9
  key: 'patientId',
@@ -12,7 +14,8 @@ exports.patientCreated = {
12
14
  key: 'patientCreated',
13
15
  dataPoints,
14
16
  onWebhookReceived: async ({ payload, settings }, onSuccess, onError) => {
15
- const { resource_id: patientId } = payload;
17
+ const validatedPayload = helpers_1.webhookPayloadSchema.parse(payload);
18
+ const patientId = validatedPayload.resource_id.toString();
16
19
  if ((0, lodash_1.isNil)(patientId)) {
17
20
  await onError({
18
21
  // We should automatically send a 400 here, so no need to provide info
@@ -23,6 +26,10 @@ exports.patientCreated = {
23
26
  data_points: {
24
27
  patientId,
25
28
  },
29
+ patient_identifier: {
30
+ system: types_1.HEALTHIE_IDENTIFIER,
31
+ value: patientId,
32
+ },
26
33
  });
27
34
  }
28
35
  },
@@ -1 +1 @@
1
- {"version":3,"file":"patientCreated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/patientCreated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAO9B,MAAM,UAAU,GAAG;IACjB,SAAS,EAAE;QACT,GAAG,EAAE,WAAW;QAChB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,cAAc,GAGvB;IACF,GAAG,EAAE,gBAAgB;IACrB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;QACrE,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,GAAG,OAAO,CAAA;QAE1C,IAAI,IAAA,cAAK,EAAC,SAAS,CAAC,EAAE;YACpB,MAAM,OAAO,CAAC;YACZ,sEAAsE;aACvE,CAAC,CAAA;SACH;aAAM;YACL,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,SAAS;iBACV;aACF,CAAC,CAAA;SACH;IACH,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"patientCreated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/patientCreated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAK9B,wCAA+E;AAC/E,4CAAqD;AAErD,MAAM,UAAU,GAAG;IACjB,SAAS,EAAE;QACT,GAAG,EAAE,WAAW;QAChB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,cAAc,GAGvB;IACF,GAAG,EAAE,gBAAgB;IACrB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;QACrE,MAAM,gBAAgB,GAAG,8BAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;QAC5D,MAAM,SAAS,GAAG,gBAAgB,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAA;QAEzD,IAAI,IAAA,cAAK,EAAC,SAAS,CAAC,EAAE;YACpB,MAAM,OAAO,CAAC;YACZ,sEAAsE;aACvE,CAAC,CAAA;SACH;aAAM;YACL,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,SAAS;iBACV;gBACD,kBAAkB,EAAE;oBAClB,MAAM,EAAE,2BAAmB;oBAC3B,KAAK,EAAE,SAAS;iBACjB;aACF,CAAC,CAAA;SACH;IACH,CAAC;CACF,CAAA"}
@@ -2,6 +2,8 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.patientUpdated = void 0;
4
4
  const lodash_1 = require("lodash");
5
+ const types_1 = require("../lib/types");
6
+ const helpers_1 = require("../lib/helpers");
5
7
  const dataPoints = {
6
8
  updatedPatientId: {
7
9
  key: 'updatedPatientId',
@@ -12,7 +14,8 @@ exports.patientUpdated = {
12
14
  key: 'patientUpdated',
13
15
  dataPoints,
14
16
  onWebhookReceived: async ({ payload, settings }, onSuccess, onError) => {
15
- const { resource_id: updatedPatientId } = payload;
17
+ const validatedPayload = helpers_1.webhookPayloadSchema.parse(payload);
18
+ const updatedPatientId = validatedPayload.resource_id.toString();
16
19
  if ((0, lodash_1.isNil)(updatedPatientId)) {
17
20
  await onError({
18
21
  // We should automatically send a 400 here, so no need to provide info
@@ -23,6 +26,10 @@ exports.patientUpdated = {
23
26
  data_points: {
24
27
  updatedPatientId,
25
28
  },
29
+ patient_identifier: {
30
+ system: types_1.HEALTHIE_IDENTIFIER,
31
+ value: updatedPatientId,
32
+ },
26
33
  });
27
34
  }
28
35
  },
@@ -1 +1 @@
1
- {"version":3,"file":"patientUpdated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/patientUpdated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAO9B,MAAM,UAAU,GAAG;IACjB,gBAAgB,EAAE;QAChB,GAAG,EAAE,kBAAkB;QACvB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,cAAc,GAGvB;IACF,GAAG,EAAE,gBAAgB;IACrB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;QACrE,MAAM,EAAE,WAAW,EAAE,gBAAgB,EAAE,GAAG,OAAO,CAAA;QAEjD,IAAI,IAAA,cAAK,EAAC,gBAAgB,CAAC,EAAE;YAC3B,MAAM,OAAO,CAAC;YACZ,sEAAsE;aACvE,CAAC,CAAA;SACH;aAAM;YACL,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,gBAAgB;iBACjB;aACF,CAAC,CAAA;SACH;IACH,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"patientUpdated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/patientUpdated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAK9B,wCAA+E;AAC/E,4CAAqD;AAErD,MAAM,UAAU,GAAG;IACjB,gBAAgB,EAAE;QAChB,GAAG,EAAE,kBAAkB;QACvB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,cAAc,GAGvB;IACF,GAAG,EAAE,gBAAgB;IACrB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;QACrE,MAAM,gBAAgB,GAAG,8BAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;QAC5D,MAAM,gBAAgB,GAAG,gBAAgB,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAA;QAEhE,IAAI,IAAA,cAAK,EAAC,gBAAgB,CAAC,EAAE;YAC3B,MAAM,OAAO,CAAC;YACZ,sEAAsE;aACvE,CAAC,CAAA;SACH;aAAM;YACL,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,gBAAgB;iBACjB;gBACD,kBAAkB,EAAE;oBAClB,MAAM,EAAE,2BAAmB;oBAC3B,KAAK,EAAE,gBAAgB;iBACxB;aACF,CAAC,CAAA;SACH;IACH,CAAC;CACF,CAAA"}
@@ -1,11 +1,12 @@
1
1
  import { type Webhook } from '@awell-health/extensions-core';
2
2
  import { type HealthieWebhookPayload } from '../lib/types';
3
+ import { type settings } from '../settings';
3
4
  declare const dataPoints: {
4
5
  createdFormCompletionId: {
5
6
  key: string;
6
7
  valueType: "string";
7
8
  };
8
9
  };
9
- export declare const requestFormCompletionCreated: Webhook<keyof typeof dataPoints, HealthieWebhookPayload>;
10
+ export declare const requestFormCompletionCreated: Webhook<keyof typeof dataPoints, HealthieWebhookPayload, typeof settings>;
10
11
  export type RequestFormCompletionCreated = typeof requestFormCompletionCreated;
11
12
  export {};
@@ -2,6 +2,10 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.requestFormCompletionCreated = void 0;
4
4
  const lodash_1 = require("lodash");
5
+ const types_1 = require("../lib/types");
6
+ const errors_1 = require("../lib/sdk/errors");
7
+ const createSdk_1 = require("../lib/sdk/createSdk");
8
+ const helpers_1 = require("../lib/helpers");
5
9
  const dataPoints = {
6
10
  createdFormCompletionId: {
7
11
  key: 'createdFormCompletionId',
@@ -12,19 +16,28 @@ exports.requestFormCompletionCreated = {
12
16
  key: 'requestFormCompletionCreated',
13
17
  dataPoints,
14
18
  onWebhookReceived: async ({ payload, settings }, onSuccess, onError) => {
15
- const { resource_id: createdFormCompletionId } = payload;
16
- if ((0, lodash_1.isNil)(createdFormCompletionId)) {
17
- await onError({
18
- // We should automatically send a 400 here, so no need to provide info
19
- });
20
- }
21
- else {
19
+ var _a, _b;
20
+ try {
21
+ const { sdk } = await (0, createSdk_1.createSdk)({ settings });
22
+ const validatedPayload = helpers_1.webhookPayloadSchema.parse(payload);
23
+ const createdFormCompletionId = validatedPayload.resource_id.toString();
24
+ const response = await sdk.getRequestedFormCompletion({ id: createdFormCompletionId });
25
+ const healthiePatientId = (_b = (_a = response === null || response === void 0 ? void 0 : response.data) === null || _a === void 0 ? void 0 : _a.requestedFormCompletion) === null || _b === void 0 ? void 0 : _b.recipient_id;
22
26
  await onSuccess({
23
27
  data_points: {
24
28
  createdFormCompletionId,
25
29
  },
30
+ ...(!(0, lodash_1.isNil)(healthiePatientId) && {
31
+ patient_identifier: {
32
+ system: types_1.HEALTHIE_IDENTIFIER,
33
+ value: healthiePatientId,
34
+ },
35
+ }),
26
36
  });
27
37
  }
38
+ catch (error) {
39
+ await onError((0, errors_1.formatError)(error));
40
+ }
28
41
  },
29
42
  };
30
43
  //# sourceMappingURL=requestedFormCompletionCreated.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"requestedFormCompletionCreated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/requestedFormCompletionCreated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAO9B,MAAM,UAAU,GAAG;IACjB,uBAAuB,EAAE;QACvB,GAAG,EAAE,yBAAyB;QAC9B,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,4BAA4B,GAGrC;IACF,GAAG,EAAE,8BAA8B;IACnC,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;QACrE,MAAM,EAAE,WAAW,EAAE,uBAAuB,EAAE,GAAG,OAAO,CAAA;QAExD,IAAI,IAAA,cAAK,EAAC,uBAAuB,CAAC,EAAE;YAClC,MAAM,OAAO,CAAC;YACZ,sEAAsE;aACvE,CAAC,CAAA;SACH;aAAM;YACL,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,uBAAuB;iBACxB;aACF,CAAC,CAAA;SACH;IACH,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"requestedFormCompletionCreated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/requestedFormCompletionCreated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAK9B,wCAA+E;AAE/E,8CAA+C;AAC/C,oDAAgD;AAChD,4CAAqD;AAErD,MAAM,UAAU,GAAG;IACjB,uBAAuB,EAAE;QACvB,GAAG,EAAE,yBAAyB;QAC9B,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,4BAA4B,GAIrC;IACF,GAAG,EAAE,8BAA8B;IACnC,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;;QACrE,IAAI;YACF,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,IAAA,qBAAS,EAAC,EAAE,QAAQ,EAAE,CAAC,CAAA;YAE7C,MAAM,gBAAgB,GAAG,8BAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YAC5D,MAAM,uBAAuB,GAAG,gBAAgB,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAA;YAEvE,MAAM,QAAQ,GAAG,MAAM,GAAG,CAAC,0BAA0B,CAAC,EAAE,EAAE,EAAE,uBAAuB,EAAE,CAAC,CAAA;YACtF,MAAM,iBAAiB,GAAG,MAAA,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,IAAI,0CAAE,uBAAuB,0CAAE,YAAY,CAAA;YAC/E,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,uBAAuB;iBACxB;gBACD,GAAG,CAAC,CAAC,IAAA,cAAK,EAAC,iBAAiB,CAAC,IAAI;oBAC/B,kBAAkB,EAAE;wBAClB,MAAM,EAAE,2BAAmB;wBAC3B,KAAK,EAAE,iBAAiB;qBACzB;iBACF,CAAC;aACH,CAAC,CAAA;SACH;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,OAAO,CAAC,IAAA,oBAAW,EAAC,KAAK,CAAC,CAAC,CAAA;SAClC;IACH,CAAC;CACF,CAAA"}
@@ -1,11 +1,12 @@
1
1
  import { type Webhook } from '@awell-health/extensions-core';
2
2
  import { type HealthieWebhookPayload } from '../lib/types';
3
+ import { type settings } from '../settings';
3
4
  declare const dataPoints: {
4
5
  updatedFormCompletionId: {
5
6
  key: string;
6
7
  valueType: "string";
7
8
  };
8
9
  };
9
- export declare const requestFormCompletionUpdated: Webhook<keyof typeof dataPoints, HealthieWebhookPayload>;
10
+ export declare const requestFormCompletionUpdated: Webhook<keyof typeof dataPoints, HealthieWebhookPayload, typeof settings>;
10
11
  export type RequestFormCompletionUpdated = typeof requestFormCompletionUpdated;
11
12
  export {};
@@ -2,6 +2,10 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.requestFormCompletionUpdated = void 0;
4
4
  const lodash_1 = require("lodash");
5
+ const types_1 = require("../lib/types");
6
+ const errors_1 = require("../lib/sdk/errors");
7
+ const createSdk_1 = require("../lib/sdk/createSdk");
8
+ const helpers_1 = require("../lib/helpers");
5
9
  const dataPoints = {
6
10
  updatedFormCompletionId: {
7
11
  key: 'updatedFormCompletionId',
@@ -12,19 +16,28 @@ exports.requestFormCompletionUpdated = {
12
16
  key: 'requestFormCompletionUpdated',
13
17
  dataPoints,
14
18
  onWebhookReceived: async ({ payload, settings }, onSuccess, onError) => {
15
- const { resource_id: updatedFormCompletionId } = payload;
16
- if ((0, lodash_1.isNil)(updatedFormCompletionId)) {
17
- await onError({
18
- // We should automatically send a 400 here, so no need to provide info
19
- });
20
- }
21
- else {
19
+ var _a, _b;
20
+ try {
21
+ const { sdk } = await (0, createSdk_1.createSdk)({ settings });
22
+ const validatedPayload = helpers_1.webhookPayloadSchema.parse(payload);
23
+ const updatedFormCompletionId = validatedPayload.resource_id.toString();
24
+ const response = await sdk.getRequestedFormCompletion({ id: updatedFormCompletionId });
25
+ const healthiePatientId = (_b = (_a = response === null || response === void 0 ? void 0 : response.data) === null || _a === void 0 ? void 0 : _a.requestedFormCompletion) === null || _b === void 0 ? void 0 : _b.recipient_id;
22
26
  await onSuccess({
23
27
  data_points: {
24
28
  updatedFormCompletionId,
25
29
  },
30
+ ...(!(0, lodash_1.isNil)(healthiePatientId) && {
31
+ patient_identifier: {
32
+ system: types_1.HEALTHIE_IDENTIFIER,
33
+ value: healthiePatientId,
34
+ },
35
+ }),
26
36
  });
27
37
  }
38
+ catch (error) {
39
+ await onError((0, errors_1.formatError)(error));
40
+ }
28
41
  },
29
42
  };
30
43
  //# sourceMappingURL=requestedFormCompletionUpdated.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"requestedFormCompletionUpdated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/requestedFormCompletionUpdated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAO9B,MAAM,UAAU,GAAG;IACjB,uBAAuB,EAAE;QACvB,GAAG,EAAE,yBAAyB;QAC9B,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,4BAA4B,GAGrC;IACF,GAAG,EAAE,8BAA8B;IACnC,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;QACrE,MAAM,EAAE,WAAW,EAAE,uBAAuB,EAAE,GAAG,OAAO,CAAA;QAExD,IAAI,IAAA,cAAK,EAAC,uBAAuB,CAAC,EAAE;YAClC,MAAM,OAAO,CAAC;YACZ,sEAAsE;aACvE,CAAC,CAAA;SACH;aAAM;YACL,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,uBAAuB;iBACxB;aACF,CAAC,CAAA;SACH;IACH,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"requestedFormCompletionUpdated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/requestedFormCompletionUpdated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAK9B,wCAA+E;AAE/E,8CAA+C;AAC/C,oDAAgD;AAChD,4CAAqD;AAErD,MAAM,UAAU,GAAG;IACjB,uBAAuB,EAAE;QACvB,GAAG,EAAE,yBAAyB;QAC9B,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,4BAA4B,GAIrC;IACF,GAAG,EAAE,8BAA8B;IACnC,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;;QACrE,IAAI;YACF,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,IAAA,qBAAS,EAAC,EAAE,QAAQ,EAAE,CAAC,CAAA;YAE7C,MAAM,gBAAgB,GAAG,8BAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YAC5D,MAAM,uBAAuB,GAAG,gBAAgB,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAA;YAEvE,MAAM,QAAQ,GAAG,MAAM,GAAG,CAAC,0BAA0B,CAAC,EAAE,EAAE,EAAE,uBAAuB,EAAE,CAAC,CAAA;YACtF,MAAM,iBAAiB,GAAG,MAAA,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,IAAI,0CAAE,uBAAuB,0CAAE,YAAY,CAAA;YAC/E,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,uBAAuB;iBACxB;gBACD,GAAG,CAAC,CAAC,IAAA,cAAK,EAAC,iBAAiB,CAAC,IAAI;oBAC/B,kBAAkB,EAAE;wBAClB,MAAM,EAAE,2BAAmB;wBAC3B,KAAK,EAAE,iBAAiB;qBACzB;iBACF,CAAC;aACH,CAAC,CAAA;SACH;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,OAAO,CAAC,IAAA,oBAAW,EAAC,KAAK,CAAC,CAAC,CAAA;SAClC;IACH,CAAC;CACF,CAAA"}
@@ -1,11 +1,12 @@
1
1
  import { type Webhook } from '@awell-health/extensions-core';
2
2
  import { type HealthieWebhookPayload } from '../lib/types';
3
+ import { type settings } from '../settings';
3
4
  declare const dataPoints: {
4
5
  createdTaskId: {
5
6
  key: string;
6
7
  valueType: "string";
7
8
  };
8
9
  };
9
- export declare const taskCreated: Webhook<keyof typeof dataPoints, HealthieWebhookPayload>;
10
+ export declare const taskCreated: Webhook<keyof typeof dataPoints, HealthieWebhookPayload, typeof settings>;
10
11
  export type TaskCreated = typeof taskCreated;
11
12
  export {};
@@ -2,6 +2,10 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.taskCreated = void 0;
4
4
  const lodash_1 = require("lodash");
5
+ const types_1 = require("../lib/types");
6
+ const createSdk_1 = require("../lib/sdk/createSdk");
7
+ const errors_1 = require("../lib/sdk/errors");
8
+ const helpers_1 = require("../lib/helpers");
5
9
  const dataPoints = {
6
10
  createdTaskId: {
7
11
  key: 'createdTaskId',
@@ -12,19 +16,28 @@ exports.taskCreated = {
12
16
  key: 'taskCreated',
13
17
  dataPoints,
14
18
  onWebhookReceived: async ({ payload, settings }, onSuccess, onError) => {
15
- const { resource_id: createdTaskId } = payload;
16
- if ((0, lodash_1.isNil)(createdTaskId)) {
17
- await onError({
18
- // We should automatically send a 400 here, so no need to provide info
19
- });
20
- }
21
- else {
19
+ var _a, _b;
20
+ try {
21
+ const { sdk } = await (0, createSdk_1.createSdk)({ settings });
22
+ const validatedPayload = helpers_1.webhookPayloadSchema.parse(payload);
23
+ const createdTaskId = validatedPayload.resource_id.toString();
24
+ const response = await sdk.getTask({ id: createdTaskId });
25
+ const healthiePatientId = (_b = (_a = response === null || response === void 0 ? void 0 : response.data) === null || _a === void 0 ? void 0 : _a.task) === null || _b === void 0 ? void 0 : _b.client_id;
22
26
  await onSuccess({
23
27
  data_points: {
24
28
  createdTaskId,
25
29
  },
30
+ ...(!(0, lodash_1.isNil)(healthiePatientId) && {
31
+ patient_identifier: {
32
+ system: types_1.HEALTHIE_IDENTIFIER,
33
+ value: healthiePatientId,
34
+ },
35
+ }),
26
36
  });
27
37
  }
38
+ catch (error) {
39
+ await onError((0, errors_1.formatError)(error));
40
+ }
28
41
  },
29
42
  };
30
43
  //# sourceMappingURL=taskCreated.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"taskCreated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/taskCreated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAO9B,MAAM,UAAU,GAAG;IACjB,aAAa,EAAE;QACb,GAAG,EAAE,eAAe;QACpB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,WAAW,GAGpB;IACF,GAAG,EAAE,aAAa;IAClB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;QACrE,MAAM,EAAE,WAAW,EAAE,aAAa,EAAE,GAAG,OAAO,CAAA;QAE9C,IAAI,IAAA,cAAK,EAAC,aAAa,CAAC,EAAE;YACxB,MAAM,OAAO,CAAC;YACZ,sEAAsE;aACvE,CAAC,CAAA;SACH;aAAM;YACL,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,aAAa;iBACd;aACF,CAAC,CAAA;SACH;IACH,CAAC;CACF,CAAA"}
1
+ {"version":3,"file":"taskCreated.js","sourceRoot":"","sources":["../../../../extensions/healthie/webhooks/taskCreated.ts"],"names":[],"mappings":";;;AAAA,mCAA8B;AAK9B,wCAA+E;AAE/E,oDAAgD;AAChD,8CAA+C;AAC/C,4CAAqD;AAGrD,MAAM,UAAU,GAAG;IACjB,aAAa,EAAE;QACb,GAAG,EAAE,eAAe;QACpB,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA;AAElC,QAAA,WAAW,GAIpB;IACF,GAAG,EAAE,aAAa;IAClB,UAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;;QACrE,IAAI;YACF,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,IAAA,qBAAS,EAAC,EAAE,QAAQ,EAAE,CAAC,CAAA;YAE7C,MAAM,gBAAgB,GAAG,8BAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YAC5D,MAAM,aAAa,GAAG,gBAAgB,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAA;YAE7D,MAAM,QAAQ,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,EAAE,EAAE,EAAE,aAAa,EAAE,CAAC,CAAA;YACzD,MAAM,iBAAiB,GAAG,MAAA,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,IAAI,0CAAE,IAAI,0CAAE,SAAS,CAAA;YACzD,MAAM,SAAS,CAAC;gBACd,WAAW,EAAE;oBACX,aAAa;iBACd;gBACD,GAAG,CAAC,CAAC,IAAA,cAAK,EAAC,iBAAiB,CAAC,IAAI;oBAC/B,kBAAkB,EAAE;wBAClB,MAAM,EAAE,2BAAmB;wBAC3B,KAAK,EAAE,iBAAiB;qBACzB;iBACF,CAAC;aACH,CAAC,CAAA;SACH;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,OAAO,CAAC,IAAA,oBAAW,EAAC,KAAK,CAAC,CAAC,CAAA;SAClC;IACH,CAAC;CACF,CAAA"}
@@ -1,11 +1,12 @@
1
1
  import { type Webhook } from '@awell-health/extensions-core';
2
2
  import { type HealthieWebhookPayload } from '../lib/types';
3
+ import { type settings } from '../settings';
3
4
  declare const dataPoints: {
4
5
  updatedTaskId: {
5
6
  key: string;
6
7
  valueType: "string";
7
8
  };
8
9
  };
9
- export declare const taskUpdated: Webhook<keyof typeof dataPoints, HealthieWebhookPayload>;
10
+ export declare const taskUpdated: Webhook<keyof typeof dataPoints, HealthieWebhookPayload, typeof settings>;
10
11
  export type TaskUpdated = typeof taskUpdated;
11
12
  export {};
@@ -2,6 +2,10 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.taskUpdated = void 0;
4
4
  const lodash_1 = require("lodash");
5
+ const types_1 = require("../lib/types");
6
+ const createSdk_1 = require("../lib/sdk/createSdk");
7
+ const errors_1 = require("../lib/sdk/errors");
8
+ const helpers_1 = require("../lib/helpers");
5
9
  const dataPoints = {
6
10
  updatedTaskId: {
7
11
  key: 'updatedTaskId',
@@ -12,19 +16,28 @@ exports.taskUpdated = {
12
16
  key: 'taskUpdated',
13
17
  dataPoints,
14
18
  onWebhookReceived: async ({ payload, settings }, onSuccess, onError) => {
15
- const { resource_id: updatedTaskId } = payload;
16
- if ((0, lodash_1.isNil)(updatedTaskId)) {
17
- await onError({
18
- // We should automatically send a 400 here, so no need to provide info
19
- });
20
- }
21
- else {
19
+ var _a, _b;
20
+ try {
21
+ const { sdk } = await (0, createSdk_1.createSdk)({ settings });
22
+ const validatedPayload = helpers_1.webhookPayloadSchema.parse(payload);
23
+ const updatedTaskId = validatedPayload.resource_id.toString();
24
+ const response = await sdk.getTask({ id: updatedTaskId });
25
+ const healthiePatientId = (_b = (_a = response === null || response === void 0 ? void 0 : response.data) === null || _a === void 0 ? void 0 : _a.task) === null || _b === void 0 ? void 0 : _b.client_id;
22
26
  await onSuccess({
23
27
  data_points: {
24
28
  updatedTaskId,
25
29
  },
30
+ ...(!(0, lodash_1.isNil)(healthiePatientId) && {
31
+ patient_identifier: {
32
+ system: types_1.HEALTHIE_IDENTIFIER,
33
+ value: healthiePatientId,
34
+ },
35
+ }),
26
36
  });
27
37
  }
28
- },
38
+ catch (error) {
39
+ await onError((0, errors_1.formatError)(error));
40
+ }
41
+ }
29
42
  };
30
43
  //# sourceMappingURL=taskUpdated.js.map