digital-tools 2.1.3 → 2.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (294) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/README.md +2 -0
  3. package/dist/client.d.ts +109 -0
  4. package/dist/client.d.ts.map +1 -0
  5. package/dist/client.js +69 -0
  6. package/dist/client.js.map +1 -0
  7. package/dist/define.d.ts +2 -2
  8. package/dist/define.d.ts.map +1 -1
  9. package/dist/define.js +21 -11
  10. package/dist/define.js.map +1 -1
  11. package/dist/function-ref.d.ts +229 -0
  12. package/dist/function-ref.d.ts.map +1 -0
  13. package/dist/function-ref.js +28 -0
  14. package/dist/function-ref.js.map +1 -0
  15. package/dist/function-sugar.d.ts +57 -0
  16. package/dist/function-sugar.d.ts.map +1 -0
  17. package/dist/function-sugar.js +79 -0
  18. package/dist/function-sugar.js.map +1 -0
  19. package/dist/index.d.ts +10 -3
  20. package/dist/index.d.ts.map +1 -1
  21. package/dist/index.js +24 -4
  22. package/dist/index.js.map +1 -1
  23. package/dist/providers/analytics/mixpanel.d.ts.map +1 -1
  24. package/dist/providers/analytics/mixpanel.js +21 -18
  25. package/dist/providers/analytics/mixpanel.js.map +1 -1
  26. package/dist/providers/calendar/cal-com.d.ts.map +1 -1
  27. package/dist/providers/calendar/cal-com.js +10 -10
  28. package/dist/providers/calendar/cal-com.js.map +1 -1
  29. package/dist/providers/calendar/google-calendar.d.ts.map +1 -1
  30. package/dist/providers/calendar/google-calendar.js +4 -4
  31. package/dist/providers/calendar/google-calendar.js.map +1 -1
  32. package/dist/providers/crm/hubspot.d.ts.map +1 -1
  33. package/dist/providers/crm/hubspot.js +107 -85
  34. package/dist/providers/crm/hubspot.js.map +1 -1
  35. package/dist/providers/development/github.d.ts.map +1 -1
  36. package/dist/providers/development/github.js +40 -43
  37. package/dist/providers/development/github.js.map +1 -1
  38. package/dist/providers/ecommerce/shopify.d.ts.map +1 -1
  39. package/dist/providers/ecommerce/shopify.js +79 -62
  40. package/dist/providers/ecommerce/shopify.js.map +1 -1
  41. package/dist/providers/email/resend.d.ts.map +1 -1
  42. package/dist/providers/email/resend.js +20 -16
  43. package/dist/providers/email/resend.js.map +1 -1
  44. package/dist/providers/email/sendgrid.d.ts.map +1 -1
  45. package/dist/providers/email/sendgrid.js +12 -9
  46. package/dist/providers/email/sendgrid.js.map +1 -1
  47. package/dist/providers/finance/stripe.d.ts.map +1 -1
  48. package/dist/providers/finance/stripe.js +44 -42
  49. package/dist/providers/finance/stripe.js.map +1 -1
  50. package/dist/providers/forms/typeform.d.ts.map +1 -1
  51. package/dist/providers/forms/typeform.js +68 -58
  52. package/dist/providers/forms/typeform.js.map +1 -1
  53. package/dist/providers/knowledge/notion.d.ts.map +1 -1
  54. package/dist/providers/knowledge/notion.js +75 -41
  55. package/dist/providers/knowledge/notion.js.map +1 -1
  56. package/dist/providers/marketing/mailchimp.d.ts.map +1 -1
  57. package/dist/providers/marketing/mailchimp.js +74 -61
  58. package/dist/providers/marketing/mailchimp.js.map +1 -1
  59. package/dist/providers/media/cloudinary.d.ts.map +1 -1
  60. package/dist/providers/media/cloudinary.js +30 -28
  61. package/dist/providers/media/cloudinary.js.map +1 -1
  62. package/dist/providers/messaging/slack.d.ts.map +1 -1
  63. package/dist/providers/messaging/slack.js +75 -58
  64. package/dist/providers/messaging/slack.js.map +1 -1
  65. package/dist/providers/messaging/twilio-sms.d.ts.map +1 -1
  66. package/dist/providers/messaging/twilio-sms.js +33 -15
  67. package/dist/providers/messaging/twilio-sms.js.map +1 -1
  68. package/dist/providers/project-management/linear.d.ts.map +1 -1
  69. package/dist/providers/project-management/linear.js +31 -27
  70. package/dist/providers/project-management/linear.js.map +1 -1
  71. package/dist/providers/spreadsheet/google-sheets.d.ts.map +1 -1
  72. package/dist/providers/spreadsheet/google-sheets.js +21 -18
  73. package/dist/providers/spreadsheet/google-sheets.js.map +1 -1
  74. package/dist/providers/spreadsheet/xlsx.d.ts.map +1 -1
  75. package/dist/providers/spreadsheet/xlsx.js +4 -4
  76. package/dist/providers/spreadsheet/xlsx.js.map +1 -1
  77. package/dist/providers/storage/index.js +1 -0
  78. package/dist/providers/storage/index.js.map +1 -1
  79. package/dist/providers/storage/s3.d.ts.map +1 -1
  80. package/dist/providers/storage/s3.js +36 -27
  81. package/dist/providers/storage/s3.js.map +1 -1
  82. package/dist/providers/support/zendesk.d.ts.map +1 -1
  83. package/dist/providers/support/zendesk.js +24 -25
  84. package/dist/providers/support/zendesk.js.map +1 -1
  85. package/dist/providers/tasks/todoist.d.ts.map +1 -1
  86. package/dist/providers/tasks/todoist.js +18 -18
  87. package/dist/providers/tasks/todoist.js.map +1 -1
  88. package/dist/providers/video-conferencing/google-meet.d.ts.map +1 -1
  89. package/dist/providers/video-conferencing/google-meet.js +11 -11
  90. package/dist/providers/video-conferencing/google-meet.js.map +1 -1
  91. package/dist/providers/video-conferencing/jitsi.js +14 -14
  92. package/dist/providers/video-conferencing/jitsi.js.map +1 -1
  93. package/dist/providers/video-conferencing/teams.d.ts.map +1 -1
  94. package/dist/providers/video-conferencing/teams.js +9 -7
  95. package/dist/providers/video-conferencing/teams.js.map +1 -1
  96. package/dist/providers/video-conferencing/zoom.d.ts.map +1 -1
  97. package/dist/providers/video-conferencing/zoom.js +26 -24
  98. package/dist/providers/video-conferencing/zoom.js.map +1 -1
  99. package/dist/tools/data.d.ts.map +1 -1
  100. package/dist/tools/data.js +5 -12
  101. package/dist/tools/data.js.map +1 -1
  102. package/dist/tools/index.d.ts +1 -0
  103. package/dist/tools/index.d.ts.map +1 -1
  104. package/dist/tools/index.js +1 -0
  105. package/dist/tools/index.js.map +1 -1
  106. package/dist/tools/system.d.ts +289 -0
  107. package/dist/tools/system.d.ts.map +1 -0
  108. package/dist/tools/system.js +752 -0
  109. package/dist/tools/system.js.map +1 -0
  110. package/dist/tools/web.d.ts.map +1 -1
  111. package/dist/tools/web.js +22 -10
  112. package/dist/tools/web.js.map +1 -1
  113. package/dist/track-record.d.ts +101 -0
  114. package/dist/track-record.d.ts.map +1 -0
  115. package/dist/track-record.js +17 -0
  116. package/dist/track-record.js.map +1 -0
  117. package/dist/types.d.ts +210 -9
  118. package/dist/types.d.ts.map +1 -1
  119. package/dist/verb-registration.d.ts +122 -0
  120. package/dist/verb-registration.d.ts.map +1 -0
  121. package/dist/verb-registration.js +176 -0
  122. package/dist/verb-registration.js.map +1 -0
  123. package/dist/worker.d.ts +93 -0
  124. package/dist/worker.d.ts.map +1 -0
  125. package/dist/worker.js +315 -0
  126. package/dist/worker.js.map +1 -0
  127. package/dist/wrap.d.ts +89 -0
  128. package/dist/wrap.d.ts.map +1 -0
  129. package/dist/wrap.js +225 -0
  130. package/dist/wrap.js.map +1 -0
  131. package/package.json +31 -14
  132. package/src/client.ts +136 -0
  133. package/src/define.ts +30 -24
  134. package/src/function-ref.ts +264 -0
  135. package/src/function-sugar.ts +134 -0
  136. package/src/index.ts +132 -10
  137. package/src/providers/analytics/mixpanel.ts +19 -18
  138. package/src/providers/calendar/cal-com.ts +29 -18
  139. package/src/providers/calendar/google-calendar.ts +20 -14
  140. package/src/providers/crm/hubspot.ts +225 -99
  141. package/src/providers/development/github.ts +206 -135
  142. package/src/providers/ecommerce/shopify.ts +250 -89
  143. package/src/providers/email/resend.ts +101 -28
  144. package/src/providers/email/sendgrid.ts +12 -9
  145. package/src/providers/finance/stripe.ts +128 -49
  146. package/src/providers/forms/typeform.ts +74 -58
  147. package/src/providers/knowledge/notion.ts +340 -88
  148. package/src/providers/marketing/mailchimp.ts +86 -70
  149. package/src/providers/media/cloudinary.ts +99 -41
  150. package/src/providers/messaging/slack.ts +283 -85
  151. package/src/providers/messaging/twilio-sms.ts +35 -15
  152. package/src/providers/project-management/linear.ts +143 -55
  153. package/src/providers/spreadsheet/google-sheets.ts +222 -56
  154. package/src/providers/spreadsheet/xlsx.ts +47 -16
  155. package/src/providers/storage/s3.ts +119 -47
  156. package/src/providers/support/zendesk.ts +196 -46
  157. package/src/providers/tasks/todoist.ts +20 -26
  158. package/src/providers/video-conferencing/google-meet.ts +17 -20
  159. package/src/providers/video-conferencing/jitsi.ts +14 -14
  160. package/src/providers/video-conferencing/teams.ts +14 -13
  161. package/src/providers/video-conferencing/zoom.ts +54 -49
  162. package/src/tools/data.ts +6 -16
  163. package/src/tools/index.ts +1 -0
  164. package/src/tools/system.ts +887 -0
  165. package/src/tools/web.ts +22 -10
  166. package/src/track-record.ts +106 -0
  167. package/src/types.ts +241 -13
  168. package/src/verb-registration.ts +197 -0
  169. package/src/worker.ts +370 -0
  170. package/src/wrap.ts +260 -0
  171. package/test/client.test.ts +146 -0
  172. package/test/communication-tools-extended.test.ts +734 -0
  173. package/test/data-tools-extended.test.ts +743 -0
  174. package/test/define-extended.test.ts +819 -0
  175. package/test/define.test.ts +150 -41
  176. package/test/entities.test.ts +623 -0
  177. package/test/extended-entities.test.ts +1228 -0
  178. package/test/provider-implementations.test.ts +725 -0
  179. package/test/provider-registry-extended.test.ts +583 -0
  180. package/test/providers/google-sheets.test.ts +851 -0
  181. package/test/providers/helpers.ts +554 -0
  182. package/test/providers/hubspot.test.ts +576 -0
  183. package/test/providers/slack.test.ts +932 -0
  184. package/test/providers/stripe.test.ts +701 -0
  185. package/test/providers.test.ts +578 -0
  186. package/test/system-tools-extended.test.ts +632 -0
  187. package/test/system.test.ts +673 -0
  188. package/test/tools.test.ts +15 -11
  189. package/test/types.test.ts +402 -0
  190. package/test/verb-registration.test.ts +395 -0
  191. package/test/web-tools.test.ts +553 -0
  192. package/test/worker-extended.test.ts +699 -0
  193. package/test/worker.test.ts +576 -0
  194. package/test/wrap.test.ts +366 -0
  195. package/tsconfig.json +3 -13
  196. package/vitest.config.ts +37 -0
  197. package/wrangler.jsonc +9 -0
  198. package/.turbo/turbo-build.log +0 -4
  199. package/LICENSE +0 -21
  200. package/dist/providers/voice/vapi.d.ts +0 -27
  201. package/dist/providers/voice/vapi.d.ts.map +0 -1
  202. package/dist/providers/voice/vapi.js +0 -440
  203. package/dist/providers/voice/vapi.js.map +0 -1
  204. package/src/define.js +0 -259
  205. package/src/entities/advertising.js +0 -999
  206. package/src/entities/ai.js +0 -756
  207. package/src/entities/analytics.js +0 -1588
  208. package/src/entities/automation.js +0 -601
  209. package/src/entities/communication.js +0 -1150
  210. package/src/entities/crm.js +0 -1386
  211. package/src/entities/design.js +0 -546
  212. package/src/entities/development.js +0 -2212
  213. package/src/entities/document.js +0 -874
  214. package/src/entities/ecommerce.js +0 -1429
  215. package/src/entities/experiment.js +0 -1039
  216. package/src/entities/finance.js +0 -3478
  217. package/src/entities/forms.js +0 -1892
  218. package/src/entities/hr.js +0 -661
  219. package/src/entities/identity.js +0 -997
  220. package/src/entities/index.js +0 -282
  221. package/src/entities/infrastructure.js +0 -1153
  222. package/src/entities/knowledge.js +0 -1438
  223. package/src/entities/marketing.js +0 -1610
  224. package/src/entities/media.js +0 -1634
  225. package/src/entities/notification.js +0 -1199
  226. package/src/entities/presentation.js +0 -1274
  227. package/src/entities/productivity.js +0 -1317
  228. package/src/entities/project-management.js +0 -1136
  229. package/src/entities/recruiting.js +0 -736
  230. package/src/entities/shipping.js +0 -509
  231. package/src/entities/signature.js +0 -1102
  232. package/src/entities/site.js +0 -222
  233. package/src/entities/spreadsheet.js +0 -1341
  234. package/src/entities/storage.js +0 -1198
  235. package/src/entities/support.js +0 -1166
  236. package/src/entities/video-conferencing.js +0 -1750
  237. package/src/entities/video.js +0 -950
  238. package/src/entities.js +0 -1663
  239. package/src/index.js +0 -74
  240. package/src/providers/analytics/index.js +0 -17
  241. package/src/providers/analytics/mixpanel.js +0 -255
  242. package/src/providers/calendar/cal-com.js +0 -303
  243. package/src/providers/calendar/google-calendar.js +0 -335
  244. package/src/providers/calendar/index.js +0 -20
  245. package/src/providers/crm/hubspot.js +0 -566
  246. package/src/providers/crm/index.js +0 -17
  247. package/src/providers/development/github.js +0 -472
  248. package/src/providers/development/index.js +0 -17
  249. package/src/providers/ecommerce/index.js +0 -17
  250. package/src/providers/ecommerce/shopify.js +0 -378
  251. package/src/providers/email/index.js +0 -20
  252. package/src/providers/email/resend.js +0 -258
  253. package/src/providers/email/sendgrid.js +0 -161
  254. package/src/providers/finance/index.js +0 -17
  255. package/src/providers/finance/stripe.js +0 -549
  256. package/src/providers/forms/index.js +0 -17
  257. package/src/providers/forms/typeform.js +0 -500
  258. package/src/providers/index.js +0 -123
  259. package/src/providers/knowledge/index.js +0 -17
  260. package/src/providers/knowledge/notion.js +0 -389
  261. package/src/providers/marketing/index.js +0 -17
  262. package/src/providers/marketing/mailchimp.js +0 -443
  263. package/src/providers/media/cloudinary.js +0 -318
  264. package/src/providers/media/index.js +0 -17
  265. package/src/providers/messaging/index.js +0 -20
  266. package/src/providers/messaging/slack.js +0 -393
  267. package/src/providers/messaging/twilio-sms.js +0 -249
  268. package/src/providers/project-management/index.js +0 -17
  269. package/src/providers/project-management/linear.js +0 -575
  270. package/src/providers/registry.js +0 -86
  271. package/src/providers/spreadsheet/google-sheets.js +0 -375
  272. package/src/providers/spreadsheet/index.js +0 -20
  273. package/src/providers/spreadsheet/xlsx.js +0 -423
  274. package/src/providers/storage/index.js +0 -24
  275. package/src/providers/storage/s3.js +0 -419
  276. package/src/providers/support/index.js +0 -17
  277. package/src/providers/support/zendesk.js +0 -373
  278. package/src/providers/tasks/index.js +0 -17
  279. package/src/providers/tasks/todoist.js +0 -286
  280. package/src/providers/types.js +0 -9
  281. package/src/providers/video-conferencing/google-meet.js +0 -286
  282. package/src/providers/video-conferencing/index.js +0 -31
  283. package/src/providers/video-conferencing/jitsi.js +0 -254
  284. package/src/providers/video-conferencing/teams.js +0 -270
  285. package/src/providers/video-conferencing/zoom.js +0 -332
  286. package/src/registry.js +0 -128
  287. package/src/tools/communication.js +0 -184
  288. package/src/tools/data.js +0 -205
  289. package/src/tools/index.js +0 -11
  290. package/src/tools/web.js +0 -137
  291. package/src/types.js +0 -10
  292. package/test/define.test.js +0 -306
  293. package/test/registry.test.js +0 -357
  294. package/test/tools.test.js +0 -363
@@ -1,566 +0,0 @@
1
- /**
2
- * HubSpot CRM Provider
3
- *
4
- * Concrete implementation of CRMProvider using HubSpot CRM API v3.
5
- *
6
- * @packageDocumentation
7
- */
8
- import { defineProvider } from '../registry.js';
9
- const HUBSPOT_API_URL = 'https://api.hubapi.com/crm/v3';
10
- /**
11
- * HubSpot provider info
12
- */
13
- export const hubspotInfo = {
14
- id: 'crm.hubspot',
15
- name: 'HubSpot',
16
- description: 'HubSpot CRM platform for managing contacts, deals, and activities',
17
- category: 'crm',
18
- website: 'https://www.hubspot.com',
19
- docsUrl: 'https://developers.hubspot.com/docs/api/overview',
20
- requiredConfig: ['accessToken'],
21
- optionalConfig: ['baseUrl'],
22
- };
23
- /**
24
- * Map HubSpot contact properties to CRMContactData
25
- */
26
- function mapContactFromHubSpot(contact) {
27
- const props = contact.properties || {};
28
- return {
29
- id: contact.id,
30
- firstName: props.firstname || '',
31
- lastName: props.lastname || '',
32
- email: props.email,
33
- phone: props.phone,
34
- company: props.company,
35
- title: props.jobtitle,
36
- ownerId: props.hubspot_owner_id,
37
- createdAt: new Date(props.createdate || contact.createdAt),
38
- updatedAt: new Date(props.lastmodifieddate || contact.updatedAt),
39
- };
40
- }
41
- /**
42
- * Map HubSpot deal properties to DealData
43
- */
44
- function mapDealFromHubSpot(deal) {
45
- const props = deal.properties || {};
46
- return {
47
- id: deal.id,
48
- name: props.dealname || '',
49
- value: props.amount ? parseFloat(props.amount) : undefined,
50
- currency: props.deal_currency_code,
51
- stage: props.dealstage || '',
52
- probability: props.hs_deal_stage_probability ? parseFloat(props.hs_deal_stage_probability) : undefined,
53
- contactId: props.associatedcontactid,
54
- companyId: props.associatedcompanyid,
55
- ownerId: props.hubspot_owner_id,
56
- closeDate: props.closedate ? new Date(props.closedate) : undefined,
57
- createdAt: new Date(props.createdate || deal.createdAt),
58
- updatedAt: new Date(props.hs_lastmodifieddate || deal.updatedAt),
59
- wonAt: props.hs_date_entered_closedwon ? new Date(props.hs_date_entered_closedwon) : undefined,
60
- lostAt: props.hs_date_entered_closedlost ? new Date(props.hs_date_entered_closedlost) : undefined,
61
- };
62
- }
63
- /**
64
- * Map HubSpot engagement to CRMActivityData
65
- */
66
- function mapActivityFromHubSpot(engagement, contactId) {
67
- const props = engagement.properties || {};
68
- return {
69
- id: engagement.id,
70
- type: props.hs_engagement_type || 'note',
71
- subject: props.hs_engagement_subject || '',
72
- body: props.hs_note_body || props.hs_email_text || '',
73
- contactId,
74
- ownerId: props.hubspot_owner_id || '',
75
- dueDate: props.hs_task_due_date ? new Date(props.hs_task_due_date) : undefined,
76
- completedAt: props.hs_engagement_completed_at ? new Date(props.hs_engagement_completed_at) : undefined,
77
- createdAt: new Date(props.hs_createdate || engagement.createdAt),
78
- };
79
- }
80
- /**
81
- * Create HubSpot CRM provider
82
- */
83
- export function createHubSpotProvider(config) {
84
- let accessToken;
85
- let baseUrl;
86
- // Helper function to associate deal with contact
87
- async function associateDealWithContact(dealId, contactId) {
88
- try {
89
- const response = await fetch(`${baseUrl}/objects/deals/${dealId}/associations/contacts/${contactId}/deal_to_contact`, {
90
- method: 'PUT',
91
- headers: {
92
- Authorization: `Bearer ${accessToken}`,
93
- 'Content-Type': 'application/json',
94
- },
95
- });
96
- if (!response.ok) {
97
- throw new Error(`HTTP ${response.status}`);
98
- }
99
- }
100
- catch (error) {
101
- // Log but don't throw - association is optional
102
- console.warn('Failed to associate deal with contact:', error);
103
- }
104
- }
105
- // Helper function to associate deal with company
106
- async function associateDealWithCompany(dealId, companyId) {
107
- try {
108
- const response = await fetch(`${baseUrl}/objects/deals/${dealId}/associations/companies/${companyId}/deal_to_company`, {
109
- method: 'PUT',
110
- headers: {
111
- Authorization: `Bearer ${accessToken}`,
112
- 'Content-Type': 'application/json',
113
- },
114
- });
115
- if (!response.ok) {
116
- throw new Error(`HTTP ${response.status}`);
117
- }
118
- }
119
- catch (error) {
120
- // Log but don't throw - association is optional
121
- console.warn('Failed to associate deal with company:', error);
122
- }
123
- }
124
- // Helper function to associate engagement with contact
125
- async function associateEngagementWithContact(engagementId, contactId) {
126
- try {
127
- const response = await fetch(`${baseUrl}/objects/engagements/${engagementId}/associations/contacts/${contactId}/engagement_to_contact`, {
128
- method: 'PUT',
129
- headers: {
130
- Authorization: `Bearer ${accessToken}`,
131
- 'Content-Type': 'application/json',
132
- },
133
- });
134
- if (!response.ok) {
135
- throw new Error(`HTTP ${response.status}`);
136
- }
137
- }
138
- catch (error) {
139
- console.warn('Failed to associate engagement with contact:', error);
140
- }
141
- }
142
- return {
143
- info: hubspotInfo,
144
- async initialize(cfg) {
145
- accessToken = cfg.accessToken;
146
- baseUrl = cfg.baseUrl || HUBSPOT_API_URL;
147
- if (!accessToken) {
148
- throw new Error('HubSpot access token is required');
149
- }
150
- },
151
- async healthCheck() {
152
- const start = Date.now();
153
- try {
154
- const response = await fetch(`${baseUrl}/objects/contacts?limit=1`, {
155
- headers: {
156
- Authorization: `Bearer ${accessToken}`,
157
- 'Content-Type': 'application/json',
158
- },
159
- });
160
- return {
161
- healthy: response.ok,
162
- latencyMs: Date.now() - start,
163
- message: response.ok ? 'Connected' : `HTTP ${response.status}`,
164
- checkedAt: new Date(),
165
- };
166
- }
167
- catch (error) {
168
- return {
169
- healthy: false,
170
- latencyMs: Date.now() - start,
171
- message: error instanceof Error ? error.message : 'Unknown error',
172
- checkedAt: new Date(),
173
- };
174
- }
175
- },
176
- async dispose() {
177
- // No cleanup needed
178
- },
179
- async createContact(contact) {
180
- const properties = {
181
- firstname: contact.firstName,
182
- lastname: contact.lastName,
183
- };
184
- if (contact.email)
185
- properties.email = contact.email;
186
- if (contact.phone)
187
- properties.phone = contact.phone;
188
- if (contact.company)
189
- properties.company = contact.company;
190
- if (contact.title)
191
- properties.jobtitle = contact.title;
192
- // Add custom fields
193
- if (contact.customFields) {
194
- Object.assign(properties, contact.customFields);
195
- }
196
- try {
197
- const response = await fetch(`${baseUrl}/objects/contacts`, {
198
- method: 'POST',
199
- headers: {
200
- Authorization: `Bearer ${accessToken}`,
201
- 'Content-Type': 'application/json',
202
- },
203
- body: JSON.stringify({ properties }),
204
- });
205
- if (!response.ok) {
206
- const errorData = await response.json().catch(() => ({}));
207
- throw new Error(errorData?.message || `HTTP ${response.status}`);
208
- }
209
- const data = await response.json();
210
- return mapContactFromHubSpot(data);
211
- }
212
- catch (error) {
213
- throw new Error(`Failed to create contact: ${error instanceof Error ? error.message : 'Unknown error'}`);
214
- }
215
- },
216
- async getContact(contactId) {
217
- try {
218
- const response = await fetch(`${baseUrl}/objects/contacts/${contactId}`, {
219
- headers: {
220
- Authorization: `Bearer ${accessToken}`,
221
- 'Content-Type': 'application/json',
222
- },
223
- });
224
- if (response.status === 404) {
225
- return null;
226
- }
227
- if (!response.ok) {
228
- throw new Error(`HTTP ${response.status}`);
229
- }
230
- const data = await response.json();
231
- return mapContactFromHubSpot(data);
232
- }
233
- catch (error) {
234
- if (error instanceof Error && error.message.includes('404')) {
235
- return null;
236
- }
237
- throw new Error(`Failed to get contact: ${error instanceof Error ? error.message : 'Unknown error'}`);
238
- }
239
- },
240
- async updateContact(contactId, updates) {
241
- const properties = {};
242
- if (updates.firstName !== undefined)
243
- properties.firstname = updates.firstName;
244
- if (updates.lastName !== undefined)
245
- properties.lastname = updates.lastName;
246
- if (updates.email !== undefined)
247
- properties.email = updates.email;
248
- if (updates.phone !== undefined)
249
- properties.phone = updates.phone;
250
- if (updates.company !== undefined)
251
- properties.company = updates.company;
252
- if (updates.title !== undefined)
253
- properties.jobtitle = updates.title;
254
- // Add custom fields
255
- if (updates.customFields) {
256
- Object.assign(properties, updates.customFields);
257
- }
258
- try {
259
- const response = await fetch(`${baseUrl}/objects/contacts/${contactId}`, {
260
- method: 'PATCH',
261
- headers: {
262
- Authorization: `Bearer ${accessToken}`,
263
- 'Content-Type': 'application/json',
264
- },
265
- body: JSON.stringify({ properties }),
266
- });
267
- if (!response.ok) {
268
- const errorData = await response.json().catch(() => ({}));
269
- throw new Error(errorData?.message || `HTTP ${response.status}`);
270
- }
271
- const data = await response.json();
272
- return mapContactFromHubSpot(data);
273
- }
274
- catch (error) {
275
- throw new Error(`Failed to update contact: ${error instanceof Error ? error.message : 'Unknown error'}`);
276
- }
277
- },
278
- async listContacts(options) {
279
- const params = new URLSearchParams({
280
- limit: String(options?.limit || 100),
281
- });
282
- if (options?.cursor) {
283
- params.set('after', options.cursor);
284
- }
285
- try {
286
- const response = await fetch(`${baseUrl}/objects/contacts?${params}`, {
287
- headers: {
288
- Authorization: `Bearer ${accessToken}`,
289
- 'Content-Type': 'application/json',
290
- },
291
- });
292
- if (!response.ok) {
293
- throw new Error(`HTTP ${response.status}`);
294
- }
295
- const data = await response.json();
296
- return {
297
- items: (data.results || []).map(mapContactFromHubSpot),
298
- total: data.total,
299
- hasMore: !!data.paging?.next,
300
- nextCursor: data.paging?.next?.after,
301
- };
302
- }
303
- catch (error) {
304
- throw new Error(`Failed to list contacts: ${error instanceof Error ? error.message : 'Unknown error'}`);
305
- }
306
- },
307
- async searchContacts(query) {
308
- try {
309
- const response = await fetch(`${baseUrl}/objects/contacts/search`, {
310
- method: 'POST',
311
- headers: {
312
- Authorization: `Bearer ${accessToken}`,
313
- 'Content-Type': 'application/json',
314
- },
315
- body: JSON.stringify({
316
- filterGroups: [
317
- {
318
- filters: [
319
- {
320
- propertyName: 'email',
321
- operator: 'CONTAINS_TOKEN',
322
- value: query,
323
- },
324
- {
325
- propertyName: 'firstname',
326
- operator: 'CONTAINS_TOKEN',
327
- value: query,
328
- },
329
- {
330
- propertyName: 'lastname',
331
- operator: 'CONTAINS_TOKEN',
332
- value: query,
333
- },
334
- ],
335
- },
336
- ],
337
- limit: 100,
338
- }),
339
- });
340
- if (!response.ok) {
341
- throw new Error(`HTTP ${response.status}`);
342
- }
343
- const data = await response.json();
344
- return (data.results || []).map(mapContactFromHubSpot);
345
- }
346
- catch (error) {
347
- throw new Error(`Failed to search contacts: ${error instanceof Error ? error.message : 'Unknown error'}`);
348
- }
349
- },
350
- async createDeal(deal) {
351
- const properties = {
352
- dealname: deal.name,
353
- dealstage: deal.stage,
354
- };
355
- if (deal.value !== undefined)
356
- properties.amount = String(deal.value);
357
- if (deal.currency)
358
- properties.deal_currency_code = deal.currency;
359
- if (deal.closeDate)
360
- properties.closedate = deal.closeDate.toISOString();
361
- if (deal.probability !== undefined)
362
- properties.hs_deal_stage_probability = String(deal.probability);
363
- try {
364
- const response = await fetch(`${baseUrl}/objects/deals`, {
365
- method: 'POST',
366
- headers: {
367
- Authorization: `Bearer ${accessToken}`,
368
- 'Content-Type': 'application/json',
369
- },
370
- body: JSON.stringify({ properties }),
371
- });
372
- if (!response.ok) {
373
- const errorData = await response.json().catch(() => ({}));
374
- throw new Error(errorData?.message || `HTTP ${response.status}`);
375
- }
376
- const data = await response.json();
377
- const dealData = mapDealFromHubSpot(data);
378
- // Associate with contact if specified
379
- if (deal.contactId) {
380
- await associateDealWithContact(dealData.id, deal.contactId);
381
- }
382
- // Associate with company if specified
383
- if (deal.companyId) {
384
- await associateDealWithCompany(dealData.id, deal.companyId);
385
- }
386
- return dealData;
387
- }
388
- catch (error) {
389
- throw new Error(`Failed to create deal: ${error instanceof Error ? error.message : 'Unknown error'}`);
390
- }
391
- },
392
- async getDeal(dealId) {
393
- try {
394
- const response = await fetch(`${baseUrl}/objects/deals/${dealId}`, {
395
- headers: {
396
- Authorization: `Bearer ${accessToken}`,
397
- 'Content-Type': 'application/json',
398
- },
399
- });
400
- if (response.status === 404) {
401
- return null;
402
- }
403
- if (!response.ok) {
404
- throw new Error(`HTTP ${response.status}`);
405
- }
406
- const data = await response.json();
407
- return mapDealFromHubSpot(data);
408
- }
409
- catch (error) {
410
- if (error instanceof Error && error.message.includes('404')) {
411
- return null;
412
- }
413
- throw new Error(`Failed to get deal: ${error instanceof Error ? error.message : 'Unknown error'}`);
414
- }
415
- },
416
- async updateDeal(dealId, updates) {
417
- const properties = {};
418
- if (updates.name !== undefined)
419
- properties.dealname = updates.name;
420
- if (updates.stage !== undefined)
421
- properties.dealstage = updates.stage;
422
- if (updates.value !== undefined)
423
- properties.amount = String(updates.value);
424
- if (updates.currency !== undefined)
425
- properties.deal_currency_code = updates.currency;
426
- if (updates.closeDate !== undefined)
427
- properties.closedate = updates.closeDate.toISOString();
428
- if (updates.probability !== undefined)
429
- properties.hs_deal_stage_probability = String(updates.probability);
430
- try {
431
- const response = await fetch(`${baseUrl}/objects/deals/${dealId}`, {
432
- method: 'PATCH',
433
- headers: {
434
- Authorization: `Bearer ${accessToken}`,
435
- 'Content-Type': 'application/json',
436
- },
437
- body: JSON.stringify({ properties }),
438
- });
439
- if (!response.ok) {
440
- const errorData = await response.json().catch(() => ({}));
441
- throw new Error(errorData?.message || `HTTP ${response.status}`);
442
- }
443
- const data = await response.json();
444
- return mapDealFromHubSpot(data);
445
- }
446
- catch (error) {
447
- throw new Error(`Failed to update deal: ${error instanceof Error ? error.message : 'Unknown error'}`);
448
- }
449
- },
450
- async listDeals(options) {
451
- const params = new URLSearchParams({
452
- limit: String(options?.limit || 100),
453
- });
454
- if (options?.cursor) {
455
- params.set('after', options.cursor);
456
- }
457
- try {
458
- const response = await fetch(`${baseUrl}/objects/deals?${params}`, {
459
- headers: {
460
- Authorization: `Bearer ${accessToken}`,
461
- 'Content-Type': 'application/json',
462
- },
463
- });
464
- if (!response.ok) {
465
- throw new Error(`HTTP ${response.status}`);
466
- }
467
- const data = await response.json();
468
- return {
469
- items: (data.results || []).map(mapDealFromHubSpot),
470
- total: data.total,
471
- hasMore: !!data.paging?.next,
472
- nextCursor: data.paging?.next?.after,
473
- };
474
- }
475
- catch (error) {
476
- throw new Error(`Failed to list deals: ${error instanceof Error ? error.message : 'Unknown error'}`);
477
- }
478
- },
479
- async logActivity(contactId, activity) {
480
- // Map activity type to HubSpot engagement type
481
- const engagementType = activity.type === 'email' ? 'EMAIL' :
482
- activity.type === 'call' ? 'CALL' :
483
- activity.type === 'meeting' ? 'MEETING' :
484
- activity.type === 'task' ? 'TASK' :
485
- 'NOTE';
486
- const properties = {
487
- hs_engagement_type: engagementType.toLowerCase(),
488
- hs_engagement_subject: activity.subject,
489
- };
490
- if (activity.body) {
491
- if (engagementType === 'NOTE') {
492
- properties.hs_note_body = activity.body;
493
- }
494
- else if (engagementType === 'EMAIL') {
495
- properties.hs_email_text = activity.body;
496
- }
497
- }
498
- if (activity.dueDate) {
499
- properties.hs_task_due_date = activity.dueDate.toISOString();
500
- }
501
- try {
502
- const response = await fetch(`${baseUrl}/objects/engagements`, {
503
- method: 'POST',
504
- headers: {
505
- Authorization: `Bearer ${accessToken}`,
506
- 'Content-Type': 'application/json',
507
- },
508
- body: JSON.stringify({ properties }),
509
- });
510
- if (!response.ok) {
511
- const errorData = await response.json().catch(() => ({}));
512
- throw new Error(errorData?.message || `HTTP ${response.status}`);
513
- }
514
- const data = await response.json();
515
- // Associate engagement with contact
516
- await associateEngagementWithContact(data.id, contactId);
517
- return mapActivityFromHubSpot(data, contactId);
518
- }
519
- catch (error) {
520
- throw new Error(`Failed to log activity: ${error instanceof Error ? error.message : 'Unknown error'}`);
521
- }
522
- },
523
- async listActivities(contactId) {
524
- try {
525
- // Get associated engagements for the contact
526
- const response = await fetch(`${baseUrl}/objects/contacts/${contactId}/associations/engagements`, {
527
- headers: {
528
- Authorization: `Bearer ${accessToken}`,
529
- 'Content-Type': 'application/json',
530
- },
531
- });
532
- if (!response.ok) {
533
- throw new Error(`HTTP ${response.status}`);
534
- }
535
- const data = await response.json();
536
- const engagementIds = (data.results || []).map((r) => r.id);
537
- if (engagementIds.length === 0) {
538
- return [];
539
- }
540
- // Fetch engagement details in batch
541
- const engagements = await Promise.all(engagementIds.map(async (id) => {
542
- const engResponse = await fetch(`${baseUrl}/objects/engagements/${id}`, {
543
- headers: {
544
- Authorization: `Bearer ${accessToken}`,
545
- 'Content-Type': 'application/json',
546
- },
547
- });
548
- if (engResponse.ok) {
549
- return engResponse.json();
550
- }
551
- return null;
552
- }));
553
- return engagements
554
- .filter((eng) => eng !== null)
555
- .map((eng) => mapActivityFromHubSpot(eng, contactId));
556
- }
557
- catch (error) {
558
- throw new Error(`Failed to list activities: ${error instanceof Error ? error.message : 'Unknown error'}`);
559
- }
560
- },
561
- };
562
- }
563
- /**
564
- * HubSpot provider definition
565
- */
566
- export const hubspotProvider = defineProvider(hubspotInfo, async (config) => createHubSpotProvider(config));
@@ -1,17 +0,0 @@
1
- /**
2
- * CRM Providers
3
- *
4
- * @packageDocumentation
5
- */
6
- export { hubspotInfo, hubspotProvider, createHubSpotProvider } from './hubspot.js';
7
- import { hubspotProvider } from './hubspot.js';
8
- /**
9
- * Register all CRM providers
10
- */
11
- export function registerCRMProviders() {
12
- hubspotProvider.register();
13
- }
14
- /**
15
- * All CRM providers
16
- */
17
- export const crmProviders = [hubspotProvider];