digital-tools 2.1.1 → 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 (293) hide show
  1. package/CHANGELOG.md +17 -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 +22 -20
  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 +21 -4
  132. package/src/client.ts +136 -0
  133. package/src/define.ts +31 -37
  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 -5
  199. package/dist/providers/voice/vapi.d.ts +0 -27
  200. package/dist/providers/voice/vapi.d.ts.map +0 -1
  201. package/dist/providers/voice/vapi.js +0 -440
  202. package/dist/providers/voice/vapi.js.map +0 -1
  203. package/src/define.js +0 -267
  204. package/src/entities/advertising.js +0 -999
  205. package/src/entities/ai.js +0 -756
  206. package/src/entities/analytics.js +0 -1588
  207. package/src/entities/automation.js +0 -601
  208. package/src/entities/communication.js +0 -1150
  209. package/src/entities/crm.js +0 -1386
  210. package/src/entities/design.js +0 -546
  211. package/src/entities/development.js +0 -2212
  212. package/src/entities/document.js +0 -874
  213. package/src/entities/ecommerce.js +0 -1429
  214. package/src/entities/experiment.js +0 -1039
  215. package/src/entities/finance.js +0 -3478
  216. package/src/entities/forms.js +0 -1892
  217. package/src/entities/hr.js +0 -661
  218. package/src/entities/identity.js +0 -997
  219. package/src/entities/index.js +0 -282
  220. package/src/entities/infrastructure.js +0 -1153
  221. package/src/entities/knowledge.js +0 -1438
  222. package/src/entities/marketing.js +0 -1610
  223. package/src/entities/media.js +0 -1634
  224. package/src/entities/notification.js +0 -1199
  225. package/src/entities/presentation.js +0 -1274
  226. package/src/entities/productivity.js +0 -1317
  227. package/src/entities/project-management.js +0 -1136
  228. package/src/entities/recruiting.js +0 -736
  229. package/src/entities/shipping.js +0 -509
  230. package/src/entities/signature.js +0 -1102
  231. package/src/entities/site.js +0 -222
  232. package/src/entities/spreadsheet.js +0 -1341
  233. package/src/entities/storage.js +0 -1198
  234. package/src/entities/support.js +0 -1166
  235. package/src/entities/video-conferencing.js +0 -1750
  236. package/src/entities/video.js +0 -950
  237. package/src/entities.js +0 -1663
  238. package/src/index.js +0 -74
  239. package/src/providers/analytics/index.js +0 -17
  240. package/src/providers/analytics/mixpanel.js +0 -255
  241. package/src/providers/calendar/cal-com.js +0 -303
  242. package/src/providers/calendar/google-calendar.js +0 -335
  243. package/src/providers/calendar/index.js +0 -20
  244. package/src/providers/crm/hubspot.js +0 -566
  245. package/src/providers/crm/index.js +0 -17
  246. package/src/providers/development/github.js +0 -472
  247. package/src/providers/development/index.js +0 -17
  248. package/src/providers/ecommerce/index.js +0 -17
  249. package/src/providers/ecommerce/shopify.js +0 -378
  250. package/src/providers/email/index.js +0 -20
  251. package/src/providers/email/resend.js +0 -258
  252. package/src/providers/email/sendgrid.js +0 -161
  253. package/src/providers/finance/index.js +0 -17
  254. package/src/providers/finance/stripe.js +0 -549
  255. package/src/providers/forms/index.js +0 -17
  256. package/src/providers/forms/typeform.js +0 -500
  257. package/src/providers/index.js +0 -123
  258. package/src/providers/knowledge/index.js +0 -17
  259. package/src/providers/knowledge/notion.js +0 -389
  260. package/src/providers/marketing/index.js +0 -17
  261. package/src/providers/marketing/mailchimp.js +0 -443
  262. package/src/providers/media/cloudinary.js +0 -318
  263. package/src/providers/media/index.js +0 -17
  264. package/src/providers/messaging/index.js +0 -20
  265. package/src/providers/messaging/slack.js +0 -393
  266. package/src/providers/messaging/twilio-sms.js +0 -249
  267. package/src/providers/project-management/index.js +0 -17
  268. package/src/providers/project-management/linear.js +0 -575
  269. package/src/providers/registry.js +0 -86
  270. package/src/providers/spreadsheet/google-sheets.js +0 -375
  271. package/src/providers/spreadsheet/index.js +0 -20
  272. package/src/providers/spreadsheet/xlsx.js +0 -423
  273. package/src/providers/storage/index.js +0 -24
  274. package/src/providers/storage/s3.js +0 -419
  275. package/src/providers/support/index.js +0 -17
  276. package/src/providers/support/zendesk.js +0 -373
  277. package/src/providers/tasks/index.js +0 -17
  278. package/src/providers/tasks/todoist.js +0 -286
  279. package/src/providers/types.js +0 -9
  280. package/src/providers/video-conferencing/google-meet.js +0 -286
  281. package/src/providers/video-conferencing/index.js +0 -31
  282. package/src/providers/video-conferencing/jitsi.js +0 -254
  283. package/src/providers/video-conferencing/teams.js +0 -270
  284. package/src/providers/video-conferencing/zoom.js +0 -332
  285. package/src/registry.js +0 -128
  286. package/src/tools/communication.js +0 -184
  287. package/src/tools/data.js +0 -205
  288. package/src/tools/index.js +0 -11
  289. package/src/tools/web.js +0 -137
  290. package/src/types.js +0 -10
  291. package/test/define.test.js +0 -306
  292. package/test/registry.test.js +0 -357
  293. 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];