@hasna/connectors 0.4.0 → 0.4.2

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 (390) hide show
  1. package/bin/index.js +189 -2
  2. package/bin/mcp.js +176 -1
  3. package/bin/serve.js +175 -0
  4. package/connectors/connect-airtable/.env.example +11 -0
  5. package/connectors/connect-airtable/CLAUDE.md +121 -0
  6. package/connectors/connect-airtable/README.md +193 -0
  7. package/connectors/connect-airtable/package.json +50 -0
  8. package/connectors/connect-airtable/src/api/client.ts +139 -0
  9. package/connectors/connect-airtable/src/api/index.ts +405 -0
  10. package/connectors/connect-airtable/src/cli/index.ts +637 -0
  11. package/connectors/connect-airtable/src/index.ts +20 -0
  12. package/connectors/connect-airtable/src/types/index.ts +349 -0
  13. package/connectors/connect-airtable/src/utils/config.ts +197 -0
  14. package/connectors/connect-airtable/tsconfig.json +16 -0
  15. package/connectors/connect-amplitude/.env.example +11 -0
  16. package/connectors/connect-amplitude/CLAUDE.md +121 -0
  17. package/connectors/connect-amplitude/README.md +193 -0
  18. package/connectors/connect-amplitude/package.json +51 -0
  19. package/connectors/connect-amplitude/src/api/client.ts +144 -0
  20. package/connectors/connect-amplitude/src/api/index.ts +215 -0
  21. package/connectors/connect-amplitude/src/cli/index.ts +532 -0
  22. package/connectors/connect-amplitude/src/index.ts +22 -0
  23. package/connectors/connect-amplitude/src/types/index.ts +329 -0
  24. package/connectors/connect-amplitude/src/utils/config.ts +208 -0
  25. package/connectors/connect-amplitude/tsconfig.json +16 -0
  26. package/connectors/connect-calendly/.env.example +11 -0
  27. package/connectors/connect-calendly/CLAUDE.md +272 -0
  28. package/connectors/connect-calendly/README.md +193 -0
  29. package/connectors/connect-calendly/package.json +51 -0
  30. package/connectors/connect-calendly/scripts/release.ts +179 -0
  31. package/connectors/connect-calendly/src/api/client.ts +213 -0
  32. package/connectors/connect-calendly/src/api/example.ts +48 -0
  33. package/connectors/connect-calendly/src/api/index.ts +51 -0
  34. package/connectors/connect-calendly/src/cli/index.ts +254 -0
  35. package/connectors/connect-calendly/src/index.ts +103 -0
  36. package/connectors/connect-calendly/src/types/index.ts +237 -0
  37. package/connectors/connect-calendly/src/utils/auth.ts +274 -0
  38. package/connectors/connect-calendly/src/utils/bulk.ts +212 -0
  39. package/connectors/connect-calendly/src/utils/config.ts +326 -0
  40. package/connectors/connect-calendly/src/utils/output.ts +175 -0
  41. package/connectors/connect-calendly/src/utils/settings.ts +114 -0
  42. package/connectors/connect-calendly/src/utils/storage.ts +198 -0
  43. package/connectors/connect-calendly/tsconfig.json +16 -0
  44. package/connectors/connect-convertkit/.env.example +11 -0
  45. package/connectors/connect-convertkit/CLAUDE.md +272 -0
  46. package/connectors/connect-convertkit/README.md +193 -0
  47. package/connectors/connect-convertkit/package.json +51 -0
  48. package/connectors/connect-convertkit/scripts/release.ts +179 -0
  49. package/connectors/connect-convertkit/src/api/client.ts +213 -0
  50. package/connectors/connect-convertkit/src/api/example.ts +48 -0
  51. package/connectors/connect-convertkit/src/api/index.ts +51 -0
  52. package/connectors/connect-convertkit/src/cli/index.ts +254 -0
  53. package/connectors/connect-convertkit/src/index.ts +103 -0
  54. package/connectors/connect-convertkit/src/types/index.ts +237 -0
  55. package/connectors/connect-convertkit/src/utils/auth.ts +274 -0
  56. package/connectors/connect-convertkit/src/utils/bulk.ts +212 -0
  57. package/connectors/connect-convertkit/src/utils/config.ts +326 -0
  58. package/connectors/connect-convertkit/src/utils/output.ts +175 -0
  59. package/connectors/connect-convertkit/src/utils/settings.ts +114 -0
  60. package/connectors/connect-convertkit/src/utils/storage.ts +198 -0
  61. package/connectors/connect-convertkit/tsconfig.json +16 -0
  62. package/connectors/connect-crisp/.env.example +11 -0
  63. package/connectors/connect-crisp/CLAUDE.md +272 -0
  64. package/connectors/connect-crisp/README.md +193 -0
  65. package/connectors/connect-crisp/package.json +51 -0
  66. package/connectors/connect-crisp/scripts/release.ts +179 -0
  67. package/connectors/connect-crisp/src/api/client.ts +213 -0
  68. package/connectors/connect-crisp/src/api/example.ts +48 -0
  69. package/connectors/connect-crisp/src/api/index.ts +51 -0
  70. package/connectors/connect-crisp/src/cli/index.ts +254 -0
  71. package/connectors/connect-crisp/src/index.ts +103 -0
  72. package/connectors/connect-crisp/src/types/index.ts +237 -0
  73. package/connectors/connect-crisp/src/utils/auth.ts +274 -0
  74. package/connectors/connect-crisp/src/utils/bulk.ts +212 -0
  75. package/connectors/connect-crisp/src/utils/config.ts +326 -0
  76. package/connectors/connect-crisp/src/utils/output.ts +175 -0
  77. package/connectors/connect-crisp/src/utils/settings.ts +114 -0
  78. package/connectors/connect-crisp/src/utils/storage.ts +198 -0
  79. package/connectors/connect-crisp/tsconfig.json +16 -0
  80. package/connectors/connect-docusign/.env.example +11 -0
  81. package/connectors/connect-docusign/CLAUDE.md +128 -0
  82. package/connectors/connect-docusign/README.md +193 -0
  83. package/connectors/connect-docusign/package.json +52 -0
  84. package/connectors/connect-docusign/src/api/client.ts +133 -0
  85. package/connectors/connect-docusign/src/api/index.ts +178 -0
  86. package/connectors/connect-docusign/src/cli/index.ts +381 -0
  87. package/connectors/connect-docusign/src/index.ts +23 -0
  88. package/connectors/connect-docusign/src/types/index.ts +208 -0
  89. package/connectors/connect-docusign/src/utils/config.ts +125 -0
  90. package/connectors/connect-docusign/src/utils/output.ts +119 -0
  91. package/connectors/connect-docusign/tsconfig.json +16 -0
  92. package/connectors/connect-drift/.env.example +11 -0
  93. package/connectors/connect-drift/CLAUDE.md +272 -0
  94. package/connectors/connect-drift/README.md +193 -0
  95. package/connectors/connect-drift/package.json +51 -0
  96. package/connectors/connect-drift/scripts/release.ts +179 -0
  97. package/connectors/connect-drift/src/api/client.ts +213 -0
  98. package/connectors/connect-drift/src/api/example.ts +48 -0
  99. package/connectors/connect-drift/src/api/index.ts +51 -0
  100. package/connectors/connect-drift/src/cli/index.ts +254 -0
  101. package/connectors/connect-drift/src/index.ts +103 -0
  102. package/connectors/connect-drift/src/types/index.ts +237 -0
  103. package/connectors/connect-drift/src/utils/auth.ts +274 -0
  104. package/connectors/connect-drift/src/utils/bulk.ts +212 -0
  105. package/connectors/connect-drift/src/utils/config.ts +326 -0
  106. package/connectors/connect-drift/src/utils/output.ts +175 -0
  107. package/connectors/connect-drift/src/utils/settings.ts +114 -0
  108. package/connectors/connect-drift/src/utils/storage.ts +198 -0
  109. package/connectors/connect-drift/tsconfig.json +16 -0
  110. package/connectors/connect-freshdesk/.env.example +11 -0
  111. package/connectors/connect-freshdesk/CLAUDE.md +272 -0
  112. package/connectors/connect-freshdesk/README.md +193 -0
  113. package/connectors/connect-freshdesk/package.json +51 -0
  114. package/connectors/connect-freshdesk/scripts/release.ts +179 -0
  115. package/connectors/connect-freshdesk/src/api/client.ts +213 -0
  116. package/connectors/connect-freshdesk/src/api/example.ts +48 -0
  117. package/connectors/connect-freshdesk/src/api/index.ts +51 -0
  118. package/connectors/connect-freshdesk/src/cli/index.ts +254 -0
  119. package/connectors/connect-freshdesk/src/index.ts +103 -0
  120. package/connectors/connect-freshdesk/src/types/index.ts +237 -0
  121. package/connectors/connect-freshdesk/src/utils/auth.ts +274 -0
  122. package/connectors/connect-freshdesk/src/utils/bulk.ts +212 -0
  123. package/connectors/connect-freshdesk/src/utils/config.ts +326 -0
  124. package/connectors/connect-freshdesk/src/utils/output.ts +175 -0
  125. package/connectors/connect-freshdesk/src/utils/settings.ts +114 -0
  126. package/connectors/connect-freshdesk/src/utils/storage.ts +198 -0
  127. package/connectors/connect-freshdesk/tsconfig.json +16 -0
  128. package/connectors/connect-gumroad/.env.example +11 -0
  129. package/connectors/connect-gumroad/CLAUDE.md +272 -0
  130. package/connectors/connect-gumroad/README.md +193 -0
  131. package/connectors/connect-gumroad/package.json +51 -0
  132. package/connectors/connect-gumroad/scripts/release.ts +179 -0
  133. package/connectors/connect-gumroad/src/api/client.ts +213 -0
  134. package/connectors/connect-gumroad/src/api/example.ts +48 -0
  135. package/connectors/connect-gumroad/src/api/index.ts +51 -0
  136. package/connectors/connect-gumroad/src/cli/index.ts +254 -0
  137. package/connectors/connect-gumroad/src/index.ts +103 -0
  138. package/connectors/connect-gumroad/src/types/index.ts +237 -0
  139. package/connectors/connect-gumroad/src/utils/auth.ts +274 -0
  140. package/connectors/connect-gumroad/src/utils/bulk.ts +212 -0
  141. package/connectors/connect-gumroad/src/utils/config.ts +326 -0
  142. package/connectors/connect-gumroad/src/utils/output.ts +175 -0
  143. package/connectors/connect-gumroad/src/utils/settings.ts +114 -0
  144. package/connectors/connect-gumroad/src/utils/storage.ts +198 -0
  145. package/connectors/connect-gumroad/tsconfig.json +16 -0
  146. package/connectors/connect-hubspot/.env.example +11 -0
  147. package/connectors/connect-hubspot/CLAUDE.md +128 -0
  148. package/connectors/connect-hubspot/README.md +193 -0
  149. package/connectors/connect-hubspot/package.json +52 -0
  150. package/connectors/connect-hubspot/src/api/client.ts +136 -0
  151. package/connectors/connect-hubspot/src/api/index.ts +379 -0
  152. package/connectors/connect-hubspot/src/cli/index.ts +589 -0
  153. package/connectors/connect-hubspot/src/index.ts +21 -0
  154. package/connectors/connect-hubspot/src/types/index.ts +285 -0
  155. package/connectors/connect-hubspot/src/utils/config.ts +205 -0
  156. package/connectors/connect-hubspot/src/utils/output.ts +119 -0
  157. package/connectors/connect-hubspot/tsconfig.json +16 -0
  158. package/connectors/connect-intercom/.env.example +11 -0
  159. package/connectors/connect-intercom/CLAUDE.md +131 -0
  160. package/connectors/connect-intercom/README.md +193 -0
  161. package/connectors/connect-intercom/package.json +52 -0
  162. package/connectors/connect-intercom/src/api/client.ts +132 -0
  163. package/connectors/connect-intercom/src/api/index.ts +366 -0
  164. package/connectors/connect-intercom/src/cli/index.ts +831 -0
  165. package/connectors/connect-intercom/src/index.ts +21 -0
  166. package/connectors/connect-intercom/src/types/index.ts +650 -0
  167. package/connectors/connect-intercom/src/utils/config.ts +157 -0
  168. package/connectors/connect-intercom/src/utils/output.ts +119 -0
  169. package/connectors/connect-intercom/tsconfig.json +16 -0
  170. package/connectors/connect-lemonsqueezy/.env.example +11 -0
  171. package/connectors/connect-lemonsqueezy/CLAUDE.md +128 -0
  172. package/connectors/connect-lemonsqueezy/README.md +193 -0
  173. package/connectors/connect-lemonsqueezy/package.json +52 -0
  174. package/connectors/connect-lemonsqueezy/src/api/client.ts +133 -0
  175. package/connectors/connect-lemonsqueezy/src/api/index.ts +502 -0
  176. package/connectors/connect-lemonsqueezy/src/cli/index.ts +723 -0
  177. package/connectors/connect-lemonsqueezy/src/index.ts +21 -0
  178. package/connectors/connect-lemonsqueezy/src/types/index.ts +353 -0
  179. package/connectors/connect-lemonsqueezy/src/utils/config.ts +205 -0
  180. package/connectors/connect-lemonsqueezy/src/utils/output.ts +119 -0
  181. package/connectors/connect-lemonsqueezy/tsconfig.json +16 -0
  182. package/connectors/connect-linkedin/.env.example +11 -0
  183. package/connectors/connect-linkedin/CLAUDE.md +124 -0
  184. package/connectors/connect-linkedin/README.md +193 -0
  185. package/connectors/connect-linkedin/package.json +52 -0
  186. package/connectors/connect-linkedin/src/api/client.ts +132 -0
  187. package/connectors/connect-linkedin/src/api/index.ts +313 -0
  188. package/connectors/connect-linkedin/src/cli/index.ts +548 -0
  189. package/connectors/connect-linkedin/src/index.ts +21 -0
  190. package/connectors/connect-linkedin/src/types/index.ts +472 -0
  191. package/connectors/connect-linkedin/src/utils/config.ts +157 -0
  192. package/connectors/connect-linkedin/src/utils/output.ts +119 -0
  193. package/connectors/connect-linkedin/tsconfig.json +16 -0
  194. package/connectors/connect-mailchimp/.env.example +11 -0
  195. package/connectors/connect-mailchimp/CLAUDE.md +127 -0
  196. package/connectors/connect-mailchimp/README.md +193 -0
  197. package/connectors/connect-mailchimp/package.json +52 -0
  198. package/connectors/connect-mailchimp/src/api/client.ts +162 -0
  199. package/connectors/connect-mailchimp/src/api/index.ts +580 -0
  200. package/connectors/connect-mailchimp/src/cli/index.ts +822 -0
  201. package/connectors/connect-mailchimp/src/index.ts +23 -0
  202. package/connectors/connect-mailchimp/src/types/index.ts +585 -0
  203. package/connectors/connect-mailchimp/src/utils/config.ts +208 -0
  204. package/connectors/connect-mailchimp/src/utils/output.ts +119 -0
  205. package/connectors/connect-mailchimp/tsconfig.json +16 -0
  206. package/connectors/connect-mongodb/.env.example +11 -0
  207. package/connectors/connect-mongodb/CLAUDE.md +272 -0
  208. package/connectors/connect-mongodb/README.md +193 -0
  209. package/connectors/connect-mongodb/package.json +51 -0
  210. package/connectors/connect-mongodb/scripts/release.ts +179 -0
  211. package/connectors/connect-mongodb/src/api/client.ts +213 -0
  212. package/connectors/connect-mongodb/src/api/example.ts +48 -0
  213. package/connectors/connect-mongodb/src/api/index.ts +51 -0
  214. package/connectors/connect-mongodb/src/cli/index.ts +254 -0
  215. package/connectors/connect-mongodb/src/index.ts +103 -0
  216. package/connectors/connect-mongodb/src/types/index.ts +237 -0
  217. package/connectors/connect-mongodb/src/utils/auth.ts +274 -0
  218. package/connectors/connect-mongodb/src/utils/bulk.ts +212 -0
  219. package/connectors/connect-mongodb/src/utils/config.ts +326 -0
  220. package/connectors/connect-mongodb/src/utils/output.ts +175 -0
  221. package/connectors/connect-mongodb/src/utils/settings.ts +114 -0
  222. package/connectors/connect-mongodb/src/utils/storage.ts +198 -0
  223. package/connectors/connect-mongodb/tsconfig.json +16 -0
  224. package/connectors/connect-netlify/.env.example +11 -0
  225. package/connectors/connect-netlify/CLAUDE.md +170 -0
  226. package/connectors/connect-netlify/README.md +193 -0
  227. package/connectors/connect-netlify/package.json +53 -0
  228. package/connectors/connect-netlify/src/api/client.ts +132 -0
  229. package/connectors/connect-netlify/src/api/index.ts +533 -0
  230. package/connectors/connect-netlify/src/cli/index.ts +985 -0
  231. package/connectors/connect-netlify/src/index.ts +22 -0
  232. package/connectors/connect-netlify/src/types/index.ts +423 -0
  233. package/connectors/connect-netlify/src/utils/config.ts +171 -0
  234. package/connectors/connect-netlify/src/utils/output.ts +119 -0
  235. package/connectors/connect-netlify/tsconfig.json +16 -0
  236. package/connectors/connect-paypal/.env.example +11 -0
  237. package/connectors/connect-paypal/CLAUDE.md +128 -0
  238. package/connectors/connect-paypal/README.md +193 -0
  239. package/connectors/connect-paypal/package.json +51 -0
  240. package/connectors/connect-paypal/src/api/client.ts +182 -0
  241. package/connectors/connect-paypal/src/api/index.ts +235 -0
  242. package/connectors/connect-paypal/src/cli/index.ts +559 -0
  243. package/connectors/connect-paypal/src/index.ts +23 -0
  244. package/connectors/connect-paypal/src/types/index.ts +377 -0
  245. package/connectors/connect-paypal/src/utils/config.ts +125 -0
  246. package/connectors/connect-paypal/src/utils/output.ts +119 -0
  247. package/connectors/connect-paypal/tsconfig.json +16 -0
  248. package/connectors/connect-pinterest/.env.example +11 -0
  249. package/connectors/connect-pinterest/CLAUDE.md +115 -0
  250. package/connectors/connect-pinterest/README.md +193 -0
  251. package/connectors/connect-pinterest/package.json +52 -0
  252. package/connectors/connect-pinterest/src/api/client.ts +125 -0
  253. package/connectors/connect-pinterest/src/api/index.ts +203 -0
  254. package/connectors/connect-pinterest/src/cli/index.ts +653 -0
  255. package/connectors/connect-pinterest/src/index.ts +21 -0
  256. package/connectors/connect-pinterest/src/types/index.ts +268 -0
  257. package/connectors/connect-pinterest/src/utils/config.ts +157 -0
  258. package/connectors/connect-pinterest/src/utils/output.ts +119 -0
  259. package/connectors/connect-pinterest/tsconfig.json +16 -0
  260. package/connectors/connect-posthog/.env.example +11 -0
  261. package/connectors/connect-posthog/CLAUDE.md +272 -0
  262. package/connectors/connect-posthog/README.md +193 -0
  263. package/connectors/connect-posthog/package.json +51 -0
  264. package/connectors/connect-posthog/scripts/release.ts +179 -0
  265. package/connectors/connect-posthog/src/api/client.ts +213 -0
  266. package/connectors/connect-posthog/src/api/example.ts +48 -0
  267. package/connectors/connect-posthog/src/api/index.ts +51 -0
  268. package/connectors/connect-posthog/src/cli/index.ts +254 -0
  269. package/connectors/connect-posthog/src/index.ts +103 -0
  270. package/connectors/connect-posthog/src/types/index.ts +237 -0
  271. package/connectors/connect-posthog/src/utils/auth.ts +274 -0
  272. package/connectors/connect-posthog/src/utils/bulk.ts +212 -0
  273. package/connectors/connect-posthog/src/utils/config.ts +326 -0
  274. package/connectors/connect-posthog/src/utils/output.ts +175 -0
  275. package/connectors/connect-posthog/src/utils/settings.ts +114 -0
  276. package/connectors/connect-posthog/src/utils/storage.ts +198 -0
  277. package/connectors/connect-posthog/tsconfig.json +16 -0
  278. package/connectors/connect-salesforce/.env.example +11 -0
  279. package/connectors/connect-salesforce/CLAUDE.md +128 -0
  280. package/connectors/connect-salesforce/README.md +193 -0
  281. package/connectors/connect-salesforce/package.json +53 -0
  282. package/connectors/connect-salesforce/src/api/client.ts +150 -0
  283. package/connectors/connect-salesforce/src/api/index.ts +367 -0
  284. package/connectors/connect-salesforce/src/cli/index.ts +594 -0
  285. package/connectors/connect-salesforce/src/index.ts +21 -0
  286. package/connectors/connect-salesforce/src/types/index.ts +292 -0
  287. package/connectors/connect-salesforce/src/utils/config.ts +208 -0
  288. package/connectors/connect-salesforce/src/utils/output.ts +119 -0
  289. package/connectors/connect-salesforce/tsconfig.json +16 -0
  290. package/connectors/connect-segment/.env.example +11 -0
  291. package/connectors/connect-segment/CLAUDE.md +272 -0
  292. package/connectors/connect-segment/README.md +193 -0
  293. package/connectors/connect-segment/package.json +51 -0
  294. package/connectors/connect-segment/scripts/release.ts +179 -0
  295. package/connectors/connect-segment/src/api/client.ts +213 -0
  296. package/connectors/connect-segment/src/api/example.ts +48 -0
  297. package/connectors/connect-segment/src/api/index.ts +51 -0
  298. package/connectors/connect-segment/src/cli/index.ts +254 -0
  299. package/connectors/connect-segment/src/index.ts +103 -0
  300. package/connectors/connect-segment/src/types/index.ts +237 -0
  301. package/connectors/connect-segment/src/utils/auth.ts +274 -0
  302. package/connectors/connect-segment/src/utils/bulk.ts +212 -0
  303. package/connectors/connect-segment/src/utils/config.ts +326 -0
  304. package/connectors/connect-segment/src/utils/output.ts +175 -0
  305. package/connectors/connect-segment/src/utils/settings.ts +114 -0
  306. package/connectors/connect-segment/src/utils/storage.ts +198 -0
  307. package/connectors/connect-segment/tsconfig.json +16 -0
  308. package/connectors/connect-sendgrid/.env.example +11 -0
  309. package/connectors/connect-sendgrid/CLAUDE.md +125 -0
  310. package/connectors/connect-sendgrid/README.md +193 -0
  311. package/connectors/connect-sendgrid/package.json +53 -0
  312. package/connectors/connect-sendgrid/src/api/client.ts +137 -0
  313. package/connectors/connect-sendgrid/src/api/index.ts +588 -0
  314. package/connectors/connect-sendgrid/src/cli/index.ts +764 -0
  315. package/connectors/connect-sendgrid/src/index.ts +21 -0
  316. package/connectors/connect-sendgrid/src/types/index.ts +403 -0
  317. package/connectors/connect-sendgrid/src/utils/config.ts +197 -0
  318. package/connectors/connect-sendgrid/src/utils/output.ts +119 -0
  319. package/connectors/connect-sendgrid/tsconfig.json +16 -0
  320. package/connectors/connect-supabase/.env.example +11 -0
  321. package/connectors/connect-supabase/CLAUDE.md +132 -0
  322. package/connectors/connect-supabase/README.md +193 -0
  323. package/connectors/connect-supabase/package.json +52 -0
  324. package/connectors/connect-supabase/src/api/client.ts +231 -0
  325. package/connectors/connect-supabase/src/api/index.ts +439 -0
  326. package/connectors/connect-supabase/src/cli/index.ts +691 -0
  327. package/connectors/connect-supabase/src/index.ts +24 -0
  328. package/connectors/connect-supabase/src/types/index.ts +215 -0
  329. package/connectors/connect-supabase/src/utils/config.ts +219 -0
  330. package/connectors/connect-supabase/tsconfig.json +16 -0
  331. package/connectors/connect-vercel/.env.example +11 -0
  332. package/connectors/connect-vercel/CLAUDE.md +142 -0
  333. package/connectors/connect-vercel/README.md +193 -0
  334. package/connectors/connect-vercel/package.json +52 -0
  335. package/connectors/connect-vercel/src/api/client.ts +139 -0
  336. package/connectors/connect-vercel/src/api/index.ts +384 -0
  337. package/connectors/connect-vercel/src/cli/index.ts +740 -0
  338. package/connectors/connect-vercel/src/index.ts +24 -0
  339. package/connectors/connect-vercel/src/types/index.ts +350 -0
  340. package/connectors/connect-vercel/src/utils/config.ts +182 -0
  341. package/connectors/connect-vercel/src/utils/output.ts +119 -0
  342. package/connectors/connect-vercel/tsconfig.json +16 -0
  343. package/connectors/connect-zendesk/.env.example +10 -0
  344. package/connectors/connect-zendesk/.github/workflows/deploy.yml +51 -0
  345. package/connectors/connect-zendesk/CLAUDE.md +78 -0
  346. package/connectors/connect-zendesk/Makefile +129 -0
  347. package/connectors/connect-zendesk/README.md +295 -0
  348. package/connectors/connect-zendesk/SCAFFOLD.md +178 -0
  349. package/connectors/connect-zendesk/nginx-connector.conf +218 -0
  350. package/connectors/connect-zendesk/nginx.conf +61 -0
  351. package/connectors/connect-zendesk/package.json +71 -0
  352. package/connectors/connect-zendesk/scripts/init.sh +62 -0
  353. package/connectors/connect-zendesk/scripts/publish.ts +210 -0
  354. package/connectors/connect-zendesk/server/index.js +142 -0
  355. package/connectors/connect-zendesk/src/api/automations.ts +95 -0
  356. package/connectors/connect-zendesk/src/api/brands.ts +80 -0
  357. package/connectors/connect-zendesk/src/api/bulk.ts +838 -0
  358. package/connectors/connect-zendesk/src/api/client.test.ts +315 -0
  359. package/connectors/connect-zendesk/src/api/client.ts +173 -0
  360. package/connectors/connect-zendesk/src/api/example.ts +59 -0
  361. package/connectors/connect-zendesk/src/api/groups.ts +60 -0
  362. package/connectors/connect-zendesk/src/api/index.test.ts +111 -0
  363. package/connectors/connect-zendesk/src/api/index.ts +131 -0
  364. package/connectors/connect-zendesk/src/api/macros.ts +124 -0
  365. package/connectors/connect-zendesk/src/api/organizations.ts +85 -0
  366. package/connectors/connect-zendesk/src/api/slas.ts +80 -0
  367. package/connectors/connect-zendesk/src/api/ticket-fields.ts +98 -0
  368. package/connectors/connect-zendesk/src/api/tickets.test.ts +215 -0
  369. package/connectors/connect-zendesk/src/api/tickets.ts +103 -0
  370. package/connectors/connect-zendesk/src/api/triggers.test.ts +204 -0
  371. package/connectors/connect-zendesk/src/api/triggers.ts +125 -0
  372. package/connectors/connect-zendesk/src/api/users.test.ts +180 -0
  373. package/connectors/connect-zendesk/src/api/users.ts +108 -0
  374. package/connectors/connect-zendesk/src/api/views.test.ts +223 -0
  375. package/connectors/connect-zendesk/src/api/views.ts +145 -0
  376. package/connectors/connect-zendesk/src/api/webhooks.test.ts +208 -0
  377. package/connectors/connect-zendesk/src/api/webhooks.ts +118 -0
  378. package/connectors/connect-zendesk/src/cli/index.ts +1478 -0
  379. package/connectors/connect-zendesk/src/index.ts +36 -0
  380. package/connectors/connect-zendesk/src/server/index.ts +204 -0
  381. package/connectors/connect-zendesk/src/types/index.ts +910 -0
  382. package/connectors/connect-zendesk/src/utils/config.test.ts +193 -0
  383. package/connectors/connect-zendesk/src/utils/config.ts +526 -0
  384. package/connectors/connect-zendesk/src/utils/export.ts +338 -0
  385. package/connectors/connect-zendesk/src/utils/logger.ts +105 -0
  386. package/connectors/connect-zendesk/src/utils/output.test.ts +137 -0
  387. package/connectors/connect-zendesk/src/utils/output.ts +119 -0
  388. package/connectors/connect-zendesk/tsconfig.json +31 -0
  389. package/dist/index.js +175 -0
  390. package/package.json +1 -1
@@ -0,0 +1,133 @@
1
+ import type { DocuSignConfig, OutputFormat } from '../types';
2
+ import { DocuSignApiError } from '../types';
3
+
4
+ // Demo environment - change to https://www.docusign.net/restapi for production
5
+ const DEFAULT_BASE_URL = 'https://demo.docusign.net/restapi/v2.1';
6
+
7
+ export interface RequestOptions {
8
+ method?: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';
9
+ params?: Record<string, string | number | boolean | undefined>;
10
+ body?: Record<string, unknown> | unknown[] | string;
11
+ headers?: Record<string, string>;
12
+ format?: OutputFormat;
13
+ }
14
+
15
+ export class DocuSignClient {
16
+ private readonly accessToken: string;
17
+ private readonly accountId: string;
18
+ private readonly baseUrl: string;
19
+
20
+ constructor(config: DocuSignConfig) {
21
+ if (!config.accessToken) {
22
+ throw new Error('Access token is required');
23
+ }
24
+ if (!config.accountId) {
25
+ throw new Error('Account ID is required');
26
+ }
27
+ this.accessToken = config.accessToken;
28
+ this.accountId = config.accountId;
29
+ this.baseUrl = config.baseUrl || DEFAULT_BASE_URL;
30
+ }
31
+
32
+ private buildUrl(path: string, params?: Record<string, string | number | boolean | undefined>): string {
33
+ // Replace {accountId} placeholder in path
34
+ const fullPath = path.replace('{accountId}', this.accountId);
35
+ const url = new URL(`${this.baseUrl}${fullPath}`);
36
+
37
+ if (params) {
38
+ Object.entries(params).forEach(([key, value]) => {
39
+ if (value !== undefined && value !== null && value !== '') {
40
+ url.searchParams.append(key, String(value));
41
+ }
42
+ });
43
+ }
44
+
45
+ return url.toString();
46
+ }
47
+
48
+ async request<T>(path: string, options: RequestOptions = {}): Promise<T> {
49
+ const { method = 'GET', params, body, headers = {} } = options;
50
+
51
+ const url = this.buildUrl(path, params);
52
+
53
+ const requestHeaders: Record<string, string> = {
54
+ 'Authorization': `Bearer ${this.accessToken}`,
55
+ 'Accept': 'application/json',
56
+ ...headers,
57
+ };
58
+
59
+ if (body && ['POST', 'PUT', 'PATCH'].includes(method)) {
60
+ requestHeaders['Content-Type'] = 'application/json';
61
+ }
62
+
63
+ const fetchOptions: RequestInit = {
64
+ method,
65
+ headers: requestHeaders,
66
+ };
67
+
68
+ if (body && ['POST', 'PUT', 'PATCH'].includes(method)) {
69
+ fetchOptions.body = typeof body === 'string' ? body : JSON.stringify(body);
70
+ }
71
+
72
+ const response = await fetch(url, fetchOptions);
73
+
74
+ // Handle 204 No Content
75
+ if (response.status === 204) {
76
+ return {} as T;
77
+ }
78
+
79
+ // Parse response
80
+ let data: unknown;
81
+ const contentType = response.headers.get('content-type') || '';
82
+
83
+ if (contentType.includes('application/json')) {
84
+ const text = await response.text();
85
+ if (text) {
86
+ try {
87
+ data = JSON.parse(text);
88
+ } catch {
89
+ data = text;
90
+ }
91
+ }
92
+ } else {
93
+ data = await response.text();
94
+ }
95
+
96
+ // Handle errors
97
+ if (!response.ok) {
98
+ const errorMessage = typeof data === 'object' && data !== null
99
+ ? JSON.stringify(data)
100
+ : String(data || response.statusText);
101
+ throw new DocuSignApiError(errorMessage, response.status);
102
+ }
103
+
104
+ return data as T;
105
+ }
106
+
107
+ async get<T>(path: string, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
108
+ return this.request<T>(path, { method: 'GET', params });
109
+ }
110
+
111
+ async post<T>(path: string, body?: Record<string, unknown> | unknown[] | string | object, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
112
+ return this.request<T>(path, { method: 'POST', body: body as Record<string, unknown>, params });
113
+ }
114
+
115
+ async put<T>(path: string, body?: Record<string, unknown> | object, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
116
+ return this.request<T>(path, { method: 'PUT', body: body as Record<string, unknown>, params });
117
+ }
118
+
119
+ async delete<T>(path: string, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
120
+ return this.request<T>(path, { method: 'DELETE', params });
121
+ }
122
+
123
+ getAccessTokenPreview(): string {
124
+ if (this.accessToken.length > 10) {
125
+ return `${this.accessToken.substring(0, 6)}...${this.accessToken.substring(this.accessToken.length - 4)}`;
126
+ }
127
+ return '***';
128
+ }
129
+
130
+ getAccountId(): string {
131
+ return this.accountId;
132
+ }
133
+ }
@@ -0,0 +1,178 @@
1
+ import type {
2
+ DocuSignConfig,
3
+ Envelope,
4
+ EnvelopesListResponse,
5
+ EnvelopeResponse,
6
+ CreateEnvelopeOptions,
7
+ TemplatesListResponse,
8
+ Template,
9
+ UserInfo,
10
+ } from '../types';
11
+ import { DocuSignClient } from './client';
12
+
13
+ /**
14
+ * DocuSign API Client
15
+ * Electronic signature API with envelope management
16
+ */
17
+ export class DocuSign {
18
+ private readonly client: DocuSignClient;
19
+
20
+ constructor(config: DocuSignConfig) {
21
+ this.client = new DocuSignClient(config);
22
+ }
23
+
24
+ /**
25
+ * Create a client from environment variables
26
+ */
27
+ static fromEnv(): DocuSign {
28
+ const accessToken = process.env.DOCUSIGN_ACCESS_TOKEN;
29
+ const accountId = process.env.DOCUSIGN_ACCOUNT_ID;
30
+ const baseUrl = process.env.DOCUSIGN_BASE_URL;
31
+
32
+ if (!accessToken) {
33
+ throw new Error('DOCUSIGN_ACCESS_TOKEN environment variable is required');
34
+ }
35
+ if (!accountId) {
36
+ throw new Error('DOCUSIGN_ACCOUNT_ID environment variable is required');
37
+ }
38
+ return new DocuSign({ accessToken, accountId, baseUrl });
39
+ }
40
+
41
+ // ============================================
42
+ // Envelope Methods
43
+ // ============================================
44
+
45
+ /**
46
+ * List envelopes
47
+ */
48
+ async listEnvelopes(options?: {
49
+ from_date?: string;
50
+ to_date?: string;
51
+ status?: string;
52
+ count?: number;
53
+ }): Promise<EnvelopesListResponse> {
54
+ const params: Record<string, string | number | undefined> = {
55
+ from_date: options?.from_date,
56
+ to_date: options?.to_date,
57
+ status: options?.status,
58
+ count: options?.count,
59
+ };
60
+ return this.client.get<EnvelopesListResponse>('/accounts/{accountId}/envelopes', params);
61
+ }
62
+
63
+ /**
64
+ * Get an envelope by ID
65
+ */
66
+ async getEnvelope(envelopeId: string): Promise<Envelope> {
67
+ return this.client.get<Envelope>(`/accounts/{accountId}/envelopes/${envelopeId}`);
68
+ }
69
+
70
+ /**
71
+ * Create an envelope
72
+ */
73
+ async createEnvelope(options: CreateEnvelopeOptions): Promise<EnvelopeResponse> {
74
+ return this.client.post<EnvelopeResponse>('/accounts/{accountId}/envelopes', {
75
+ emailSubject: options.emailSubject,
76
+ emailBlurb: options.emailBlurb,
77
+ documents: options.documents,
78
+ recipients: options.recipients,
79
+ status: options.status || 'created',
80
+ });
81
+ }
82
+
83
+ /**
84
+ * Send an envelope (change status to 'sent')
85
+ */
86
+ async sendEnvelope(envelopeId: string): Promise<EnvelopeResponse> {
87
+ return this.client.put<EnvelopeResponse>(`/accounts/{accountId}/envelopes/${envelopeId}`, {
88
+ status: 'sent',
89
+ });
90
+ }
91
+
92
+ /**
93
+ * Void an envelope
94
+ */
95
+ async voidEnvelope(envelopeId: string, voidedReason: string): Promise<EnvelopeResponse> {
96
+ return this.client.put<EnvelopeResponse>(`/accounts/{accountId}/envelopes/${envelopeId}`, {
97
+ status: 'voided',
98
+ voidedReason,
99
+ });
100
+ }
101
+
102
+ // ============================================
103
+ // Template Methods
104
+ // ============================================
105
+
106
+ /**
107
+ * List templates
108
+ */
109
+ async listTemplates(options?: {
110
+ count?: number;
111
+ start_position?: number;
112
+ search_text?: string;
113
+ }): Promise<TemplatesListResponse> {
114
+ const params: Record<string, string | number | undefined> = {
115
+ count: options?.count,
116
+ start_position: options?.start_position,
117
+ search_text: options?.search_text,
118
+ };
119
+ return this.client.get<TemplatesListResponse>('/accounts/{accountId}/templates', params);
120
+ }
121
+
122
+ /**
123
+ * Get a template by ID
124
+ */
125
+ async getTemplate(templateId: string): Promise<Template> {
126
+ return this.client.get<Template>(`/accounts/{accountId}/templates/${templateId}`);
127
+ }
128
+
129
+ /**
130
+ * Create envelope from template
131
+ */
132
+ async createEnvelopeFromTemplate(options: {
133
+ templateId: string;
134
+ emailSubject?: string;
135
+ emailBlurb?: string;
136
+ status?: 'created' | 'sent';
137
+ templateRoles?: Array<{
138
+ email: string;
139
+ name: string;
140
+ roleName: string;
141
+ }>;
142
+ }): Promise<EnvelopeResponse> {
143
+ return this.client.post<EnvelopeResponse>('/accounts/{accountId}/envelopes', {
144
+ templateId: options.templateId,
145
+ emailSubject: options.emailSubject,
146
+ emailBlurb: options.emailBlurb,
147
+ status: options.status || 'created',
148
+ templateRoles: options.templateRoles,
149
+ });
150
+ }
151
+
152
+ // ============================================
153
+ // Utility Methods
154
+ // ============================================
155
+
156
+ /**
157
+ * Get a preview of the access token
158
+ */
159
+ getAccessTokenPreview(): string {
160
+ return this.client.getAccessTokenPreview();
161
+ }
162
+
163
+ /**
164
+ * Get the account ID
165
+ */
166
+ getAccountId(): string {
167
+ return this.client.getAccountId();
168
+ }
169
+
170
+ /**
171
+ * Get the underlying client for direct API access
172
+ */
173
+ getClient(): DocuSignClient {
174
+ return this.client;
175
+ }
176
+ }
177
+
178
+ export { DocuSignClient } from './client';
@@ -0,0 +1,381 @@
1
+ #!/usr/bin/env bun
2
+ import { Command } from 'commander';
3
+ import chalk from 'chalk';
4
+ import { DocuSign } from '../api';
5
+ import {
6
+ getAccessToken,
7
+ setAccessToken,
8
+ getAccountId,
9
+ setAccountId,
10
+ getBaseUrl,
11
+ setBaseUrl,
12
+ clearConfig,
13
+ getConfigDir,
14
+ setProfileOverride,
15
+ getCurrentProfile,
16
+ setCurrentProfile,
17
+ listProfiles,
18
+ createProfile,
19
+ deleteProfile,
20
+ profileExists,
21
+ loadProfile,
22
+ } from '../utils/config';
23
+ import type { OutputFormat } from '../utils/output';
24
+ import { success, error, info, print } from '../utils/output';
25
+
26
+ const CONNECTOR_NAME = 'connect-docusign';
27
+ const VERSION = '0.0.1';
28
+
29
+ const program = new Command();
30
+
31
+ program
32
+ .name(CONNECTOR_NAME)
33
+ .description('DocuSign connector CLI - Electronic signature with envelope management')
34
+ .version(VERSION)
35
+ .option('-t, --token <token>', 'Access token (overrides config)')
36
+ .option('-a, --account <id>', 'Account ID (overrides config)')
37
+ .option('-f, --format <format>', 'Output format (json, pretty)', 'pretty')
38
+ .option('-p, --profile <profile>', 'Use a specific profile')
39
+ .hook('preAction', (thisCommand) => {
40
+ const opts = thisCommand.opts();
41
+ if (opts.profile) {
42
+ if (!profileExists(opts.profile)) {
43
+ error(`Profile "${opts.profile}" does not exist. Create it with "${CONNECTOR_NAME} profile create ${opts.profile}"`);
44
+ process.exit(1);
45
+ }
46
+ setProfileOverride(opts.profile);
47
+ }
48
+ if (opts.token) {
49
+ process.env.DOCUSIGN_ACCESS_TOKEN = opts.token;
50
+ }
51
+ if (opts.account) {
52
+ process.env.DOCUSIGN_ACCOUNT_ID = opts.account;
53
+ }
54
+ });
55
+
56
+ function getFormat(cmd: Command): OutputFormat {
57
+ const parent = cmd.parent;
58
+ return (parent?.opts().format || 'pretty') as OutputFormat;
59
+ }
60
+
61
+ function getClient(): DocuSign {
62
+ const accessToken = getAccessToken();
63
+ const accountId = getAccountId();
64
+ const baseUrl = getBaseUrl();
65
+
66
+ if (!accessToken) {
67
+ error(`No access token configured. Run "${CONNECTOR_NAME} config set-token <token>" or set DOCUSIGN_ACCESS_TOKEN.`);
68
+ process.exit(1);
69
+ }
70
+ if (!accountId) {
71
+ error(`No account ID configured. Run "${CONNECTOR_NAME} config set-account <id>" or set DOCUSIGN_ACCOUNT_ID.`);
72
+ process.exit(1);
73
+ }
74
+ return new DocuSign({ accessToken, accountId, baseUrl });
75
+ }
76
+
77
+ // ============================================
78
+ // Profile Commands
79
+ // ============================================
80
+ const profileCmd = program
81
+ .command('profile')
82
+ .description('Manage configuration profiles');
83
+
84
+ profileCmd
85
+ .command('list')
86
+ .description('List all profiles')
87
+ .action(() => {
88
+ const profiles = listProfiles();
89
+ const current = getCurrentProfile();
90
+ if (profiles.length === 0) {
91
+ info('No profiles found. Use "profile create <name>" to create one.');
92
+ return;
93
+ }
94
+ success(`Profiles:`);
95
+ profiles.forEach(p => {
96
+ const isActive = p === current ? chalk.green(' (active)') : '';
97
+ console.log(` ${p}${isActive}`);
98
+ });
99
+ });
100
+
101
+ profileCmd
102
+ .command('use <name>')
103
+ .description('Switch to a profile')
104
+ .action((name: string) => {
105
+ if (!profileExists(name)) {
106
+ error(`Profile "${name}" does not exist. Create it with "profile create ${name}"`);
107
+ process.exit(1);
108
+ }
109
+ setCurrentProfile(name);
110
+ success(`Switched to profile: ${name}`);
111
+ });
112
+
113
+ profileCmd
114
+ .command('create <name>')
115
+ .description('Create a new profile')
116
+ .option('--token <token>', 'Access token')
117
+ .option('--account <id>', 'Account ID')
118
+ .option('--use', 'Switch to this profile after creation')
119
+ .action((name: string, opts) => {
120
+ if (profileExists(name)) {
121
+ error(`Profile "${name}" already exists`);
122
+ process.exit(1);
123
+ }
124
+ createProfile(name, {
125
+ accessToken: opts.token,
126
+ accountId: opts.account,
127
+ });
128
+ success(`Profile "${name}" created`);
129
+ if (opts.use) {
130
+ setCurrentProfile(name);
131
+ info(`Switched to profile: ${name}`);
132
+ }
133
+ });
134
+
135
+ profileCmd
136
+ .command('delete <name>')
137
+ .description('Delete a profile')
138
+ .action((name: string) => {
139
+ if (name === 'default') {
140
+ error('Cannot delete the default profile');
141
+ process.exit(1);
142
+ }
143
+ if (deleteProfile(name)) {
144
+ success(`Profile "${name}" deleted`);
145
+ } else {
146
+ error(`Profile "${name}" not found`);
147
+ process.exit(1);
148
+ }
149
+ });
150
+
151
+ profileCmd
152
+ .command('show [name]')
153
+ .description('Show profile configuration')
154
+ .action((name?: string) => {
155
+ const profileName = name || getCurrentProfile();
156
+ const config = loadProfile(profileName);
157
+ const active = getCurrentProfile();
158
+ console.log(chalk.bold(`Profile: ${profileName}${profileName === active ? chalk.green(' (active)') : ''}`));
159
+ info(`Access Token: ${config.accessToken ? `${config.accessToken.substring(0, 8)}...` : chalk.gray('not set')}`);
160
+ info(`Account ID: ${config.accountId || chalk.gray('not set')}`);
161
+ info(`Base URL: ${config.baseUrl || chalk.gray('default (demo)')}`);
162
+ });
163
+
164
+ // ============================================
165
+ // Config Commands
166
+ // ============================================
167
+ const configCmd = program
168
+ .command('config')
169
+ .description('Manage CLI configuration (for active profile)');
170
+
171
+ configCmd
172
+ .command('set-token <token>')
173
+ .description('Set access token')
174
+ .action((token: string) => {
175
+ setAccessToken(token);
176
+ success(`Access token saved to profile: ${getCurrentProfile()}`);
177
+ });
178
+
179
+ configCmd
180
+ .command('set-account <accountId>')
181
+ .description('Set account ID')
182
+ .action((accountId: string) => {
183
+ setAccountId(accountId);
184
+ success(`Account ID saved to profile: ${getCurrentProfile()}`);
185
+ });
186
+
187
+ configCmd
188
+ .command('set-url <baseUrl>')
189
+ .description('Set base URL (for production use)')
190
+ .action((baseUrl: string) => {
191
+ setBaseUrl(baseUrl);
192
+ success(`Base URL saved to profile: ${getCurrentProfile()}`);
193
+ });
194
+
195
+ configCmd
196
+ .command('show')
197
+ .description('Show current configuration')
198
+ .action(() => {
199
+ const profileName = getCurrentProfile();
200
+ const accessToken = getAccessToken();
201
+ const accountId = getAccountId();
202
+ const baseUrl = getBaseUrl();
203
+ console.log(chalk.bold(`Active Profile: ${profileName}`));
204
+ info(`Config directory: ${getConfigDir()}`);
205
+ info(`Access Token: ${accessToken ? `${accessToken.substring(0, 8)}...` : chalk.gray('not set')}`);
206
+ info(`Account ID: ${accountId || chalk.gray('not set')}`);
207
+ info(`Base URL: ${baseUrl || chalk.gray('default (demo)')}`);
208
+ });
209
+
210
+ configCmd
211
+ .command('clear')
212
+ .description('Clear configuration for active profile')
213
+ .action(() => {
214
+ clearConfig();
215
+ success(`Configuration cleared for profile: ${getCurrentProfile()}`);
216
+ });
217
+
218
+ // ============================================
219
+ // Envelope Commands
220
+ // ============================================
221
+ const envelopeCmd = program
222
+ .command('envelope')
223
+ .description('Envelope management commands');
224
+
225
+ envelopeCmd
226
+ .command('list')
227
+ .description('List envelopes')
228
+ .option('--from <date>', 'From date (ISO format)')
229
+ .option('--to <date>', 'To date (ISO format)')
230
+ .option('--status <status>', 'Filter by status')
231
+ .option('-n, --count <count>', 'Number of results', '20')
232
+ .action(async (opts) => {
233
+ try {
234
+ const client = getClient();
235
+ const result = await client.listEnvelopes({
236
+ from_date: opts.from,
237
+ to_date: opts.to,
238
+ status: opts.status,
239
+ count: parseInt(opts.count),
240
+ });
241
+ const format = getFormat(envelopeCmd);
242
+ if (format === 'json') {
243
+ print(result, format);
244
+ } else {
245
+ success(`Envelopes (${result.resultSetSize}):`);
246
+ if (result.envelopes) {
247
+ result.envelopes.forEach(e => {
248
+ const status = e.status === 'completed' ? chalk.green(`[${e.status}]`)
249
+ : e.status === 'sent' ? chalk.yellow(`[${e.status}]`)
250
+ : chalk.gray(`[${e.status}]`);
251
+ console.log(` ${e.emailSubject || 'No subject'} ${status}`);
252
+ console.log(` ID: ${e.envelopeId}`);
253
+ if (e.sentDateTime) console.log(` Sent: ${e.sentDateTime}`);
254
+ });
255
+ } else {
256
+ info('No envelopes found');
257
+ }
258
+ }
259
+ } catch (err) {
260
+ error(String(err));
261
+ process.exit(1);
262
+ }
263
+ });
264
+
265
+ envelopeCmd
266
+ .command('get <envelopeId>')
267
+ .description('Get envelope details')
268
+ .action(async (envelopeId: string) => {
269
+ try {
270
+ const client = getClient();
271
+ const result = await client.getEnvelope(envelopeId);
272
+ const format = getFormat(envelopeCmd);
273
+ if (format === 'json') {
274
+ print(result, format);
275
+ } else {
276
+ console.log(chalk.bold(`Envelope: ${result.emailSubject || 'No subject'}`));
277
+ info(`ID: ${result.envelopeId}`);
278
+ info(`Status: ${result.status}`);
279
+ if (result.sentDateTime) info(`Sent: ${result.sentDateTime}`);
280
+ if (result.completedDateTime) info(`Completed: ${result.completedDateTime}`);
281
+ if (result.createdDateTime) info(`Created: ${result.createdDateTime}`);
282
+ }
283
+ } catch (err) {
284
+ error(String(err));
285
+ process.exit(1);
286
+ }
287
+ });
288
+
289
+ envelopeCmd
290
+ .command('send <envelopeId>')
291
+ .description('Send a draft envelope')
292
+ .action(async (envelopeId: string) => {
293
+ try {
294
+ const client = getClient();
295
+ const result = await client.sendEnvelope(envelopeId);
296
+ success(`Envelope sent: ${result.envelopeId}`);
297
+ } catch (err) {
298
+ error(String(err));
299
+ process.exit(1);
300
+ }
301
+ });
302
+
303
+ envelopeCmd
304
+ .command('void <envelopeId>')
305
+ .description('Void an envelope')
306
+ .requiredOption('-r, --reason <reason>', 'Reason for voiding')
307
+ .action(async (envelopeId: string, opts) => {
308
+ try {
309
+ const client = getClient();
310
+ await client.voidEnvelope(envelopeId, opts.reason);
311
+ success(`Envelope voided: ${envelopeId}`);
312
+ } catch (err) {
313
+ error(String(err));
314
+ process.exit(1);
315
+ }
316
+ });
317
+
318
+ // ============================================
319
+ // Template Commands
320
+ // ============================================
321
+ const templateCmd = program
322
+ .command('template')
323
+ .description('Template management commands');
324
+
325
+ templateCmd
326
+ .command('list')
327
+ .description('List templates')
328
+ .option('-n, --count <count>', 'Number of results', '20')
329
+ .option('-s, --search <text>', 'Search text')
330
+ .action(async (opts) => {
331
+ try {
332
+ const client = getClient();
333
+ const result = await client.listTemplates({
334
+ count: parseInt(opts.count),
335
+ search_text: opts.search,
336
+ });
337
+ const format = getFormat(templateCmd);
338
+ if (format === 'json') {
339
+ print(result, format);
340
+ } else {
341
+ success(`Templates (${result.resultSetSize}):`);
342
+ if (result.envelopeTemplates) {
343
+ result.envelopeTemplates.forEach(t => {
344
+ console.log(` ${t.name}`);
345
+ console.log(` ID: ${t.templateId}`);
346
+ if (t.description) console.log(` ${chalk.gray(t.description)}`);
347
+ });
348
+ } else {
349
+ info('No templates found');
350
+ }
351
+ }
352
+ } catch (err) {
353
+ error(String(err));
354
+ process.exit(1);
355
+ }
356
+ });
357
+
358
+ templateCmd
359
+ .command('get <templateId>')
360
+ .description('Get template details')
361
+ .action(async (templateId: string) => {
362
+ try {
363
+ const client = getClient();
364
+ const result = await client.getTemplate(templateId);
365
+ const format = getFormat(templateCmd);
366
+ if (format === 'json') {
367
+ print(result, format);
368
+ } else {
369
+ console.log(chalk.bold(`Template: ${result.name}`));
370
+ info(`ID: ${result.templateId}`);
371
+ if (result.description) info(`Description: ${result.description}`);
372
+ if (result.created) info(`Created: ${result.created}`);
373
+ if (result.lastModified) info(`Last Modified: ${result.lastModified}`);
374
+ }
375
+ } catch (err) {
376
+ error(String(err));
377
+ process.exit(1);
378
+ }
379
+ });
380
+
381
+ program.parse();