@hasna/connectors 0.0.1

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 (1269) hide show
  1. package/README.md +304 -0
  2. package/bin/index.js +5281 -0
  3. package/connectors/connect-anthropic/.env.example +4 -0
  4. package/connectors/connect-anthropic/.npmrc.example +2 -0
  5. package/connectors/connect-anthropic/AGENTS.md +97 -0
  6. package/connectors/connect-anthropic/CLAUDE.md +97 -0
  7. package/connectors/connect-anthropic/GEMINI.md +97 -0
  8. package/connectors/connect-anthropic/README.md +106 -0
  9. package/connectors/connect-anthropic/package.json +60 -0
  10. package/connectors/connect-anthropic/src/api/client.ts +122 -0
  11. package/connectors/connect-anthropic/src/api/index.ts +51 -0
  12. package/connectors/connect-anthropic/src/api/messages.ts +109 -0
  13. package/connectors/connect-anthropic/src/cli/index.ts +336 -0
  14. package/connectors/connect-anthropic/src/index.ts +24 -0
  15. package/connectors/connect-anthropic/src/types/index.ts +198 -0
  16. package/connectors/connect-anthropic/src/utils/config.ts +208 -0
  17. package/connectors/connect-anthropic/src/utils/output.ts +119 -0
  18. package/connectors/connect-anthropic/tsconfig.json +16 -0
  19. package/connectors/connect-aws/.env.example +11 -0
  20. package/connectors/connect-aws/.npmrc.example +2 -0
  21. package/connectors/connect-aws/AGENTS.md +145 -0
  22. package/connectors/connect-aws/CLAUDE.md +145 -0
  23. package/connectors/connect-aws/GEMINI.md +145 -0
  24. package/connectors/connect-aws/README.md +131 -0
  25. package/connectors/connect-aws/package.json +51 -0
  26. package/connectors/connect-aws/src/api/client.ts +349 -0
  27. package/connectors/connect-aws/src/api/dynamodb.ts +542 -0
  28. package/connectors/connect-aws/src/api/index.ts +71 -0
  29. package/connectors/connect-aws/src/api/lambda.ts +326 -0
  30. package/connectors/connect-aws/src/api/s3.ts +305 -0
  31. package/connectors/connect-aws/src/cli/index.ts +614 -0
  32. package/connectors/connect-aws/src/index.ts +28 -0
  33. package/connectors/connect-aws/src/types/index.ts +276 -0
  34. package/connectors/connect-aws/src/utils/config.ts +230 -0
  35. package/connectors/connect-aws/src/utils/output.ts +119 -0
  36. package/connectors/connect-aws/tsconfig.json +16 -0
  37. package/connectors/connect-brandsight/.env.example +8 -0
  38. package/connectors/connect-brandsight/.npmrc.example +2 -0
  39. package/connectors/connect-brandsight/AGENTS.md +128 -0
  40. package/connectors/connect-brandsight/CLAUDE.md +128 -0
  41. package/connectors/connect-brandsight/GEMINI.md +128 -0
  42. package/connectors/connect-brandsight/README.md +129 -0
  43. package/connectors/connect-brandsight/package.json +56 -0
  44. package/connectors/connect-brandsight/src/api/client.ts +171 -0
  45. package/connectors/connect-brandsight/src/api/domains.ts +387 -0
  46. package/connectors/connect-brandsight/src/api/example.ts +59 -0
  47. package/connectors/connect-brandsight/src/api/index.ts +50 -0
  48. package/connectors/connect-brandsight/src/cli/index.ts +775 -0
  49. package/connectors/connect-brandsight/src/index.ts +11 -0
  50. package/connectors/connect-brandsight/src/types/index.ts +197 -0
  51. package/connectors/connect-brandsight/src/utils/config.ts +244 -0
  52. package/connectors/connect-brandsight/src/utils/contacts.ts +204 -0
  53. package/connectors/connect-brandsight/src/utils/output.ts +119 -0
  54. package/connectors/connect-brandsight/tsconfig.json +29 -0
  55. package/connectors/connect-browseruse/.env.example +7 -0
  56. package/connectors/connect-browseruse/.npmrc.example +2 -0
  57. package/connectors/connect-browseruse/AGENTS.md +172 -0
  58. package/connectors/connect-browseruse/CLAUDE.md +172 -0
  59. package/connectors/connect-browseruse/GEMINI.md +172 -0
  60. package/connectors/connect-browseruse/README.md +153 -0
  61. package/connectors/connect-browseruse/package.json +52 -0
  62. package/connectors/connect-browseruse/src/api/billing.ts +32 -0
  63. package/connectors/connect-browseruse/src/api/browsers.ts +50 -0
  64. package/connectors/connect-browseruse/src/api/client.ts +168 -0
  65. package/connectors/connect-browseruse/src/api/files.ts +70 -0
  66. package/connectors/connect-browseruse/src/api/index.ts +95 -0
  67. package/connectors/connect-browseruse/src/api/profiles.ts +59 -0
  68. package/connectors/connect-browseruse/src/api/sessions.ts +88 -0
  69. package/connectors/connect-browseruse/src/api/skills.ts +194 -0
  70. package/connectors/connect-browseruse/src/api/tasks.ts +127 -0
  71. package/connectors/connect-browseruse/src/cli/index.ts +888 -0
  72. package/connectors/connect-browseruse/src/index.ts +35 -0
  73. package/connectors/connect-browseruse/src/types/index.ts +312 -0
  74. package/connectors/connect-browseruse/src/utils/config.ts +212 -0
  75. package/connectors/connect-browseruse/src/utils/output.ts +119 -0
  76. package/connectors/connect-browseruse/tsconfig.json +16 -0
  77. package/connectors/connect-cloudflare/.env.example +10 -0
  78. package/connectors/connect-cloudflare/.npmrc.example +2 -0
  79. package/connectors/connect-cloudflare/AGENTS.md +84 -0
  80. package/connectors/connect-cloudflare/CLAUDE.md +84 -0
  81. package/connectors/connect-cloudflare/GEMINI.md +84 -0
  82. package/connectors/connect-cloudflare/README.md +94 -0
  83. package/connectors/connect-cloudflare/package.json +59 -0
  84. package/connectors/connect-cloudflare/scripts/init.sh +62 -0
  85. package/connectors/connect-cloudflare/src/api/accounts.ts +352 -0
  86. package/connectors/connect-cloudflare/src/api/analytics.ts +638 -0
  87. package/connectors/connect-cloudflare/src/api/bulk.ts +1104 -0
  88. package/connectors/connect-cloudflare/src/api/cache.ts +192 -0
  89. package/connectors/connect-cloudflare/src/api/client.ts +201 -0
  90. package/connectors/connect-cloudflare/src/api/dns.ts +109 -0
  91. package/connectors/connect-cloudflare/src/api/firewall.ts +405 -0
  92. package/connectors/connect-cloudflare/src/api/index.ts +150 -0
  93. package/connectors/connect-cloudflare/src/api/kv.ts +171 -0
  94. package/connectors/connect-cloudflare/src/api/pages.ts +241 -0
  95. package/connectors/connect-cloudflare/src/api/r2.ts +270 -0
  96. package/connectors/connect-cloudflare/src/api/ssl.ts +416 -0
  97. package/connectors/connect-cloudflare/src/api/workers.ts +235 -0
  98. package/connectors/connect-cloudflare/src/api/zones.ts +121 -0
  99. package/connectors/connect-cloudflare/src/cli/index.ts +1644 -0
  100. package/connectors/connect-cloudflare/src/index.ts +21 -0
  101. package/connectors/connect-cloudflare/src/types/index.ts +754 -0
  102. package/connectors/connect-cloudflare/src/utils/config.ts +365 -0
  103. package/connectors/connect-cloudflare/src/utils/output.ts +119 -0
  104. package/connectors/connect-cloudflare/tsconfig.json +29 -0
  105. package/connectors/connect-discord/.env.example +9 -0
  106. package/connectors/connect-discord/.npmrc.example +2 -0
  107. package/connectors/connect-discord/AGENTS.md +187 -0
  108. package/connectors/connect-discord/CLAUDE.md +187 -0
  109. package/connectors/connect-discord/GEMINI.md +187 -0
  110. package/connectors/connect-discord/README.md +158 -0
  111. package/connectors/connect-discord/package.json +55 -0
  112. package/connectors/connect-discord/src/api/channels.ts +451 -0
  113. package/connectors/connect-discord/src/api/client.ts +147 -0
  114. package/connectors/connect-discord/src/api/commands.ts +212 -0
  115. package/connectors/connect-discord/src/api/gateway.ts +27 -0
  116. package/connectors/connect-discord/src/api/guilds.ts +434 -0
  117. package/connectors/connect-discord/src/api/index.ts +82 -0
  118. package/connectors/connect-discord/src/api/invites.ts +27 -0
  119. package/connectors/connect-discord/src/api/users.ts +66 -0
  120. package/connectors/connect-discord/src/api/webhooks.ts +188 -0
  121. package/connectors/connect-discord/src/cli/index.ts +788 -0
  122. package/connectors/connect-discord/src/index.ts +35 -0
  123. package/connectors/connect-discord/src/types/index.ts +545 -0
  124. package/connectors/connect-discord/src/utils/config.ts +219 -0
  125. package/connectors/connect-discord/src/utils/output.ts +119 -0
  126. package/connectors/connect-discord/tsconfig.json +16 -0
  127. package/connectors/connect-docker/.env.example +11 -0
  128. package/connectors/connect-docker/.npmrc.example +2 -0
  129. package/connectors/connect-docker/AGENTS.md +112 -0
  130. package/connectors/connect-docker/CLAUDE.md +112 -0
  131. package/connectors/connect-docker/GEMINI.md +112 -0
  132. package/connectors/connect-docker/README.md +97 -0
  133. package/connectors/connect-docker/package.json +57 -0
  134. package/connectors/connect-docker/src/api/client.ts +181 -0
  135. package/connectors/connect-docker/src/api/example.ts +79 -0
  136. package/connectors/connect-docker/src/api/index.ts +63 -0
  137. package/connectors/connect-docker/src/cli/index.ts +318 -0
  138. package/connectors/connect-docker/src/index.ts +30 -0
  139. package/connectors/connect-docker/src/types/index.ts +172 -0
  140. package/connectors/connect-docker/src/utils/config.ts +238 -0
  141. package/connectors/connect-docker/src/utils/output.ts +119 -0
  142. package/connectors/connect-docker/tsconfig.json +16 -0
  143. package/connectors/connect-e2b/.env.example +7 -0
  144. package/connectors/connect-e2b/.npmrc.example +2 -0
  145. package/connectors/connect-e2b/AGENTS.md +126 -0
  146. package/connectors/connect-e2b/CLAUDE.md +126 -0
  147. package/connectors/connect-e2b/GEMINI.md +126 -0
  148. package/connectors/connect-e2b/README.md +135 -0
  149. package/connectors/connect-e2b/package.json +51 -0
  150. package/connectors/connect-e2b/src/api/client.ts +150 -0
  151. package/connectors/connect-e2b/src/api/code.ts +188 -0
  152. package/connectors/connect-e2b/src/api/filesystem.ts +168 -0
  153. package/connectors/connect-e2b/src/api/index.ts +131 -0
  154. package/connectors/connect-e2b/src/api/sandbox.ts +91 -0
  155. package/connectors/connect-e2b/src/cli/index.ts +481 -0
  156. package/connectors/connect-e2b/src/index.ts +28 -0
  157. package/connectors/connect-e2b/src/types/index.ts +136 -0
  158. package/connectors/connect-e2b/src/utils/config.ts +231 -0
  159. package/connectors/connect-e2b/src/utils/output.ts +119 -0
  160. package/connectors/connect-e2b/tsconfig.json +16 -0
  161. package/connectors/connect-elevenlabs/.env.example +15 -0
  162. package/connectors/connect-elevenlabs/.npmrc.example +2 -0
  163. package/connectors/connect-elevenlabs/AGENTS.md +80 -0
  164. package/connectors/connect-elevenlabs/CLAUDE.md +80 -0
  165. package/connectors/connect-elevenlabs/GEMINI.md +80 -0
  166. package/connectors/connect-elevenlabs/README.md +98 -0
  167. package/connectors/connect-elevenlabs/package.json +57 -0
  168. package/connectors/connect-elevenlabs/src/api/client.ts +175 -0
  169. package/connectors/connect-elevenlabs/src/api/history.ts +103 -0
  170. package/connectors/connect-elevenlabs/src/api/index.ts +101 -0
  171. package/connectors/connect-elevenlabs/src/api/models.ts +49 -0
  172. package/connectors/connect-elevenlabs/src/api/sound-effects.ts +62 -0
  173. package/connectors/connect-elevenlabs/src/api/sts.ts +109 -0
  174. package/connectors/connect-elevenlabs/src/api/stt.ts +93 -0
  175. package/connectors/connect-elevenlabs/src/api/tts.ts +175 -0
  176. package/connectors/connect-elevenlabs/src/api/user.ts +43 -0
  177. package/connectors/connect-elevenlabs/src/api/voices.ts +169 -0
  178. package/connectors/connect-elevenlabs/src/cli/index.ts +739 -0
  179. package/connectors/connect-elevenlabs/src/index.ts +40 -0
  180. package/connectors/connect-elevenlabs/src/types/index.ts +432 -0
  181. package/connectors/connect-elevenlabs/src/utils/config.ts +242 -0
  182. package/connectors/connect-elevenlabs/src/utils/output.ts +119 -0
  183. package/connectors/connect-elevenlabs/tsconfig.json +16 -0
  184. package/connectors/connect-exa/.npmrc.example +2 -0
  185. package/connectors/connect-exa/AGENTS.md +76 -0
  186. package/connectors/connect-exa/CLAUDE.md +76 -0
  187. package/connectors/connect-exa/GEMINI.md +76 -0
  188. package/connectors/connect-exa/README.md +94 -0
  189. package/connectors/connect-exa/package.json +59 -0
  190. package/connectors/connect-exa/src/api/answer.ts +150 -0
  191. package/connectors/connect-exa/src/api/client.ts +171 -0
  192. package/connectors/connect-exa/src/api/contents.ts +150 -0
  193. package/connectors/connect-exa/src/api/context.ts +84 -0
  194. package/connectors/connect-exa/src/api/index.ts +77 -0
  195. package/connectors/connect-exa/src/api/research.ts +154 -0
  196. package/connectors/connect-exa/src/api/search.ts +153 -0
  197. package/connectors/connect-exa/src/api/similar.ts +138 -0
  198. package/connectors/connect-exa/src/api/team.ts +165 -0
  199. package/connectors/connect-exa/src/api/websets.ts +228 -0
  200. package/connectors/connect-exa/src/cli/index.ts +813 -0
  201. package/connectors/connect-exa/src/index.ts +32 -0
  202. package/connectors/connect-exa/src/types/index.ts +410 -0
  203. package/connectors/connect-exa/src/utils/config.ts +336 -0
  204. package/connectors/connect-exa/src/utils/output.ts +119 -0
  205. package/connectors/connect-exa/tsconfig.json +21 -0
  206. package/connectors/connect-figma/.npmrc.example +2 -0
  207. package/connectors/connect-figma/AGENTS.md +185 -0
  208. package/connectors/connect-figma/CLAUDE.md +185 -0
  209. package/connectors/connect-figma/GEMINI.md +185 -0
  210. package/connectors/connect-figma/README.md +164 -0
  211. package/connectors/connect-figma/package.json +50 -0
  212. package/connectors/connect-figma/src/api/client.ts +111 -0
  213. package/connectors/connect-figma/src/api/comments.ts +114 -0
  214. package/connectors/connect-figma/src/api/components.ts +82 -0
  215. package/connectors/connect-figma/src/api/devresources.ts +78 -0
  216. package/connectors/connect-figma/src/api/files.ts +132 -0
  217. package/connectors/connect-figma/src/api/index.ts +86 -0
  218. package/connectors/connect-figma/src/api/projects.ts +36 -0
  219. package/connectors/connect-figma/src/api/styles.ts +46 -0
  220. package/connectors/connect-figma/src/api/teams.ts +17 -0
  221. package/connectors/connect-figma/src/api/users.ts +16 -0
  222. package/connectors/connect-figma/src/api/variables.ts +73 -0
  223. package/connectors/connect-figma/src/api/webhooks.ts +97 -0
  224. package/connectors/connect-figma/src/cli/index.ts +960 -0
  225. package/connectors/connect-figma/src/index.ts +34 -0
  226. package/connectors/connect-figma/src/types/index.ts +593 -0
  227. package/connectors/connect-figma/src/utils/config.ts +197 -0
  228. package/connectors/connect-figma/src/utils/output.ts +119 -0
  229. package/connectors/connect-figma/tsconfig.json +16 -0
  230. package/connectors/connect-firecrawl/.env.example +7 -0
  231. package/connectors/connect-firecrawl/.npmrc.example +2 -0
  232. package/connectors/connect-firecrawl/AGENTS.md +104 -0
  233. package/connectors/connect-firecrawl/CLAUDE.md +104 -0
  234. package/connectors/connect-firecrawl/GEMINI.md +104 -0
  235. package/connectors/connect-firecrawl/README.md +95 -0
  236. package/connectors/connect-firecrawl/package.json +51 -0
  237. package/connectors/connect-firecrawl/src/api/client.ts +123 -0
  238. package/connectors/connect-firecrawl/src/api/crawl.ts +93 -0
  239. package/connectors/connect-firecrawl/src/api/index.ts +61 -0
  240. package/connectors/connect-firecrawl/src/api/map.ts +51 -0
  241. package/connectors/connect-firecrawl/src/api/scrape.ts +71 -0
  242. package/connectors/connect-firecrawl/src/api/search.ts +61 -0
  243. package/connectors/connect-firecrawl/src/cli/index.ts +432 -0
  244. package/connectors/connect-firecrawl/src/index.ts +24 -0
  245. package/connectors/connect-firecrawl/src/types/index.ts +216 -0
  246. package/connectors/connect-firecrawl/src/utils/config.ts +208 -0
  247. package/connectors/connect-firecrawl/src/utils/output.ts +119 -0
  248. package/connectors/connect-firecrawl/tsconfig.json +16 -0
  249. package/connectors/connect-github/.env.example +11 -0
  250. package/connectors/connect-github/.npmrc.example +2 -0
  251. package/connectors/connect-github/AGENTS.md +150 -0
  252. package/connectors/connect-github/CLAUDE.md +150 -0
  253. package/connectors/connect-github/GEMINI.md +150 -0
  254. package/connectors/connect-github/README.md +126 -0
  255. package/connectors/connect-github/package.json +49 -0
  256. package/connectors/connect-github/src/api/client.ts +137 -0
  257. package/connectors/connect-github/src/api/index.ts +62 -0
  258. package/connectors/connect-github/src/api/issues.ts +186 -0
  259. package/connectors/connect-github/src/api/pulls.ts +284 -0
  260. package/connectors/connect-github/src/api/repos.ts +155 -0
  261. package/connectors/connect-github/src/api/users.ts +139 -0
  262. package/connectors/connect-github/src/cli/index.ts +732 -0
  263. package/connectors/connect-github/src/index.ts +24 -0
  264. package/connectors/connect-github/src/types/index.ts +497 -0
  265. package/connectors/connect-github/src/utils/config.ts +208 -0
  266. package/connectors/connect-github/src/utils/output.ts +119 -0
  267. package/connectors/connect-github/tsconfig.json +16 -0
  268. package/connectors/connect-gmail/.env.example +8 -0
  269. package/connectors/connect-gmail/.npmrc.example +2 -0
  270. package/connectors/connect-gmail/AGENTS.md +79 -0
  271. package/connectors/connect-gmail/CLAUDE.md +79 -0
  272. package/connectors/connect-gmail/GEMINI.md +79 -0
  273. package/connectors/connect-gmail/README.md +97 -0
  274. package/connectors/connect-gmail/package.json +58 -0
  275. package/connectors/connect-gmail/src/api/attachments.ts +141 -0
  276. package/connectors/connect-gmail/src/api/bulk.ts +661 -0
  277. package/connectors/connect-gmail/src/api/client.ts +131 -0
  278. package/connectors/connect-gmail/src/api/drafts.ts +198 -0
  279. package/connectors/connect-gmail/src/api/export.ts +312 -0
  280. package/connectors/connect-gmail/src/api/filters.ts +127 -0
  281. package/connectors/connect-gmail/src/api/index.ts +63 -0
  282. package/connectors/connect-gmail/src/api/labels.ts +123 -0
  283. package/connectors/connect-gmail/src/api/messages.ts +527 -0
  284. package/connectors/connect-gmail/src/api/profile.ts +72 -0
  285. package/connectors/connect-gmail/src/api/threads.ts +85 -0
  286. package/connectors/connect-gmail/src/cli/index.ts +2143 -0
  287. package/connectors/connect-gmail/src/index.ts +30 -0
  288. package/connectors/connect-gmail/src/types/index.ts +202 -0
  289. package/connectors/connect-gmail/src/utils/auth.ts +247 -0
  290. package/connectors/connect-gmail/src/utils/config.ts +466 -0
  291. package/connectors/connect-gmail/src/utils/contacts.ts +147 -0
  292. package/connectors/connect-gmail/src/utils/markdown.ts +110 -0
  293. package/connectors/connect-gmail/src/utils/output.ts +119 -0
  294. package/connectors/connect-gmail/src/utils/settings.ts +87 -0
  295. package/connectors/connect-gmail/tsconfig.json +16 -0
  296. package/connectors/connect-google/.env.example +10 -0
  297. package/connectors/connect-google/.npmrc.example +2 -0
  298. package/connectors/connect-google/AGENTS.md +76 -0
  299. package/connectors/connect-google/CLAUDE.md +76 -0
  300. package/connectors/connect-google/GEMINI.md +76 -0
  301. package/connectors/connect-google/README.md +94 -0
  302. package/connectors/connect-google/package.json +60 -0
  303. package/connectors/connect-google/src/api/calendar.ts +339 -0
  304. package/connectors/connect-google/src/api/client.ts +201 -0
  305. package/connectors/connect-google/src/api/docs.ts +372 -0
  306. package/connectors/connect-google/src/api/drive.ts +370 -0
  307. package/connectors/connect-google/src/api/gmail.ts +338 -0
  308. package/connectors/connect-google/src/api/index.ts +66 -0
  309. package/connectors/connect-google/src/api/sheets.ts +343 -0
  310. package/connectors/connect-google/src/cli/index.ts +1232 -0
  311. package/connectors/connect-google/src/index.ts +27 -0
  312. package/connectors/connect-google/src/types/index.ts +1893 -0
  313. package/connectors/connect-google/src/utils/config.ts +248 -0
  314. package/connectors/connect-google/src/utils/output.ts +119 -0
  315. package/connectors/connect-google/tsconfig.json +21 -0
  316. package/connectors/connect-googlecalendar/.npmrc.example +2 -0
  317. package/connectors/connect-googlecalendar/AGENTS.md +117 -0
  318. package/connectors/connect-googlecalendar/CLAUDE.md +117 -0
  319. package/connectors/connect-googlecalendar/GEMINI.md +117 -0
  320. package/connectors/connect-googlecalendar/README.md +97 -0
  321. package/connectors/connect-googlecalendar/package.json +57 -0
  322. package/connectors/connect-googlecalendar/src/api/calendars.ts +106 -0
  323. package/connectors/connect-googlecalendar/src/api/client.ts +266 -0
  324. package/connectors/connect-googlecalendar/src/api/events.ts +266 -0
  325. package/connectors/connect-googlecalendar/src/api/index.ts +96 -0
  326. package/connectors/connect-googlecalendar/src/cli/index.ts +819 -0
  327. package/connectors/connect-googlecalendar/src/index.ts +30 -0
  328. package/connectors/connect-googlecalendar/src/types/index.ts +347 -0
  329. package/connectors/connect-googlecalendar/src/utils/config.ts +251 -0
  330. package/connectors/connect-googlecalendar/src/utils/output.ts +119 -0
  331. package/connectors/connect-googlecalendar/tsconfig.json +16 -0
  332. package/connectors/connect-googlecloud/.env.example +11 -0
  333. package/connectors/connect-googlecloud/.npmrc.example +2 -0
  334. package/connectors/connect-googlecloud/AGENTS.md +110 -0
  335. package/connectors/connect-googlecloud/CLAUDE.md +110 -0
  336. package/connectors/connect-googlecloud/GEMINI.md +110 -0
  337. package/connectors/connect-googlecloud/README.md +96 -0
  338. package/connectors/connect-googlecloud/package.json +56 -0
  339. package/connectors/connect-googlecloud/src/api/client.ts +208 -0
  340. package/connectors/connect-googlecloud/src/api/index.ts +53 -0
  341. package/connectors/connect-googlecloud/src/api/projects.ts +75 -0
  342. package/connectors/connect-googlecloud/src/cli/index.ts +305 -0
  343. package/connectors/connect-googlecloud/src/index.ts +28 -0
  344. package/connectors/connect-googlecloud/src/types/index.ts +100 -0
  345. package/connectors/connect-googlecloud/src/utils/config.ts +232 -0
  346. package/connectors/connect-googlecloud/src/utils/output.ts +119 -0
  347. package/connectors/connect-googlecloud/tsconfig.json +16 -0
  348. package/connectors/connect-googlecontacts/.npmrc.example +2 -0
  349. package/connectors/connect-googlecontacts/AGENTS.md +181 -0
  350. package/connectors/connect-googlecontacts/CLAUDE.md +181 -0
  351. package/connectors/connect-googlecontacts/GEMINI.md +181 -0
  352. package/connectors/connect-googlecontacts/README.md +117 -0
  353. package/connectors/connect-googlecontacts/package.json +56 -0
  354. package/connectors/connect-googlecontacts/src/api/client.ts +306 -0
  355. package/connectors/connect-googlecontacts/src/api/contacts.ts +236 -0
  356. package/connectors/connect-googlecontacts/src/api/index.ts +99 -0
  357. package/connectors/connect-googlecontacts/src/cli/index.ts +654 -0
  358. package/connectors/connect-googlecontacts/src/index.ts +34 -0
  359. package/connectors/connect-googlecontacts/src/types/index.ts +254 -0
  360. package/connectors/connect-googlecontacts/src/utils/config.ts +337 -0
  361. package/connectors/connect-googlecontacts/src/utils/output.ts +119 -0
  362. package/connectors/connect-googlecontacts/tsconfig.json +16 -0
  363. package/connectors/connect-googledocs/.env.example +11 -0
  364. package/connectors/connect-googledocs/.npmrc.example +2 -0
  365. package/connectors/connect-googledocs/AGENTS.md +130 -0
  366. package/connectors/connect-googledocs/CLAUDE.md +130 -0
  367. package/connectors/connect-googledocs/GEMINI.md +130 -0
  368. package/connectors/connect-googledocs/README.md +112 -0
  369. package/connectors/connect-googledocs/package.json +50 -0
  370. package/connectors/connect-googledocs/src/api/client.ts +159 -0
  371. package/connectors/connect-googledocs/src/api/content.ts +219 -0
  372. package/connectors/connect-googledocs/src/api/documents.ts +52 -0
  373. package/connectors/connect-googledocs/src/api/index.ts +65 -0
  374. package/connectors/connect-googledocs/src/api/styles.ts +386 -0
  375. package/connectors/connect-googledocs/src/cli/index.ts +364 -0
  376. package/connectors/connect-googledocs/src/index.ts +24 -0
  377. package/connectors/connect-googledocs/src/types/index.ts +767 -0
  378. package/connectors/connect-googledocs/src/utils/config.ts +208 -0
  379. package/connectors/connect-googledocs/src/utils/output.ts +119 -0
  380. package/connectors/connect-googledocs/tsconfig.json +16 -0
  381. package/connectors/connect-googledrive/.npmrc.example +2 -0
  382. package/connectors/connect-googledrive/AGENTS.md +76 -0
  383. package/connectors/connect-googledrive/CLAUDE.md +76 -0
  384. package/connectors/connect-googledrive/GEMINI.md +76 -0
  385. package/connectors/connect-googledrive/README.md +94 -0
  386. package/connectors/connect-googledrive/package.json +55 -0
  387. package/connectors/connect-googledrive/src/api/client.ts +216 -0
  388. package/connectors/connect-googledrive/src/api/drives.ts +186 -0
  389. package/connectors/connect-googledrive/src/api/files.ts +305 -0
  390. package/connectors/connect-googledrive/src/api/folders.ts +133 -0
  391. package/connectors/connect-googledrive/src/api/index.ts +47 -0
  392. package/connectors/connect-googledrive/src/api/storage.ts +48 -0
  393. package/connectors/connect-googledrive/src/api/trash.ts +47 -0
  394. package/connectors/connect-googledrive/src/cli/index.ts +933 -0
  395. package/connectors/connect-googledrive/src/index.ts +30 -0
  396. package/connectors/connect-googledrive/src/types/index.ts +378 -0
  397. package/connectors/connect-googledrive/src/utils/auth.ts +207 -0
  398. package/connectors/connect-googledrive/src/utils/config.ts +440 -0
  399. package/connectors/connect-googledrive/src/utils/output.ts +135 -0
  400. package/connectors/connect-googledrive/tsconfig.json +25 -0
  401. package/connectors/connect-googlegemini/.env.example +7 -0
  402. package/connectors/connect-googlegemini/.npmrc.example +2 -0
  403. package/connectors/connect-googlegemini/AGENTS.md +184 -0
  404. package/connectors/connect-googlegemini/CLAUDE.md +184 -0
  405. package/connectors/connect-googlegemini/GEMINI.md +184 -0
  406. package/connectors/connect-googlegemini/README.md +143 -0
  407. package/connectors/connect-googlegemini/package.json +55 -0
  408. package/connectors/connect-googlegemini/src/api/client.ts +219 -0
  409. package/connectors/connect-googlegemini/src/api/embeddings.ts +142 -0
  410. package/connectors/connect-googlegemini/src/api/files.ts +152 -0
  411. package/connectors/connect-googlegemini/src/api/generate.ts +187 -0
  412. package/connectors/connect-googlegemini/src/api/images.ts +216 -0
  413. package/connectors/connect-googlegemini/src/api/index.ts +103 -0
  414. package/connectors/connect-googlegemini/src/api/models.ts +102 -0
  415. package/connectors/connect-googlegemini/src/api/speech.ts +195 -0
  416. package/connectors/connect-googlegemini/src/api/video.ts +224 -0
  417. package/connectors/connect-googlegemini/src/cli/index.ts +702 -0
  418. package/connectors/connect-googlegemini/src/index.ts +34 -0
  419. package/connectors/connect-googlegemini/src/types/index.ts +324 -0
  420. package/connectors/connect-googlegemini/src/utils/config.ts +139 -0
  421. package/connectors/connect-googlegemini/src/utils/output.ts +169 -0
  422. package/connectors/connect-googlegemini/tsconfig.json +15 -0
  423. package/connectors/connect-googlemaps/.npmrc.example +2 -0
  424. package/connectors/connect-googlemaps/AGENTS.md +143 -0
  425. package/connectors/connect-googlemaps/CLAUDE.md +143 -0
  426. package/connectors/connect-googlemaps/GEMINI.md +143 -0
  427. package/connectors/connect-googlemaps/README.md +152 -0
  428. package/connectors/connect-googlemaps/package.json +29 -0
  429. package/connectors/connect-googlemaps/src/api/index.ts +315 -0
  430. package/connectors/connect-googlemaps/src/cli/index.ts +423 -0
  431. package/connectors/connect-googlemaps/src/index.ts +3 -0
  432. package/connectors/connect-googlemaps/src/types/index.ts +268 -0
  433. package/connectors/connect-googlemaps/src/utils/config.ts +59 -0
  434. package/connectors/connect-googlemaps/src/utils/output.ts +178 -0
  435. package/connectors/connect-googlemaps/tsconfig.json +17 -0
  436. package/connectors/connect-googlesheets/.env.example +15 -0
  437. package/connectors/connect-googlesheets/.npmrc.example +2 -0
  438. package/connectors/connect-googlesheets/AGENTS.md +144 -0
  439. package/connectors/connect-googlesheets/CLAUDE.md +144 -0
  440. package/connectors/connect-googlesheets/GEMINI.md +144 -0
  441. package/connectors/connect-googlesheets/README.md +124 -0
  442. package/connectors/connect-googlesheets/package.json +51 -0
  443. package/connectors/connect-googlesheets/src/api/client.ts +230 -0
  444. package/connectors/connect-googlesheets/src/api/index.ts +113 -0
  445. package/connectors/connect-googlesheets/src/api/sheets.ts +249 -0
  446. package/connectors/connect-googlesheets/src/api/spreadsheets.ts +150 -0
  447. package/connectors/connect-googlesheets/src/api/values.ts +209 -0
  448. package/connectors/connect-googlesheets/src/cli/index.ts +544 -0
  449. package/connectors/connect-googlesheets/src/index.ts +32 -0
  450. package/connectors/connect-googlesheets/src/types/index.ts +764 -0
  451. package/connectors/connect-googlesheets/src/utils/config.ts +289 -0
  452. package/connectors/connect-googlesheets/src/utils/output.ts +119 -0
  453. package/connectors/connect-googlesheets/tsconfig.json +16 -0
  454. package/connectors/connect-googletasks/.env.example +6 -0
  455. package/connectors/connect-googletasks/.npmrc.example +2 -0
  456. package/connectors/connect-googletasks/AGENTS.md +122 -0
  457. package/connectors/connect-googletasks/CLAUDE.md +122 -0
  458. package/connectors/connect-googletasks/GEMINI.md +122 -0
  459. package/connectors/connect-googletasks/README.md +131 -0
  460. package/connectors/connect-googletasks/package.json +50 -0
  461. package/connectors/connect-googletasks/src/api/index.ts +321 -0
  462. package/connectors/connect-googletasks/src/cli/index.ts +542 -0
  463. package/connectors/connect-googletasks/src/index.ts +42 -0
  464. package/connectors/connect-googletasks/src/types/index.ts +167 -0
  465. package/connectors/connect-googletasks/src/utils/config.ts +287 -0
  466. package/connectors/connect-googletasks/src/utils/output.ts +145 -0
  467. package/connectors/connect-googletasks/tsconfig.json +16 -0
  468. package/connectors/connect-hedra/.env.example +7 -0
  469. package/connectors/connect-hedra/.npmrc.example +2 -0
  470. package/connectors/connect-hedra/AGENTS.md +101 -0
  471. package/connectors/connect-hedra/CLAUDE.md +101 -0
  472. package/connectors/connect-hedra/GEMINI.md +101 -0
  473. package/connectors/connect-hedra/README.md +95 -0
  474. package/connectors/connect-hedra/package.json +57 -0
  475. package/connectors/connect-hedra/src/api/characters.ts +44 -0
  476. package/connectors/connect-hedra/src/api/client.ts +136 -0
  477. package/connectors/connect-hedra/src/api/index.ts +57 -0
  478. package/connectors/connect-hedra/src/api/projects.ts +44 -0
  479. package/connectors/connect-hedra/src/api/voices.ts +23 -0
  480. package/connectors/connect-hedra/src/cli/index.ts +314 -0
  481. package/connectors/connect-hedra/src/index.ts +24 -0
  482. package/connectors/connect-hedra/src/types/index.ts +103 -0
  483. package/connectors/connect-hedra/src/utils/config.ts +211 -0
  484. package/connectors/connect-hedra/src/utils/output.ts +119 -0
  485. package/connectors/connect-hedra/tsconfig.json +16 -0
  486. package/connectors/connect-heygen/.env.example +11 -0
  487. package/connectors/connect-heygen/.npmrc.example +2 -0
  488. package/connectors/connect-heygen/AGENTS.md +102 -0
  489. package/connectors/connect-heygen/CLAUDE.md +102 -0
  490. package/connectors/connect-heygen/GEMINI.md +102 -0
  491. package/connectors/connect-heygen/README.md +96 -0
  492. package/connectors/connect-heygen/package.json +57 -0
  493. package/connectors/connect-heygen/src/api/client.ts +134 -0
  494. package/connectors/connect-heygen/src/api/example.ts +48 -0
  495. package/connectors/connect-heygen/src/api/index.ts +49 -0
  496. package/connectors/connect-heygen/src/cli/index.ts +242 -0
  497. package/connectors/connect-heygen/src/index.ts +24 -0
  498. package/connectors/connect-heygen/src/types/index.ts +69 -0
  499. package/connectors/connect-heygen/src/utils/config.ts +209 -0
  500. package/connectors/connect-heygen/src/utils/output.ts +119 -0
  501. package/connectors/connect-heygen/tsconfig.json +16 -0
  502. package/connectors/connect-huggingface/.env.example +10 -0
  503. package/connectors/connect-huggingface/.npmrc.example +2 -0
  504. package/connectors/connect-huggingface/AGENTS.md +113 -0
  505. package/connectors/connect-huggingface/CLAUDE.md +113 -0
  506. package/connectors/connect-huggingface/GEMINI.md +113 -0
  507. package/connectors/connect-huggingface/README.md +97 -0
  508. package/connectors/connect-huggingface/package.json +57 -0
  509. package/connectors/connect-huggingface/src/api/client.ts +136 -0
  510. package/connectors/connect-huggingface/src/api/example.ts +48 -0
  511. package/connectors/connect-huggingface/src/api/index.ts +49 -0
  512. package/connectors/connect-huggingface/src/cli/index.ts +243 -0
  513. package/connectors/connect-huggingface/src/index.ts +24 -0
  514. package/connectors/connect-huggingface/src/types/index.ts +69 -0
  515. package/connectors/connect-huggingface/src/utils/config.ts +211 -0
  516. package/connectors/connect-huggingface/src/utils/output.ts +119 -0
  517. package/connectors/connect-huggingface/tsconfig.json +16 -0
  518. package/connectors/connect-icons8/.env.example +7 -0
  519. package/connectors/connect-icons8/.npmrc.example +2 -0
  520. package/connectors/connect-icons8/AGENTS.md +101 -0
  521. package/connectors/connect-icons8/CLAUDE.md +101 -0
  522. package/connectors/connect-icons8/GEMINI.md +101 -0
  523. package/connectors/connect-icons8/README.md +95 -0
  524. package/connectors/connect-icons8/package.json +55 -0
  525. package/connectors/connect-icons8/src/api/client.ts +137 -0
  526. package/connectors/connect-icons8/src/api/example.ts +64 -0
  527. package/connectors/connect-icons8/src/api/index.ts +48 -0
  528. package/connectors/connect-icons8/src/cli/index.ts +286 -0
  529. package/connectors/connect-icons8/src/index.ts +24 -0
  530. package/connectors/connect-icons8/src/types/index.ts +114 -0
  531. package/connectors/connect-icons8/src/utils/config.ts +211 -0
  532. package/connectors/connect-icons8/src/utils/output.ts +119 -0
  533. package/connectors/connect-icons8/tsconfig.json +16 -0
  534. package/connectors/connect-maropost/.env.example +13 -0
  535. package/connectors/connect-maropost/.npmrc.example +2 -0
  536. package/connectors/connect-maropost/AGENTS.md +110 -0
  537. package/connectors/connect-maropost/CLAUDE.md +110 -0
  538. package/connectors/connect-maropost/GEMINI.md +110 -0
  539. package/connectors/connect-maropost/README.md +96 -0
  540. package/connectors/connect-maropost/package.json +51 -0
  541. package/connectors/connect-maropost/src/api/campaigns.ts +129 -0
  542. package/connectors/connect-maropost/src/api/client.ts +162 -0
  543. package/connectors/connect-maropost/src/api/contacts.ts +128 -0
  544. package/connectors/connect-maropost/src/api/index.ts +91 -0
  545. package/connectors/connect-maropost/src/api/journeys.ts +60 -0
  546. package/connectors/connect-maropost/src/api/lists.ts +80 -0
  547. package/connectors/connect-maropost/src/api/reports.ts +123 -0
  548. package/connectors/connect-maropost/src/api/transactional.ts +109 -0
  549. package/connectors/connect-maropost/src/cli/index.ts +958 -0
  550. package/connectors/connect-maropost/src/index.ts +33 -0
  551. package/connectors/connect-maropost/src/types/index.ts +340 -0
  552. package/connectors/connect-maropost/src/utils/config.ts +213 -0
  553. package/connectors/connect-maropost/src/utils/output.ts +119 -0
  554. package/connectors/connect-maropost/tsconfig.json +16 -0
  555. package/connectors/connect-mercury/.env.example +5 -0
  556. package/connectors/connect-mercury/.npmrc.example +2 -0
  557. package/connectors/connect-mercury/AGENTS.md +137 -0
  558. package/connectors/connect-mercury/CLAUDE.md +137 -0
  559. package/connectors/connect-mercury/GEMINI.md +137 -0
  560. package/connectors/connect-mercury/README.md +146 -0
  561. package/connectors/connect-mercury/package.json +60 -0
  562. package/connectors/connect-mercury/src/api/accounts.ts +79 -0
  563. package/connectors/connect-mercury/src/api/attachments.ts +24 -0
  564. package/connectors/connect-mercury/src/api/categories.ts +40 -0
  565. package/connectors/connect-mercury/src/api/client.ts +134 -0
  566. package/connectors/connect-mercury/src/api/credit.ts +38 -0
  567. package/connectors/connect-mercury/src/api/customers.ts +53 -0
  568. package/connectors/connect-mercury/src/api/events.ts +63 -0
  569. package/connectors/connect-mercury/src/api/index.ts +97 -0
  570. package/connectors/connect-mercury/src/api/invoices.ts +102 -0
  571. package/connectors/connect-mercury/src/api/organization.ts +88 -0
  572. package/connectors/connect-mercury/src/api/recipients.ts +84 -0
  573. package/connectors/connect-mercury/src/api/transactions.ts +128 -0
  574. package/connectors/connect-mercury/src/api/transfers.ts +96 -0
  575. package/connectors/connect-mercury/src/api/treasury.ts +82 -0
  576. package/connectors/connect-mercury/src/api/webhooks.ts +90 -0
  577. package/connectors/connect-mercury/src/cli/index.ts +1263 -0
  578. package/connectors/connect-mercury/src/index.ts +33 -0
  579. package/connectors/connect-mercury/src/types/index.ts +505 -0
  580. package/connectors/connect-mercury/src/utils/config.ts +393 -0
  581. package/connectors/connect-mercury/src/utils/output.ts +119 -0
  582. package/connectors/connect-mercury/tsconfig.json +16 -0
  583. package/connectors/connect-meta/.npmrc.example +2 -0
  584. package/connectors/connect-meta/AGENTS.md +76 -0
  585. package/connectors/connect-meta/CLAUDE.md +76 -0
  586. package/connectors/connect-meta/GEMINI.md +76 -0
  587. package/connectors/connect-meta/README.md +94 -0
  588. package/connectors/connect-meta/package.json +61 -0
  589. package/connectors/connect-meta/src/api/accounts.ts +120 -0
  590. package/connectors/connect-meta/src/api/ads.ts +274 -0
  591. package/connectors/connect-meta/src/api/adsets.ts +263 -0
  592. package/connectors/connect-meta/src/api/audiences.ts +392 -0
  593. package/connectors/connect-meta/src/api/business.ts +495 -0
  594. package/connectors/connect-meta/src/api/campaigns.ts +191 -0
  595. package/connectors/connect-meta/src/api/catalogs.ts +500 -0
  596. package/connectors/connect-meta/src/api/client.ts +154 -0
  597. package/connectors/connect-meta/src/api/creatives.ts +357 -0
  598. package/connectors/connect-meta/src/api/index.ts +100 -0
  599. package/connectors/connect-meta/src/api/insights.ts +357 -0
  600. package/connectors/connect-meta/src/api/instagram.ts +449 -0
  601. package/connectors/connect-meta/src/api/pages.ts +330 -0
  602. package/connectors/connect-meta/src/api/pixels.ts +408 -0
  603. package/connectors/connect-meta/src/cli/index.ts +1585 -0
  604. package/connectors/connect-meta/src/index.ts +44 -0
  605. package/connectors/connect-meta/src/types/index.ts +1523 -0
  606. package/connectors/connect-meta/src/utils/config.ts +458 -0
  607. package/connectors/connect-meta/src/utils/output.ts +152 -0
  608. package/connectors/connect-meta/tsconfig.json +18 -0
  609. package/connectors/connect-midjourney/.env.example +13 -0
  610. package/connectors/connect-midjourney/.npmrc.example +2 -0
  611. package/connectors/connect-midjourney/AGENTS.md +104 -0
  612. package/connectors/connect-midjourney/CLAUDE.md +104 -0
  613. package/connectors/connect-midjourney/GEMINI.md +104 -0
  614. package/connectors/connect-midjourney/README.md +96 -0
  615. package/connectors/connect-midjourney/package.json +57 -0
  616. package/connectors/connect-midjourney/src/api/client.ts +143 -0
  617. package/connectors/connect-midjourney/src/api/imagine.ts +84 -0
  618. package/connectors/connect-midjourney/src/api/index.ts +50 -0
  619. package/connectors/connect-midjourney/src/cli/index.ts +343 -0
  620. package/connectors/connect-midjourney/src/index.ts +24 -0
  621. package/connectors/connect-midjourney/src/types/index.ts +98 -0
  622. package/connectors/connect-midjourney/src/utils/config.ts +219 -0
  623. package/connectors/connect-midjourney/src/utils/output.ts +119 -0
  624. package/connectors/connect-midjourney/tsconfig.json +16 -0
  625. package/connectors/connect-mistral/.env.example +4 -0
  626. package/connectors/connect-mistral/.npmrc.example +2 -0
  627. package/connectors/connect-mistral/AGENTS.md +100 -0
  628. package/connectors/connect-mistral/CLAUDE.md +100 -0
  629. package/connectors/connect-mistral/GEMINI.md +100 -0
  630. package/connectors/connect-mistral/README.md +109 -0
  631. package/connectors/connect-mistral/package.json +60 -0
  632. package/connectors/connect-mistral/src/api/chat.ts +113 -0
  633. package/connectors/connect-mistral/src/api/client.ts +122 -0
  634. package/connectors/connect-mistral/src/api/embeddings.ts +52 -0
  635. package/connectors/connect-mistral/src/api/index.ts +62 -0
  636. package/connectors/connect-mistral/src/cli/index.ts +371 -0
  637. package/connectors/connect-mistral/src/index.ts +24 -0
  638. package/connectors/connect-mistral/src/types/index.ts +183 -0
  639. package/connectors/connect-mistral/src/utils/config.ts +208 -0
  640. package/connectors/connect-mistral/src/utils/output.ts +119 -0
  641. package/connectors/connect-mistral/tsconfig.json +16 -0
  642. package/connectors/connect-mixpanel/.env.example +8 -0
  643. package/connectors/connect-mixpanel/.npmrc.example +2 -0
  644. package/connectors/connect-mixpanel/AGENTS.md +178 -0
  645. package/connectors/connect-mixpanel/CLAUDE.md +178 -0
  646. package/connectors/connect-mixpanel/GEMINI.md +178 -0
  647. package/connectors/connect-mixpanel/README.md +149 -0
  648. package/connectors/connect-mixpanel/package.json +54 -0
  649. package/connectors/connect-mixpanel/src/api/client.ts +352 -0
  650. package/connectors/connect-mixpanel/src/api/engage.ts +209 -0
  651. package/connectors/connect-mixpanel/src/api/export.ts +122 -0
  652. package/connectors/connect-mixpanel/src/api/funnels.ts +136 -0
  653. package/connectors/connect-mixpanel/src/api/index.ts +97 -0
  654. package/connectors/connect-mixpanel/src/api/insights.ts +198 -0
  655. package/connectors/connect-mixpanel/src/api/retention.ts +139 -0
  656. package/connectors/connect-mixpanel/src/api/track.ts +69 -0
  657. package/connectors/connect-mixpanel/src/cli/index.ts +678 -0
  658. package/connectors/connect-mixpanel/src/index.ts +32 -0
  659. package/connectors/connect-mixpanel/src/types/index.ts +262 -0
  660. package/connectors/connect-mixpanel/src/utils/config.ts +255 -0
  661. package/connectors/connect-mixpanel/src/utils/output.ts +119 -0
  662. package/connectors/connect-mixpanel/tsconfig.json +16 -0
  663. package/connectors/connect-notion/.env.example +10 -0
  664. package/connectors/connect-notion/.npmrc.example +2 -0
  665. package/connectors/connect-notion/AGENTS.md +75 -0
  666. package/connectors/connect-notion/CLAUDE.md +211 -0
  667. package/connectors/connect-notion/GEMINI.md +54 -0
  668. package/connectors/connect-notion/README.md +244 -0
  669. package/connectors/connect-notion/package.json +56 -0
  670. package/connectors/connect-notion/src/api/blocks.ts +463 -0
  671. package/connectors/connect-notion/src/api/bulk.ts +614 -0
  672. package/connectors/connect-notion/src/api/client.ts +127 -0
  673. package/connectors/connect-notion/src/api/comments.ts +142 -0
  674. package/connectors/connect-notion/src/api/databases.ts +652 -0
  675. package/connectors/connect-notion/src/api/export.ts +487 -0
  676. package/connectors/connect-notion/src/api/index.ts +72 -0
  677. package/connectors/connect-notion/src/api/pages.ts +465 -0
  678. package/connectors/connect-notion/src/api/search.ts +202 -0
  679. package/connectors/connect-notion/src/api/users.ts +99 -0
  680. package/connectors/connect-notion/src/cli/index.ts +1666 -0
  681. package/connectors/connect-notion/src/index.ts +16 -0
  682. package/connectors/connect-notion/src/types/index.ts +723 -0
  683. package/connectors/connect-notion/src/utils/auth.ts +186 -0
  684. package/connectors/connect-notion/src/utils/config.ts +434 -0
  685. package/connectors/connect-notion/src/utils/output.ts +119 -0
  686. package/connectors/connect-notion/tsconfig.json +29 -0
  687. package/connectors/connect-openai/.env.example +4 -0
  688. package/connectors/connect-openai/.npmrc.example +2 -0
  689. package/connectors/connect-openai/AGENTS.md +77 -0
  690. package/connectors/connect-openai/CLAUDE.md +77 -0
  691. package/connectors/connect-openai/GEMINI.md +77 -0
  692. package/connectors/connect-openai/README.md +95 -0
  693. package/connectors/connect-openai/package.json +61 -0
  694. package/connectors/connect-openai/src/api/chat.ts +134 -0
  695. package/connectors/connect-openai/src/api/client.ts +128 -0
  696. package/connectors/connect-openai/src/api/embeddings.ts +57 -0
  697. package/connectors/connect-openai/src/api/images.ts +75 -0
  698. package/connectors/connect-openai/src/api/index.ts +67 -0
  699. package/connectors/connect-openai/src/cli/index.ts +459 -0
  700. package/connectors/connect-openai/src/index.ts +26 -0
  701. package/connectors/connect-openai/src/types/index.ts +241 -0
  702. package/connectors/connect-openai/src/utils/config.ts +219 -0
  703. package/connectors/connect-openai/src/utils/output.ts +119 -0
  704. package/connectors/connect-openai/tsconfig.json +16 -0
  705. package/connectors/connect-openweathermap/.env.example +2 -0
  706. package/connectors/connect-openweathermap/.npmrc.example +2 -0
  707. package/connectors/connect-openweathermap/AGENTS.md +106 -0
  708. package/connectors/connect-openweathermap/CLAUDE.md +106 -0
  709. package/connectors/connect-openweathermap/GEMINI.md +106 -0
  710. package/connectors/connect-openweathermap/README.md +115 -0
  711. package/connectors/connect-openweathermap/package.json +52 -0
  712. package/connectors/connect-openweathermap/src/api/client.ts +76 -0
  713. package/connectors/connect-openweathermap/src/api/index.ts +24 -0
  714. package/connectors/connect-openweathermap/src/api/weather.ts +108 -0
  715. package/connectors/connect-openweathermap/src/cli/index.ts +470 -0
  716. package/connectors/connect-openweathermap/src/index.ts +33 -0
  717. package/connectors/connect-openweathermap/src/types/index.ts +275 -0
  718. package/connectors/connect-openweathermap/src/utils/config.ts +82 -0
  719. package/connectors/connect-openweathermap/src/utils/output.ts +106 -0
  720. package/connectors/connect-openweathermap/tsconfig.json +16 -0
  721. package/connectors/connect-pandadoc/.env.example +13 -0
  722. package/connectors/connect-pandadoc/.npmrc.example +2 -0
  723. package/connectors/connect-pandadoc/AGENTS.md +76 -0
  724. package/connectors/connect-pandadoc/CLAUDE.md +76 -0
  725. package/connectors/connect-pandadoc/GEMINI.md +76 -0
  726. package/connectors/connect-pandadoc/README.md +94 -0
  727. package/connectors/connect-pandadoc/package.json +57 -0
  728. package/connectors/connect-pandadoc/src/api/catalogs.ts +58 -0
  729. package/connectors/connect-pandadoc/src/api/client.ts +169 -0
  730. package/connectors/connect-pandadoc/src/api/contacts.ts +58 -0
  731. package/connectors/connect-pandadoc/src/api/content-library.ts +57 -0
  732. package/connectors/connect-pandadoc/src/api/documents.ts +263 -0
  733. package/connectors/connect-pandadoc/src/api/folders.ts +58 -0
  734. package/connectors/connect-pandadoc/src/api/forms.ts +37 -0
  735. package/connectors/connect-pandadoc/src/api/index.ts +83 -0
  736. package/connectors/connect-pandadoc/src/api/members.ts +42 -0
  737. package/connectors/connect-pandadoc/src/api/templates.ts +61 -0
  738. package/connectors/connect-pandadoc/src/api/webhooks.ts +81 -0
  739. package/connectors/connect-pandadoc/src/cli/index.ts +1212 -0
  740. package/connectors/connect-pandadoc/src/index.ts +39 -0
  741. package/connectors/connect-pandadoc/src/types/index.ts +454 -0
  742. package/connectors/connect-pandadoc/src/utils/config.ts +259 -0
  743. package/connectors/connect-pandadoc/src/utils/output.ts +119 -0
  744. package/connectors/connect-pandadoc/tsconfig.json +16 -0
  745. package/connectors/connect-quo/.env.example +7 -0
  746. package/connectors/connect-quo/.npmrc.example +2 -0
  747. package/connectors/connect-quo/AGENTS.md +76 -0
  748. package/connectors/connect-quo/CLAUDE.md +76 -0
  749. package/connectors/connect-quo/GEMINI.md +76 -0
  750. package/connectors/connect-quo/README.md +94 -0
  751. package/connectors/connect-quo/package.json +58 -0
  752. package/connectors/connect-quo/src/api/calls.ts +64 -0
  753. package/connectors/connect-quo/src/api/client.ts +133 -0
  754. package/connectors/connect-quo/src/api/contacts.ts +57 -0
  755. package/connectors/connect-quo/src/api/conversations.ts +45 -0
  756. package/connectors/connect-quo/src/api/custom-fields.ts +17 -0
  757. package/connectors/connect-quo/src/api/index.ts +76 -0
  758. package/connectors/connect-quo/src/api/messages.ts +50 -0
  759. package/connectors/connect-quo/src/api/phone-numbers.ts +24 -0
  760. package/connectors/connect-quo/src/api/users.ts +24 -0
  761. package/connectors/connect-quo/src/api/webhooks.ts +121 -0
  762. package/connectors/connect-quo/src/cli/index.ts +713 -0
  763. package/connectors/connect-quo/src/index.ts +32 -0
  764. package/connectors/connect-quo/src/types/index.ts +361 -0
  765. package/connectors/connect-quo/src/utils/config.ts +242 -0
  766. package/connectors/connect-quo/src/utils/output.ts +119 -0
  767. package/connectors/connect-quo/tsconfig.json +16 -0
  768. package/connectors/connect-reddit/.npmrc.example +2 -0
  769. package/connectors/connect-reddit/AGENTS.md +176 -0
  770. package/connectors/connect-reddit/CLAUDE.md +176 -0
  771. package/connectors/connect-reddit/GEMINI.md +176 -0
  772. package/connectors/connect-reddit/README.md +160 -0
  773. package/connectors/connect-reddit/package.json +50 -0
  774. package/connectors/connect-reddit/src/api/client.ts +299 -0
  775. package/connectors/connect-reddit/src/api/comments.ts +268 -0
  776. package/connectors/connect-reddit/src/api/index.ts +113 -0
  777. package/connectors/connect-reddit/src/api/posts.ts +298 -0
  778. package/connectors/connect-reddit/src/api/search.ts +235 -0
  779. package/connectors/connect-reddit/src/api/subreddits.ts +279 -0
  780. package/connectors/connect-reddit/src/api/users.ts +403 -0
  781. package/connectors/connect-reddit/src/cli/index.ts +766 -0
  782. package/connectors/connect-reddit/src/index.ts +36 -0
  783. package/connectors/connect-reddit/src/types/index.ts +295 -0
  784. package/connectors/connect-reddit/src/utils/config.ts +281 -0
  785. package/connectors/connect-reddit/src/utils/output.ts +138 -0
  786. package/connectors/connect-reddit/tsconfig.json +16 -0
  787. package/connectors/connect-reducto/.npmrc.example +2 -0
  788. package/connectors/connect-reducto/AGENTS.md +136 -0
  789. package/connectors/connect-reducto/CLAUDE.md +136 -0
  790. package/connectors/connect-reducto/GEMINI.md +136 -0
  791. package/connectors/connect-reducto/README.md +145 -0
  792. package/connectors/connect-reducto/package.json +48 -0
  793. package/connectors/connect-reducto/src/api/index.ts +362 -0
  794. package/connectors/connect-reducto/src/cli/index.ts +582 -0
  795. package/connectors/connect-reducto/src/index.ts +48 -0
  796. package/connectors/connect-reducto/src/types/index.ts +204 -0
  797. package/connectors/connect-reducto/src/utils/config.ts +144 -0
  798. package/connectors/connect-reducto/src/utils/output.ts +256 -0
  799. package/connectors/connect-reducto/tsconfig.json +18 -0
  800. package/connectors/connect-resend/.npmrc.example +2 -0
  801. package/connectors/connect-resend/AGENTS.md +76 -0
  802. package/connectors/connect-resend/CLAUDE.md +76 -0
  803. package/connectors/connect-resend/GEMINI.md +76 -0
  804. package/connectors/connect-resend/README.md +94 -0
  805. package/connectors/connect-resend/package.json +58 -0
  806. package/connectors/connect-resend/src/api/api-keys.ts +41 -0
  807. package/connectors/connect-resend/src/api/audiences.ts +46 -0
  808. package/connectors/connect-resend/src/api/broadcasts.ts +65 -0
  809. package/connectors/connect-resend/src/api/client.ts +132 -0
  810. package/connectors/connect-resend/src/api/contacts.ts +64 -0
  811. package/connectors/connect-resend/src/api/domains.ts +64 -0
  812. package/connectors/connect-resend/src/api/emails.ts +66 -0
  813. package/connectors/connect-resend/src/api/index.ts +77 -0
  814. package/connectors/connect-resend/src/api/templates.ts +65 -0
  815. package/connectors/connect-resend/src/api/webhooks.ts +55 -0
  816. package/connectors/connect-resend/src/cli/index.ts +1029 -0
  817. package/connectors/connect-resend/src/index.ts +32 -0
  818. package/connectors/connect-resend/src/types/index.ts +327 -0
  819. package/connectors/connect-resend/src/utils/config.ts +228 -0
  820. package/connectors/connect-resend/src/utils/output.ts +119 -0
  821. package/connectors/connect-resend/tsconfig.json +21 -0
  822. package/connectors/connect-revolut/.npmrc.example +2 -0
  823. package/connectors/connect-revolut/AGENTS.md +162 -0
  824. package/connectors/connect-revolut/CLAUDE.md +162 -0
  825. package/connectors/connect-revolut/GEMINI.md +162 -0
  826. package/connectors/connect-revolut/README.md +145 -0
  827. package/connectors/connect-revolut/package.json +54 -0
  828. package/connectors/connect-revolut/src/api/accounts.ts +46 -0
  829. package/connectors/connect-revolut/src/api/cards.ts +87 -0
  830. package/connectors/connect-revolut/src/api/client.ts +128 -0
  831. package/connectors/connect-revolut/src/api/counterparties.ts +64 -0
  832. package/connectors/connect-revolut/src/api/exchange.ts +87 -0
  833. package/connectors/connect-revolut/src/api/index.ts +85 -0
  834. package/connectors/connect-revolut/src/api/payments.ts +64 -0
  835. package/connectors/connect-revolut/src/api/transactions.ts +62 -0
  836. package/connectors/connect-revolut/src/cli/index.ts +674 -0
  837. package/connectors/connect-revolut/src/index.ts +32 -0
  838. package/connectors/connect-revolut/src/types/index.ts +306 -0
  839. package/connectors/connect-revolut/src/utils/config.ts +212 -0
  840. package/connectors/connect-revolut/src/utils/output.ts +77 -0
  841. package/connectors/connect-revolut/tsconfig.json +16 -0
  842. package/connectors/connect-sedo/.env.example +7 -0
  843. package/connectors/connect-sedo/.npmrc.example +2 -0
  844. package/connectors/connect-sedo/AGENTS.md +111 -0
  845. package/connectors/connect-sedo/CLAUDE.md +111 -0
  846. package/connectors/connect-sedo/GEMINI.md +111 -0
  847. package/connectors/connect-sedo/README.md +112 -0
  848. package/connectors/connect-sedo/package.json +54 -0
  849. package/connectors/connect-sedo/src/api/client.ts +139 -0
  850. package/connectors/connect-sedo/src/api/domains.ts +246 -0
  851. package/connectors/connect-sedo/src/api/index.ts +30 -0
  852. package/connectors/connect-sedo/src/cli/index.ts +490 -0
  853. package/connectors/connect-sedo/src/index.ts +18 -0
  854. package/connectors/connect-sedo/src/types/index.ts +104 -0
  855. package/connectors/connect-sedo/src/utils/config.ts +234 -0
  856. package/connectors/connect-sedo/src/utils/output.ts +62 -0
  857. package/connectors/connect-sedo/tsconfig.json +29 -0
  858. package/connectors/connect-sentry/.env.example +10 -0
  859. package/connectors/connect-sentry/.npmrc.example +2 -0
  860. package/connectors/connect-sentry/AGENTS.md +102 -0
  861. package/connectors/connect-sentry/CLAUDE.md +102 -0
  862. package/connectors/connect-sentry/GEMINI.md +102 -0
  863. package/connectors/connect-sentry/README.md +96 -0
  864. package/connectors/connect-sentry/package.json +55 -0
  865. package/connectors/connect-sentry/src/api/client.ts +136 -0
  866. package/connectors/connect-sentry/src/api/example.ts +48 -0
  867. package/connectors/connect-sentry/src/api/index.ts +49 -0
  868. package/connectors/connect-sentry/src/cli/index.ts +242 -0
  869. package/connectors/connect-sentry/src/index.ts +24 -0
  870. package/connectors/connect-sentry/src/types/index.ts +69 -0
  871. package/connectors/connect-sentry/src/utils/config.ts +210 -0
  872. package/connectors/connect-sentry/src/utils/output.ts +119 -0
  873. package/connectors/connect-sentry/tsconfig.json +16 -0
  874. package/connectors/connect-shadcn/.env.example +5 -0
  875. package/connectors/connect-shadcn/.npmrc.example +2 -0
  876. package/connectors/connect-shadcn/AGENTS.md +104 -0
  877. package/connectors/connect-shadcn/CLAUDE.md +104 -0
  878. package/connectors/connect-shadcn/GEMINI.md +104 -0
  879. package/connectors/connect-shadcn/README.md +94 -0
  880. package/connectors/connect-shadcn/package.json +55 -0
  881. package/connectors/connect-shadcn/src/api/client.ts +91 -0
  882. package/connectors/connect-shadcn/src/api/components.ts +146 -0
  883. package/connectors/connect-shadcn/src/api/index.ts +50 -0
  884. package/connectors/connect-shadcn/src/cli/index.ts +320 -0
  885. package/connectors/connect-shadcn/src/index.ts +22 -0
  886. package/connectors/connect-shadcn/src/types/index.ts +89 -0
  887. package/connectors/connect-shadcn/src/utils/config.ts +208 -0
  888. package/connectors/connect-shadcn/src/utils/output.ts +119 -0
  889. package/connectors/connect-shadcn/tsconfig.json +16 -0
  890. package/connectors/connect-shopify/.npmrc.example +2 -0
  891. package/connectors/connect-shopify/AGENTS.md +170 -0
  892. package/connectors/connect-shopify/CLAUDE.md +170 -0
  893. package/connectors/connect-shopify/GEMINI.md +170 -0
  894. package/connectors/connect-shopify/README.md +153 -0
  895. package/connectors/connect-shopify/package.json +29 -0
  896. package/connectors/connect-shopify/src/api/client.ts +163 -0
  897. package/connectors/connect-shopify/src/api/collections.ts +322 -0
  898. package/connectors/connect-shopify/src/api/customers.ts +239 -0
  899. package/connectors/connect-shopify/src/api/index.ts +89 -0
  900. package/connectors/connect-shopify/src/api/inventory.ts +236 -0
  901. package/connectors/connect-shopify/src/api/orders.ts +367 -0
  902. package/connectors/connect-shopify/src/api/products.ts +252 -0
  903. package/connectors/connect-shopify/src/api/shop.ts +50 -0
  904. package/connectors/connect-shopify/src/cli/index.ts +870 -0
  905. package/connectors/connect-shopify/src/index.ts +35 -0
  906. package/connectors/connect-shopify/src/types/index.ts +262 -0
  907. package/connectors/connect-shopify/src/utils/config.ts +240 -0
  908. package/connectors/connect-shopify/src/utils/output.ts +119 -0
  909. package/connectors/connect-shopify/tsconfig.json +17 -0
  910. package/connectors/connect-snap/.npmrc.example +2 -0
  911. package/connectors/connect-snap/AGENTS.md +76 -0
  912. package/connectors/connect-snap/CLAUDE.md +76 -0
  913. package/connectors/connect-snap/GEMINI.md +76 -0
  914. package/connectors/connect-snap/README.md +94 -0
  915. package/connectors/connect-snap/package.json +62 -0
  916. package/connectors/connect-snap/src/api/accounts.ts +81 -0
  917. package/connectors/connect-snap/src/api/ads.ts +102 -0
  918. package/connectors/connect-snap/src/api/adsquads.ts +130 -0
  919. package/connectors/connect-snap/src/api/audiences.ts +208 -0
  920. package/connectors/connect-snap/src/api/campaigns.ts +92 -0
  921. package/connectors/connect-snap/src/api/catalogs.ts +313 -0
  922. package/connectors/connect-snap/src/api/client.ts +324 -0
  923. package/connectors/connect-snap/src/api/conversions.ts +403 -0
  924. package/connectors/connect-snap/src/api/creatives.ts +232 -0
  925. package/connectors/connect-snap/src/api/index.ts +124 -0
  926. package/connectors/connect-snap/src/api/leads.ts +299 -0
  927. package/connectors/connect-snap/src/api/media.ts +246 -0
  928. package/connectors/connect-snap/src/api/organizations.ts +30 -0
  929. package/connectors/connect-snap/src/api/pixels.ts +215 -0
  930. package/connectors/connect-snap/src/api/stats.ts +305 -0
  931. package/connectors/connect-snap/src/api/targeting.ts +255 -0
  932. package/connectors/connect-snap/src/cli/index.ts +1810 -0
  933. package/connectors/connect-snap/src/index.ts +52 -0
  934. package/connectors/connect-snap/src/types/index.ts +1226 -0
  935. package/connectors/connect-snap/src/utils/config.ts +509 -0
  936. package/connectors/connect-snap/src/utils/output.ts +139 -0
  937. package/connectors/connect-snap/tsconfig.json +16 -0
  938. package/connectors/connect-stabilityai/.npmrc.example +2 -0
  939. package/connectors/connect-stabilityai/AGENTS.md +76 -0
  940. package/connectors/connect-stabilityai/CLAUDE.md +76 -0
  941. package/connectors/connect-stabilityai/GEMINI.md +76 -0
  942. package/connectors/connect-stabilityai/README.md +94 -0
  943. package/connectors/connect-stabilityai/package.json +63 -0
  944. package/connectors/connect-stabilityai/src/api/3d.ts +99 -0
  945. package/connectors/connect-stabilityai/src/api/client.ts +238 -0
  946. package/connectors/connect-stabilityai/src/api/edit.ts +130 -0
  947. package/connectors/connect-stabilityai/src/api/engines.ts +41 -0
  948. package/connectors/connect-stabilityai/src/api/image-to-image.ts +150 -0
  949. package/connectors/connect-stabilityai/src/api/index.ts +81 -0
  950. package/connectors/connect-stabilityai/src/api/inpaint.ts +153 -0
  951. package/connectors/connect-stabilityai/src/api/outpaint.ts +117 -0
  952. package/connectors/connect-stabilityai/src/api/text-to-image.ts +181 -0
  953. package/connectors/connect-stabilityai/src/api/upscale.ts +113 -0
  954. package/connectors/connect-stabilityai/src/api/user.ts +24 -0
  955. package/connectors/connect-stabilityai/src/cli/index.ts +859 -0
  956. package/connectors/connect-stabilityai/src/index.ts +37 -0
  957. package/connectors/connect-stabilityai/src/types/index.ts +315 -0
  958. package/connectors/connect-stabilityai/src/utils/config.ts +340 -0
  959. package/connectors/connect-stabilityai/src/utils/output.ts +119 -0
  960. package/connectors/connect-stabilityai/tsconfig.json +21 -0
  961. package/connectors/connect-stripe/.env.example +10 -0
  962. package/connectors/connect-stripe/.npmrc.example +2 -0
  963. package/connectors/connect-stripe/AGENTS.md +204 -0
  964. package/connectors/connect-stripe/CLAUDE.md +204 -0
  965. package/connectors/connect-stripe/GEMINI.md +204 -0
  966. package/connectors/connect-stripe/README.md +181 -0
  967. package/connectors/connect-stripe/package.json +55 -0
  968. package/connectors/connect-stripe/src/api/balance.ts +28 -0
  969. package/connectors/connect-stripe/src/api/billing-portal.ts +64 -0
  970. package/connectors/connect-stripe/src/api/charges.ts +65 -0
  971. package/connectors/connect-stripe/src/api/checkout-sessions.ts +55 -0
  972. package/connectors/connect-stripe/src/api/client.ts +190 -0
  973. package/connectors/connect-stripe/src/api/coupons.ts +52 -0
  974. package/connectors/connect-stripe/src/api/customers.ts +65 -0
  975. package/connectors/connect-stripe/src/api/events.ts +28 -0
  976. package/connectors/connect-stripe/src/api/index.ts +118 -0
  977. package/connectors/connect-stripe/src/api/invoice-items.ts +52 -0
  978. package/connectors/connect-stripe/src/api/invoices.ts +102 -0
  979. package/connectors/connect-stripe/src/api/payment-intents.ts +81 -0
  980. package/connectors/connect-stripe/src/api/payment-links.ts +57 -0
  981. package/connectors/connect-stripe/src/api/payment-methods.ts +59 -0
  982. package/connectors/connect-stripe/src/api/prices.ts +57 -0
  983. package/connectors/connect-stripe/src/api/products.ts +65 -0
  984. package/connectors/connect-stripe/src/api/promotion-codes.ts +44 -0
  985. package/connectors/connect-stripe/src/api/subscription-items.ts +53 -0
  986. package/connectors/connect-stripe/src/api/subscriptions.ts +73 -0
  987. package/connectors/connect-stripe/src/api/webhooks.ts +52 -0
  988. package/connectors/connect-stripe/src/cli/index.ts +1995 -0
  989. package/connectors/connect-stripe/src/index.ts +44 -0
  990. package/connectors/connect-stripe/src/types/index.ts +2147 -0
  991. package/connectors/connect-stripe/src/utils/config.ts +220 -0
  992. package/connectors/connect-stripe/src/utils/output.ts +119 -0
  993. package/connectors/connect-stripe/tsconfig.json +16 -0
  994. package/connectors/connect-stripeatlas/.env.example +11 -0
  995. package/connectors/connect-stripeatlas/.npmrc.example +2 -0
  996. package/connectors/connect-stripeatlas/AGENTS.md +102 -0
  997. package/connectors/connect-stripeatlas/CLAUDE.md +102 -0
  998. package/connectors/connect-stripeatlas/GEMINI.md +102 -0
  999. package/connectors/connect-stripeatlas/README.md +95 -0
  1000. package/connectors/connect-stripeatlas/package.json +57 -0
  1001. package/connectors/connect-stripeatlas/src/api/client.ts +77 -0
  1002. package/connectors/connect-stripeatlas/src/api/example.ts +60 -0
  1003. package/connectors/connect-stripeatlas/src/api/index.ts +65 -0
  1004. package/connectors/connect-stripeatlas/src/cli/index.ts +270 -0
  1005. package/connectors/connect-stripeatlas/src/index.ts +29 -0
  1006. package/connectors/connect-stripeatlas/src/types/index.ts +93 -0
  1007. package/connectors/connect-stripeatlas/src/utils/config.ts +228 -0
  1008. package/connectors/connect-stripeatlas/src/utils/output.ts +119 -0
  1009. package/connectors/connect-stripeatlas/tsconfig.json +16 -0
  1010. package/connectors/connect-substack/.env.example +4 -0
  1011. package/connectors/connect-substack/.npmrc.example +2 -0
  1012. package/connectors/connect-substack/AGENTS.md +168 -0
  1013. package/connectors/connect-substack/CLAUDE.md +168 -0
  1014. package/connectors/connect-substack/GEMINI.md +168 -0
  1015. package/connectors/connect-substack/README.md +146 -0
  1016. package/connectors/connect-substack/package.json +51 -0
  1017. package/connectors/connect-substack/src/api/client.ts +147 -0
  1018. package/connectors/connect-substack/src/api/comments.ts +68 -0
  1019. package/connectors/connect-substack/src/api/index.ts +77 -0
  1020. package/connectors/connect-substack/src/api/posts.ts +135 -0
  1021. package/connectors/connect-substack/src/api/publication.ts +126 -0
  1022. package/connectors/connect-substack/src/api/stats.ts +113 -0
  1023. package/connectors/connect-substack/src/api/subscribers.ts +97 -0
  1024. package/connectors/connect-substack/src/cli/index.ts +531 -0
  1025. package/connectors/connect-substack/src/index.ts +31 -0
  1026. package/connectors/connect-substack/src/types/index.ts +257 -0
  1027. package/connectors/connect-substack/src/utils/config.ts +208 -0
  1028. package/connectors/connect-substack/src/utils/output.ts +143 -0
  1029. package/connectors/connect-substack/tsconfig.json +16 -0
  1030. package/connectors/connect-tiktok/.npmrc.example +2 -0
  1031. package/connectors/connect-tiktok/AGENTS.md +76 -0
  1032. package/connectors/connect-tiktok/CLAUDE.md +76 -0
  1033. package/connectors/connect-tiktok/GEMINI.md +76 -0
  1034. package/connectors/connect-tiktok/README.md +94 -0
  1035. package/connectors/connect-tiktok/package.json +60 -0
  1036. package/connectors/connect-tiktok/src/api/adgroups.ts +144 -0
  1037. package/connectors/connect-tiktok/src/api/ads.ts +160 -0
  1038. package/connectors/connect-tiktok/src/api/advertisers.ts +104 -0
  1039. package/connectors/connect-tiktok/src/api/audiences.ts +246 -0
  1040. package/connectors/connect-tiktok/src/api/business.ts +273 -0
  1041. package/connectors/connect-tiktok/src/api/campaigns.ts +116 -0
  1042. package/connectors/connect-tiktok/src/api/catalogs.ts +326 -0
  1043. package/connectors/connect-tiktok/src/api/client.ts +137 -0
  1044. package/connectors/connect-tiktok/src/api/creatives.ts +293 -0
  1045. package/connectors/connect-tiktok/src/api/events.ts +314 -0
  1046. package/connectors/connect-tiktok/src/api/identity.ts +255 -0
  1047. package/connectors/connect-tiktok/src/api/index.ts +105 -0
  1048. package/connectors/connect-tiktok/src/api/pixels.ts +188 -0
  1049. package/connectors/connect-tiktok/src/api/reports.ts +290 -0
  1050. package/connectors/connect-tiktok/src/api/targeting.ts +326 -0
  1051. package/connectors/connect-tiktok/src/cli/index.ts +1329 -0
  1052. package/connectors/connect-tiktok/src/index.ts +39 -0
  1053. package/connectors/connect-tiktok/src/types/index.ts +1052 -0
  1054. package/connectors/connect-tiktok/src/utils/config.ts +419 -0
  1055. package/connectors/connect-tiktok/src/utils/output.ts +136 -0
  1056. package/connectors/connect-tiktok/tsconfig.json +16 -0
  1057. package/connectors/connect-tinker/.env.example +8 -0
  1058. package/connectors/connect-tinker/.npmrc.example +2 -0
  1059. package/connectors/connect-tinker/AGENTS.md +189 -0
  1060. package/connectors/connect-tinker/CLAUDE.md +189 -0
  1061. package/connectors/connect-tinker/GEMINI.md +189 -0
  1062. package/connectors/connect-tinker/README.md +157 -0
  1063. package/connectors/connect-tinker/package.json +55 -0
  1064. package/connectors/connect-tinker/src/api/client.ts +146 -0
  1065. package/connectors/connect-tinker/src/api/index.ts +100 -0
  1066. package/connectors/connect-tinker/src/api/sampling.ts +163 -0
  1067. package/connectors/connect-tinker/src/api/state.ts +147 -0
  1068. package/connectors/connect-tinker/src/api/training.ts +152 -0
  1069. package/connectors/connect-tinker/src/cli/index.ts +775 -0
  1070. package/connectors/connect-tinker/src/index.ts +28 -0
  1071. package/connectors/connect-tinker/src/types/index.ts +287 -0
  1072. package/connectors/connect-tinker/src/utils/config.ts +230 -0
  1073. package/connectors/connect-tinker/src/utils/output.ts +139 -0
  1074. package/connectors/connect-tinker/tsconfig.json +16 -0
  1075. package/connectors/connect-twilio/.npmrc.example +2 -0
  1076. package/connectors/connect-twilio/AGENTS.md +76 -0
  1077. package/connectors/connect-twilio/CLAUDE.md +76 -0
  1078. package/connectors/connect-twilio/GEMINI.md +76 -0
  1079. package/connectors/connect-twilio/README.md +94 -0
  1080. package/connectors/connect-twilio/package.json +72 -0
  1081. package/connectors/connect-twilio/src/api/accounts.ts +352 -0
  1082. package/connectors/connect-twilio/src/api/calls.ts +120 -0
  1083. package/connectors/connect-twilio/src/api/client.ts +181 -0
  1084. package/connectors/connect-twilio/src/api/conversations.ts +313 -0
  1085. package/connectors/connect-twilio/src/api/index.ts +91 -0
  1086. package/connectors/connect-twilio/src/api/lookup.ts +271 -0
  1087. package/connectors/connect-twilio/src/api/messages.ts +107 -0
  1088. package/connectors/connect-twilio/src/api/numbers.ts +152 -0
  1089. package/connectors/connect-twilio/src/api/verify.ts +213 -0
  1090. package/connectors/connect-twilio/src/api/video.ts +305 -0
  1091. package/connectors/connect-twilio/src/cli/index.ts +1093 -0
  1092. package/connectors/connect-twilio/src/index.ts +34 -0
  1093. package/connectors/connect-twilio/src/types/index.ts +983 -0
  1094. package/connectors/connect-twilio/src/utils/config.ts +424 -0
  1095. package/connectors/connect-twilio/src/utils/output.ts +119 -0
  1096. package/connectors/connect-twilio/tsconfig.json +16 -0
  1097. package/connectors/connect-uspto/.env.example +13 -0
  1098. package/connectors/connect-uspto/.npmrc.example +2 -0
  1099. package/connectors/connect-uspto/AGENTS.md +80 -0
  1100. package/connectors/connect-uspto/CLAUDE.md +80 -0
  1101. package/connectors/connect-uspto/GEMINI.md +80 -0
  1102. package/connectors/connect-uspto/README.md +98 -0
  1103. package/connectors/connect-uspto/package.json +54 -0
  1104. package/connectors/connect-uspto/src/api/browser.ts +335 -0
  1105. package/connectors/connect-uspto/src/api/client.ts +186 -0
  1106. package/connectors/connect-uspto/src/api/index.ts +104 -0
  1107. package/connectors/connect-uspto/src/api/patents.ts +290 -0
  1108. package/connectors/connect-uspto/src/api/ptab.ts +150 -0
  1109. package/connectors/connect-uspto/src/api/trademarks.ts +302 -0
  1110. package/connectors/connect-uspto/src/cli/index.ts +713 -0
  1111. package/connectors/connect-uspto/src/index.ts +26 -0
  1112. package/connectors/connect-uspto/src/types/index.ts +302 -0
  1113. package/connectors/connect-uspto/src/utils/config.ts +235 -0
  1114. package/connectors/connect-uspto/src/utils/output.ts +119 -0
  1115. package/connectors/connect-uspto/tsconfig.json +16 -0
  1116. package/connectors/connect-webflow/.npmrc.example +2 -0
  1117. package/connectors/connect-webflow/AGENTS.md +193 -0
  1118. package/connectors/connect-webflow/CLAUDE.md +193 -0
  1119. package/connectors/connect-webflow/GEMINI.md +193 -0
  1120. package/connectors/connect-webflow/README.md +173 -0
  1121. package/connectors/connect-webflow/package.json +29 -0
  1122. package/connectors/connect-webflow/src/api/assets.ts +89 -0
  1123. package/connectors/connect-webflow/src/api/client.ts +121 -0
  1124. package/connectors/connect-webflow/src/api/collections.ts +46 -0
  1125. package/connectors/connect-webflow/src/api/forms.ts +75 -0
  1126. package/connectors/connect-webflow/src/api/index.ts +93 -0
  1127. package/connectors/connect-webflow/src/api/items.ts +141 -0
  1128. package/connectors/connect-webflow/src/api/orders.ts +89 -0
  1129. package/connectors/connect-webflow/src/api/pages.ts +76 -0
  1130. package/connectors/connect-webflow/src/api/products.ts +160 -0
  1131. package/connectors/connect-webflow/src/api/sites.ts +41 -0
  1132. package/connectors/connect-webflow/src/api/users.ts +81 -0
  1133. package/connectors/connect-webflow/src/cli/index.ts +1048 -0
  1134. package/connectors/connect-webflow/src/index.ts +35 -0
  1135. package/connectors/connect-webflow/src/types/index.ts +488 -0
  1136. package/connectors/connect-webflow/src/utils/config.ts +208 -0
  1137. package/connectors/connect-webflow/src/utils/output.ts +119 -0
  1138. package/connectors/connect-webflow/tsconfig.json +17 -0
  1139. package/connectors/connect-wix/.npmrc.example +2 -0
  1140. package/connectors/connect-wix/AGENTS.md +181 -0
  1141. package/connectors/connect-wix/CLAUDE.md +181 -0
  1142. package/connectors/connect-wix/GEMINI.md +181 -0
  1143. package/connectors/connect-wix/README.md +163 -0
  1144. package/connectors/connect-wix/package.json +29 -0
  1145. package/connectors/connect-wix/src/api/bookings.ts +575 -0
  1146. package/connectors/connect-wix/src/api/client.ts +147 -0
  1147. package/connectors/connect-wix/src/api/contacts.ts +308 -0
  1148. package/connectors/connect-wix/src/api/index.ts +90 -0
  1149. package/connectors/connect-wix/src/api/inventory.ts +195 -0
  1150. package/connectors/connect-wix/src/api/members.ts +172 -0
  1151. package/connectors/connect-wix/src/api/orders.ts +415 -0
  1152. package/connectors/connect-wix/src/api/products.ts +453 -0
  1153. package/connectors/connect-wix/src/api/sites.ts +77 -0
  1154. package/connectors/connect-wix/src/cli/index.ts +1009 -0
  1155. package/connectors/connect-wix/src/index.ts +35 -0
  1156. package/connectors/connect-wix/src/types/index.ts +786 -0
  1157. package/connectors/connect-wix/src/utils/config.ts +219 -0
  1158. package/connectors/connect-wix/src/utils/output.ts +119 -0
  1159. package/connectors/connect-wix/tsconfig.json +17 -0
  1160. package/connectors/connect-x/.env.example +11 -0
  1161. package/connectors/connect-x/.npmrc.example +2 -0
  1162. package/connectors/connect-x/AGENTS.md +84 -0
  1163. package/connectors/connect-x/CLAUDE.md +84 -0
  1164. package/connectors/connect-x/GEMINI.md +84 -0
  1165. package/connectors/connect-x/README.md +102 -0
  1166. package/connectors/connect-x/package.json +59 -0
  1167. package/connectors/connect-x/src/api/client.ts +392 -0
  1168. package/connectors/connect-x/src/api/index.ts +171 -0
  1169. package/connectors/connect-x/src/api/media.ts +323 -0
  1170. package/connectors/connect-x/src/api/oauth.ts +408 -0
  1171. package/connectors/connect-x/src/api/oauth1.ts +351 -0
  1172. package/connectors/connect-x/src/api/tweets.ts +339 -0
  1173. package/connectors/connect-x/src/api/users.ts +259 -0
  1174. package/connectors/connect-x/src/cli/index.ts +1205 -0
  1175. package/connectors/connect-x/src/index.ts +92 -0
  1176. package/connectors/connect-x/src/types/index.ts +230 -0
  1177. package/connectors/connect-x/src/utils/config.ts +496 -0
  1178. package/connectors/connect-x/src/utils/output.ts +119 -0
  1179. package/connectors/connect-x/tsconfig.json +16 -0
  1180. package/connectors/connect-xads/.env.example +11 -0
  1181. package/connectors/connect-xads/.npmrc.example +2 -0
  1182. package/connectors/connect-xads/AGENTS.md +183 -0
  1183. package/connectors/connect-xads/CLAUDE.md +183 -0
  1184. package/connectors/connect-xads/GEMINI.md +183 -0
  1185. package/connectors/connect-xads/README.md +161 -0
  1186. package/connectors/connect-xads/package.json +52 -0
  1187. package/connectors/connect-xads/src/api/accounts.ts +70 -0
  1188. package/connectors/connect-xads/src/api/analytics.ts +165 -0
  1189. package/connectors/connect-xads/src/api/audiences.ts +143 -0
  1190. package/connectors/connect-xads/src/api/campaigns.ts +113 -0
  1191. package/connectors/connect-xads/src/api/client.ts +315 -0
  1192. package/connectors/connect-xads/src/api/index.ts +91 -0
  1193. package/connectors/connect-xads/src/api/line-items.ts +126 -0
  1194. package/connectors/connect-xads/src/api/media.ts +96 -0
  1195. package/connectors/connect-xads/src/api/promoted-tweets.ts +97 -0
  1196. package/connectors/connect-xads/src/api/targeting.ts +165 -0
  1197. package/connectors/connect-xads/src/cli/index.ts +1036 -0
  1198. package/connectors/connect-xads/src/index.ts +41 -0
  1199. package/connectors/connect-xads/src/types/index.ts +474 -0
  1200. package/connectors/connect-xads/src/utils/config.ts +176 -0
  1201. package/connectors/connect-xads/src/utils/output.ts +177 -0
  1202. package/connectors/connect-xads/tsconfig.json +15 -0
  1203. package/connectors/connect-xai/.env.example +4 -0
  1204. package/connectors/connect-xai/.npmrc.example +2 -0
  1205. package/connectors/connect-xai/AGENTS.md +97 -0
  1206. package/connectors/connect-xai/CLAUDE.md +97 -0
  1207. package/connectors/connect-xai/GEMINI.md +97 -0
  1208. package/connectors/connect-xai/README.md +106 -0
  1209. package/connectors/connect-xai/package.json +60 -0
  1210. package/connectors/connect-xai/src/api/chat.ts +114 -0
  1211. package/connectors/connect-xai/src/api/client.ts +122 -0
  1212. package/connectors/connect-xai/src/api/index.ts +58 -0
  1213. package/connectors/connect-xai/src/cli/index.ts +330 -0
  1214. package/connectors/connect-xai/src/index.ts +24 -0
  1215. package/connectors/connect-xai/src/types/index.ts +172 -0
  1216. package/connectors/connect-xai/src/utils/config.ts +208 -0
  1217. package/connectors/connect-xai/src/utils/output.ts +119 -0
  1218. package/connectors/connect-xai/tsconfig.json +16 -0
  1219. package/connectors/connect-youtube/.npmrc.example +2 -0
  1220. package/connectors/connect-youtube/AGENTS.md +76 -0
  1221. package/connectors/connect-youtube/CLAUDE.md +76 -0
  1222. package/connectors/connect-youtube/GEMINI.md +76 -0
  1223. package/connectors/connect-youtube/README.md +94 -0
  1224. package/connectors/connect-youtube/package.json +61 -0
  1225. package/connectors/connect-youtube/src/api/analytics.ts +364 -0
  1226. package/connectors/connect-youtube/src/api/captions.ts +196 -0
  1227. package/connectors/connect-youtube/src/api/categories.ts +107 -0
  1228. package/connectors/connect-youtube/src/api/channels.ts +149 -0
  1229. package/connectors/connect-youtube/src/api/client.ts +278 -0
  1230. package/connectors/connect-youtube/src/api/commentThreads.ts +215 -0
  1231. package/connectors/connect-youtube/src/api/comments.ts +179 -0
  1232. package/connectors/connect-youtube/src/api/index.ts +113 -0
  1233. package/connectors/connect-youtube/src/api/live.ts +480 -0
  1234. package/connectors/connect-youtube/src/api/members.ts +119 -0
  1235. package/connectors/connect-youtube/src/api/playlistItems.ts +184 -0
  1236. package/connectors/connect-youtube/src/api/playlists.ts +174 -0
  1237. package/connectors/connect-youtube/src/api/search.ts +222 -0
  1238. package/connectors/connect-youtube/src/api/subscriptions.ts +164 -0
  1239. package/connectors/connect-youtube/src/api/thumbnails.ts +73 -0
  1240. package/connectors/connect-youtube/src/api/videos.ts +217 -0
  1241. package/connectors/connect-youtube/src/api/watermarks.ts +110 -0
  1242. package/connectors/connect-youtube/src/cli/index.ts +1768 -0
  1243. package/connectors/connect-youtube/src/index.ts +41 -0
  1244. package/connectors/connect-youtube/src/types/index.ts +1207 -0
  1245. package/connectors/connect-youtube/src/utils/auth.ts +236 -0
  1246. package/connectors/connect-youtube/src/utils/config.ts +529 -0
  1247. package/connectors/connect-youtube/src/utils/output.ts +157 -0
  1248. package/connectors/connect-youtube/tsconfig.json +16 -0
  1249. package/connectors/connect-zoom/.npmrc.example +2 -0
  1250. package/connectors/connect-zoom/AGENTS.md +164 -0
  1251. package/connectors/connect-zoom/CLAUDE.md +164 -0
  1252. package/connectors/connect-zoom/GEMINI.md +164 -0
  1253. package/connectors/connect-zoom/README.md +145 -0
  1254. package/connectors/connect-zoom/package.json +51 -0
  1255. package/connectors/connect-zoom/src/api/client.ts +177 -0
  1256. package/connectors/connect-zoom/src/api/index.ts +81 -0
  1257. package/connectors/connect-zoom/src/api/meetings.ts +126 -0
  1258. package/connectors/connect-zoom/src/api/recordings.ts +129 -0
  1259. package/connectors/connect-zoom/src/api/reports.ts +178 -0
  1260. package/connectors/connect-zoom/src/api/users.ts +52 -0
  1261. package/connectors/connect-zoom/src/api/webinars.ts +115 -0
  1262. package/connectors/connect-zoom/src/cli/index.ts +735 -0
  1263. package/connectors/connect-zoom/src/index.ts +26 -0
  1264. package/connectors/connect-zoom/src/types/index.ts +311 -0
  1265. package/connectors/connect-zoom/src/utils/config.ts +241 -0
  1266. package/connectors/connect-zoom/src/utils/output.ts +119 -0
  1267. package/connectors/connect-zoom/tsconfig.json +16 -0
  1268. package/dist/index.js +580 -0
  1269. package/package.json +68 -0
@@ -0,0 +1,1810 @@
1
+ #!/usr/bin/env bun
2
+ import { Command } from 'commander';
3
+ import chalk from 'chalk';
4
+ import { Snap, exchangeCodeForTokens, generateAuthUrl } from '../api';
5
+ import {
6
+ getAccessToken,
7
+ setAccessToken,
8
+ setRefreshToken,
9
+ setTokens,
10
+ getClientId,
11
+ setClientId,
12
+ getClientSecret,
13
+ setClientSecret,
14
+ clearConfig,
15
+ getConfigDir,
16
+ getBaseConfigDir,
17
+ setProfileOverride,
18
+ getCurrentProfile,
19
+ setCurrentProfile,
20
+ listProfiles,
21
+ createProfile,
22
+ deleteProfile,
23
+ profileExists,
24
+ loadProfile,
25
+ getAdAccountId,
26
+ getDefaultAdAccountId,
27
+ setDefaultAdAccountId,
28
+ setNamedAdAccount,
29
+ removeNamedAdAccount,
30
+ listNamedAdAccounts,
31
+ getOrganizationId,
32
+ getDefaultOrganizationId,
33
+ setDefaultOrganizationId,
34
+ setNamedOrganization,
35
+ removeNamedOrganization,
36
+ listNamedOrganizations,
37
+ getExportsDir,
38
+ getImportsDir,
39
+ } from '../utils/config';
40
+ import type { OutputFormat } from '../utils/output';
41
+ import { success, error, info, print, formatMicroCurrency } from '../utils/output';
42
+
43
+ const CONNECTOR_NAME = 'connect-snap';
44
+ const VERSION = '0.1.0';
45
+
46
+ const program = new Command();
47
+
48
+ program
49
+ .name(CONNECTOR_NAME)
50
+ .description('Snapchat Marketing API CLI - Organizations, ad accounts, campaigns, ads, creatives, audiences, and analytics')
51
+ .version(VERSION)
52
+ .option('-t, --token <token>', 'Access token (overrides config)')
53
+ .option('-f, --format <format>', 'Output format (json, pretty)', 'pretty')
54
+ .option('-p, --profile <profile>', 'Use a specific profile')
55
+ .hook('preAction', (thisCommand) => {
56
+ const opts = thisCommand.opts();
57
+ if (opts.profile) {
58
+ if (!profileExists(opts.profile)) {
59
+ error(`Profile "${opts.profile}" does not exist. Create it with "${CONNECTOR_NAME} profile create ${opts.profile}"`);
60
+ process.exit(1);
61
+ }
62
+ setProfileOverride(opts.profile);
63
+ }
64
+ if (opts.token) {
65
+ process.env.SNAP_ACCESS_TOKEN = opts.token;
66
+ }
67
+ });
68
+
69
+ function getFormat(cmd: Command): OutputFormat {
70
+ const parent = cmd.parent;
71
+ return (parent?.opts().format || 'pretty') as OutputFormat;
72
+ }
73
+
74
+ function getClient(): Snap {
75
+ const accessToken = getAccessToken();
76
+ if (!accessToken) {
77
+ error(`No access token configured. Run "${CONNECTOR_NAME} auth login" or set SNAP_ACCESS_TOKEN environment variable.`);
78
+ process.exit(1);
79
+ }
80
+ const config = loadProfile();
81
+ return new Snap({
82
+ accessToken,
83
+ refreshToken: config.refreshToken,
84
+ clientId: config.clientId,
85
+ clientSecret: config.clientSecret,
86
+ });
87
+ }
88
+
89
+ function resolveAdAccountId(nameOrId?: string): string {
90
+ const resolved = getAdAccountId(nameOrId);
91
+ if (!resolved) {
92
+ error(`No ad account specified. Use --account or set default with "${CONNECTOR_NAME} config set-account <id>"`);
93
+ process.exit(1);
94
+ }
95
+ return resolved;
96
+ }
97
+
98
+ function resolveOrganizationId(nameOrId?: string): string {
99
+ const resolved = getOrganizationId(nameOrId);
100
+ if (!resolved) {
101
+ error(`No organization specified. Use --org or set default with "${CONNECTOR_NAME} config set-org <id>"`);
102
+ process.exit(1);
103
+ }
104
+ return resolved;
105
+ }
106
+
107
+ // ============================================
108
+ // Auth Commands
109
+ // ============================================
110
+ const authCmd = program
111
+ .command('auth')
112
+ .description('Authentication management');
113
+
114
+ authCmd
115
+ .command('login')
116
+ .description('Configure OAuth credentials')
117
+ .option('--client-id <id>', 'OAuth Client ID')
118
+ .option('--client-secret <secret>', 'OAuth Client Secret')
119
+ .option('--access-token <token>', 'Access token (if you have one)')
120
+ .option('--refresh-token <token>', 'Refresh token')
121
+ .action(async (opts) => {
122
+ if (opts.clientId) {
123
+ setClientId(opts.clientId);
124
+ info(`Client ID saved`);
125
+ }
126
+ if (opts.clientSecret) {
127
+ setClientSecret(opts.clientSecret);
128
+ info(`Client Secret saved`);
129
+ }
130
+ if (opts.accessToken) {
131
+ setAccessToken(opts.accessToken);
132
+ info(`Access token saved`);
133
+ }
134
+ if (opts.refreshToken) {
135
+ setRefreshToken(opts.refreshToken);
136
+ info(`Refresh token saved`);
137
+ }
138
+
139
+ if (!opts.clientId && !opts.accessToken) {
140
+ info('To authenticate, provide either:');
141
+ info(' 1. --access-token (if you already have a token)');
142
+ info(' 2. --client-id and --client-secret (for OAuth flow)');
143
+ }
144
+
145
+ success(`Credentials saved to profile: ${getCurrentProfile()}`);
146
+ });
147
+
148
+ authCmd
149
+ .command('url')
150
+ .description('Generate OAuth authorization URL')
151
+ .option('--client-id <id>', 'OAuth Client ID')
152
+ .option('--redirect-uri <uri>', 'Redirect URI', 'http://localhost:8080/callback')
153
+ .option('--scope <scopes>', 'Comma-separated scopes', 'snapchat-marketing-api')
154
+ .action((opts) => {
155
+ const clientId = opts.clientId || getClientId();
156
+ if (!clientId) {
157
+ error('Client ID is required. Use --client-id or run "auth login --client-id <id>"');
158
+ process.exit(1);
159
+ }
160
+
161
+ const url = generateAuthUrl(
162
+ clientId,
163
+ opts.redirectUri,
164
+ opts.scope.split(','),
165
+ );
166
+
167
+ info('Open this URL in your browser to authorize:');
168
+ console.log(chalk.cyan(url));
169
+ });
170
+
171
+ authCmd
172
+ .command('exchange <code>')
173
+ .description('Exchange authorization code for tokens')
174
+ .option('--client-id <id>', 'OAuth Client ID')
175
+ .option('--client-secret <secret>', 'OAuth Client Secret')
176
+ .option('--redirect-uri <uri>', 'Redirect URI', 'http://localhost:8080/callback')
177
+ .action(async (code: string, opts) => {
178
+ try {
179
+ const clientId = opts.clientId || getClientId();
180
+ const clientSecret = opts.clientSecret || getClientSecret();
181
+
182
+ if (!clientId || !clientSecret) {
183
+ error('Client ID and Secret are required');
184
+ process.exit(1);
185
+ }
186
+
187
+ const tokens = await exchangeCodeForTokens(
188
+ code,
189
+ clientId,
190
+ clientSecret,
191
+ opts.redirectUri
192
+ );
193
+
194
+ setTokens(tokens.access_token, tokens.refresh_token, tokens.expires_in);
195
+
196
+ success('Tokens saved successfully!');
197
+ info(`Token expires in ${tokens.expires_in} seconds`);
198
+ } catch (err) {
199
+ error(String(err));
200
+ process.exit(1);
201
+ }
202
+ });
203
+
204
+ authCmd
205
+ .command('refresh')
206
+ .description('Refresh the access token')
207
+ .action(async () => {
208
+ try {
209
+ const client = getClient();
210
+ if (!client.canRefreshToken()) {
211
+ error('Cannot refresh token. Need refresh_token, client_id, and client_secret.');
212
+ process.exit(1);
213
+ }
214
+
215
+ await client.refreshToken();
216
+ success('Token refreshed successfully!');
217
+ } catch (err) {
218
+ error(String(err));
219
+ process.exit(1);
220
+ }
221
+ });
222
+
223
+ authCmd
224
+ .command('status')
225
+ .description('Check authentication status')
226
+ .action(() => {
227
+ const config = loadProfile();
228
+ const hasToken = !!config.accessToken;
229
+ const hasRefresh = !!config.refreshToken;
230
+ const hasClientId = !!config.clientId;
231
+ const hasClientSecret = !!config.clientSecret;
232
+
233
+ console.log(chalk.bold('Authentication Status:'));
234
+ console.log(` Access Token: ${hasToken ? chalk.green('Set') : chalk.red('Not set')}`);
235
+ console.log(` Refresh Token: ${hasRefresh ? chalk.green('Set') : chalk.gray('Not set')}`);
236
+ console.log(` Client ID: ${hasClientId ? chalk.green('Set') : chalk.gray('Not set')}`);
237
+ console.log(` Client Secret: ${hasClientSecret ? chalk.green('Set') : chalk.gray('Not set')}`);
238
+
239
+ if (config.tokenExpiresAt) {
240
+ const expiresIn = config.tokenExpiresAt - Date.now();
241
+ if (expiresIn > 0) {
242
+ const minutes = Math.floor(expiresIn / 60000);
243
+ console.log(` Token Expires: ${chalk.yellow(`${minutes} minutes`)}`);
244
+ } else {
245
+ console.log(` Token Expires: ${chalk.red('Expired')}`);
246
+ }
247
+ }
248
+ });
249
+
250
+ // ============================================
251
+ // Profile Commands
252
+ // ============================================
253
+ const profileCmd = program
254
+ .command('profile')
255
+ .description('Manage configuration profiles');
256
+
257
+ profileCmd
258
+ .command('list')
259
+ .description('List all profiles')
260
+ .action(() => {
261
+ const profiles = listProfiles();
262
+ const current = getCurrentProfile();
263
+
264
+ if (profiles.length === 0) {
265
+ info('No profiles found. Use "profile create <name>" to create one.');
266
+ return;
267
+ }
268
+
269
+ success(`Profiles:`);
270
+ profiles.forEach(p => {
271
+ const isActive = p === current ? chalk.green(' (active)') : '';
272
+ console.log(` ${p}${isActive}`);
273
+ });
274
+ });
275
+
276
+ profileCmd
277
+ .command('use <name>')
278
+ .description('Switch to a profile')
279
+ .action((name: string) => {
280
+ if (!profileExists(name)) {
281
+ error(`Profile "${name}" does not exist. Create it with "profile create ${name}"`);
282
+ process.exit(1);
283
+ }
284
+ setCurrentProfile(name);
285
+ success(`Switched to profile: ${name}`);
286
+ });
287
+
288
+ profileCmd
289
+ .command('create <name>')
290
+ .description('Create a new profile')
291
+ .option('--use', 'Switch to this profile after creation')
292
+ .action((name: string, opts) => {
293
+ if (profileExists(name)) {
294
+ error(`Profile "${name}" already exists`);
295
+ process.exit(1);
296
+ }
297
+
298
+ createProfile(name, {});
299
+ success(`Profile "${name}" created`);
300
+
301
+ if (opts.use) {
302
+ setCurrentProfile(name);
303
+ info(`Switched to profile: ${name}`);
304
+ }
305
+ });
306
+
307
+ profileCmd
308
+ .command('delete <name>')
309
+ .description('Delete a profile')
310
+ .action((name: string) => {
311
+ if (name === 'default') {
312
+ error('Cannot delete the default profile');
313
+ process.exit(1);
314
+ }
315
+ if (deleteProfile(name)) {
316
+ success(`Profile "${name}" deleted`);
317
+ } else {
318
+ error(`Profile "${name}" not found`);
319
+ process.exit(1);
320
+ }
321
+ });
322
+
323
+ profileCmd
324
+ .command('show [name]')
325
+ .description('Show profile configuration')
326
+ .action((name?: string) => {
327
+ const profileName = name || getCurrentProfile();
328
+ const config = loadProfile(profileName);
329
+ const active = getCurrentProfile();
330
+
331
+ console.log(chalk.bold(`Profile: ${profileName}${profileName === active ? chalk.green(' (active)') : ''}`));
332
+ info(`Access Token: ${config.accessToken ? `${config.accessToken.substring(0, 8)}...` : chalk.gray('not set')}`);
333
+ info(`Client ID: ${config.clientId ? `${config.clientId.substring(0, 8)}...` : chalk.gray('not set')}`);
334
+ info(`Default Org: ${config.defaultOrganizationId || chalk.gray('not set')}`);
335
+ info(`Default Account: ${config.defaultAdAccountId || chalk.gray('not set')}`);
336
+ });
337
+
338
+ // ============================================
339
+ // Config Commands
340
+ // ============================================
341
+ const configCmd = program
342
+ .command('config')
343
+ .description('Manage CLI configuration (for active profile)');
344
+
345
+ configCmd
346
+ .command('show')
347
+ .description('Show current configuration')
348
+ .action(() => {
349
+ const profileName = getCurrentProfile();
350
+ const config = loadProfile();
351
+ const namedOrgs = listNamedOrganizations();
352
+ const namedAccounts = listNamedAdAccounts();
353
+
354
+ console.log(chalk.bold(`Active Profile: ${profileName}`));
355
+ console.log();
356
+ info(`Base directory: ${getBaseConfigDir()}`);
357
+ info(`Profile directory: ${getConfigDir()}`);
358
+ info(`Exports directory: ${getExportsDir()}`);
359
+ info(`Imports directory: ${getImportsDir()}`);
360
+ console.log();
361
+ info(`Access Token: ${config.accessToken ? `${config.accessToken.substring(0, 8)}...` : chalk.gray('not set')}`);
362
+ info(`Default Organization: ${config.defaultOrganizationId || chalk.gray('not set')}`);
363
+ info(`Default Ad Account: ${config.defaultAdAccountId || chalk.gray('not set')}`);
364
+
365
+ const orgNames = Object.keys(namedOrgs);
366
+ if (orgNames.length > 0) {
367
+ console.log();
368
+ info(`Named Organizations:`);
369
+ orgNames.forEach(name => {
370
+ console.log(` ${chalk.cyan(name)}: ${namedOrgs[name]}`);
371
+ });
372
+ }
373
+
374
+ const accountNames = Object.keys(namedAccounts);
375
+ if (accountNames.length > 0) {
376
+ console.log();
377
+ info(`Named Ad Accounts:`);
378
+ accountNames.forEach(name => {
379
+ console.log(` ${chalk.cyan(name)}: ${namedAccounts[name]}`);
380
+ });
381
+ }
382
+ });
383
+
384
+ configCmd
385
+ .command('set-org <orgId>')
386
+ .description('Set default organization ID')
387
+ .action((orgId: string) => {
388
+ setDefaultOrganizationId(orgId);
389
+ success(`Default organization set: ${orgId}`);
390
+ });
391
+
392
+ configCmd
393
+ .command('set-account <accountId>')
394
+ .description('Set default ad account ID')
395
+ .action((accountId: string) => {
396
+ setDefaultAdAccountId(accountId);
397
+ success(`Default ad account set: ${accountId}`);
398
+ });
399
+
400
+ configCmd
401
+ .command('set-named-org <name> <orgId>')
402
+ .description('Set a named organization')
403
+ .action((name: string, orgId: string) => {
404
+ setNamedOrganization(name, orgId);
405
+ success(`Organization "${name}" set to: ${orgId}`);
406
+ });
407
+
408
+ configCmd
409
+ .command('set-named-account <name> <accountId>')
410
+ .description('Set a named ad account')
411
+ .action((name: string, accountId: string) => {
412
+ setNamedAdAccount(name, accountId);
413
+ success(`Ad account "${name}" set to: ${accountId}`);
414
+ });
415
+
416
+ configCmd
417
+ .command('remove-named-org <name>')
418
+ .description('Remove a named organization')
419
+ .action((name: string) => {
420
+ if (removeNamedOrganization(name)) {
421
+ success(`Named organization "${name}" removed`);
422
+ } else {
423
+ error(`Named organization "${name}" not found`);
424
+ process.exit(1);
425
+ }
426
+ });
427
+
428
+ configCmd
429
+ .command('remove-named-account <name>')
430
+ .description('Remove a named ad account')
431
+ .action((name: string) => {
432
+ if (removeNamedAdAccount(name)) {
433
+ success(`Named ad account "${name}" removed`);
434
+ } else {
435
+ error(`Named ad account "${name}" not found`);
436
+ process.exit(1);
437
+ }
438
+ });
439
+
440
+ configCmd
441
+ .command('clear')
442
+ .description('Clear configuration for active profile')
443
+ .action(() => {
444
+ clearConfig();
445
+ success(`Configuration cleared for profile: ${getCurrentProfile()}`);
446
+ });
447
+
448
+ // ============================================
449
+ // Organizations Commands
450
+ // ============================================
451
+ const orgsCmd = program
452
+ .command('orgs')
453
+ .description('Manage organizations');
454
+
455
+ orgsCmd
456
+ .command('list')
457
+ .description('List all organizations')
458
+ .action(async () => {
459
+ try {
460
+ const client = getClient();
461
+ const result = await client.organizations.list();
462
+
463
+ if (getFormat(orgsCmd) === 'json') {
464
+ print(result, 'json');
465
+ } else {
466
+ success(`Organizations (${result.length} total):`);
467
+ result.forEach(org => {
468
+ console.log(` ${chalk.bold(org.name)}`);
469
+ console.log(` ID: ${org.id}`);
470
+ console.log(` Type: ${org.type}`);
471
+ console.log();
472
+ });
473
+ }
474
+ } catch (err) {
475
+ error(String(err));
476
+ process.exit(1);
477
+ }
478
+ });
479
+
480
+ orgsCmd
481
+ .command('get [orgId]')
482
+ .description('Get organization details')
483
+ .action(async (orgId?: string) => {
484
+ try {
485
+ const client = getClient();
486
+ const id = resolveOrganizationId(orgId);
487
+ const result = await client.organizations.get(id);
488
+ print(result, getFormat(orgsCmd));
489
+ } catch (err) {
490
+ error(String(err));
491
+ process.exit(1);
492
+ }
493
+ });
494
+
495
+ // ============================================
496
+ // Accounts Commands
497
+ // ============================================
498
+ const accountsCmd = program
499
+ .command('accounts')
500
+ .description('Manage ad accounts');
501
+
502
+ accountsCmd
503
+ .command('list [orgId]')
504
+ .description('List ad accounts for an organization')
505
+ .action(async (orgId?: string) => {
506
+ try {
507
+ const client = getClient();
508
+ const id = resolveOrganizationId(orgId);
509
+ const result = await client.accounts.list(id);
510
+
511
+ if (getFormat(accountsCmd) === 'json') {
512
+ print(result, 'json');
513
+ } else {
514
+ success(`Ad Accounts (${result.length} total):`);
515
+ result.forEach(account => {
516
+ console.log(` ${chalk.bold(account.name)} (${account.status})`);
517
+ console.log(` ID: ${account.id}`);
518
+ console.log(` Type: ${account.type}`);
519
+ console.log(` Currency: ${account.currency}`);
520
+ console.log(` Timezone: ${account.timezone}`);
521
+ console.log();
522
+ });
523
+ }
524
+ } catch (err) {
525
+ error(String(err));
526
+ process.exit(1);
527
+ }
528
+ });
529
+
530
+ accountsCmd
531
+ .command('get [accountId]')
532
+ .description('Get ad account details')
533
+ .action(async (accountId?: string) => {
534
+ try {
535
+ const client = getClient();
536
+ const id = resolveAdAccountId(accountId);
537
+ const result = await client.accounts.get(id);
538
+ print(result, getFormat(accountsCmd));
539
+ } catch (err) {
540
+ error(String(err));
541
+ process.exit(1);
542
+ }
543
+ });
544
+
545
+ accountsCmd
546
+ .command('create')
547
+ .description('Create a new ad account')
548
+ .requiredOption('-n, --name <name>', 'Account name')
549
+ .requiredOption('--org <orgId>', 'Organization ID')
550
+ .requiredOption('--type <type>', 'Account type (PARTNER, BRAND, DIRECT)')
551
+ .requiredOption('--currency <currency>', 'Currency (USD, EUR, etc.)')
552
+ .requiredOption('--timezone <timezone>', 'Timezone (e.g., America/New_York)')
553
+ .option('--billing-type <type>', 'Billing type (INVOICED, PREPAID, CREDIT_CARD)')
554
+ .action(async (opts) => {
555
+ try {
556
+ const client = getClient();
557
+ const result = await client.accounts.create({
558
+ name: opts.name,
559
+ organization_id: opts.org,
560
+ type: opts.type,
561
+ currency: opts.currency,
562
+ timezone: opts.timezone,
563
+ billing_type: opts.billingType,
564
+ });
565
+ success('Ad account created!');
566
+ print(result, getFormat(accountsCmd));
567
+ } catch (err) {
568
+ error(String(err));
569
+ process.exit(1);
570
+ }
571
+ });
572
+
573
+ accountsCmd
574
+ .command('update <accountId>')
575
+ .description('Update an ad account')
576
+ .option('-n, --name <name>', 'Account name')
577
+ .option('-s, --status <status>', 'Status (ACTIVE, PAUSED)')
578
+ .action(async (accountId: string, opts) => {
579
+ try {
580
+ const client = getClient();
581
+ const result = await client.accounts.update(accountId, {
582
+ name: opts.name,
583
+ status: opts.status,
584
+ });
585
+ success('Ad account updated!');
586
+ print(result, getFormat(accountsCmd));
587
+ } catch (err) {
588
+ error(String(err));
589
+ process.exit(1);
590
+ }
591
+ });
592
+
593
+ // ============================================
594
+ // Campaigns Commands
595
+ // ============================================
596
+ const campaignsCmd = program
597
+ .command('campaigns')
598
+ .description('Manage campaigns');
599
+
600
+ campaignsCmd
601
+ .command('list [accountId]')
602
+ .description('List campaigns for an ad account')
603
+ .action(async (accountId?: string) => {
604
+ try {
605
+ const client = getClient();
606
+ const id = resolveAdAccountId(accountId);
607
+ const result = await client.campaigns.list(id);
608
+
609
+ if (getFormat(campaignsCmd) === 'json') {
610
+ print(result, 'json');
611
+ } else {
612
+ success(`Campaigns (${result.length} total):`);
613
+ result.forEach(campaign => {
614
+ const status = campaign.status === 'ACTIVE' ? chalk.green(campaign.status) : chalk.yellow(campaign.status);
615
+ console.log(` ${chalk.bold(campaign.name)} (${status})`);
616
+ console.log(` ID: ${campaign.id}`);
617
+ console.log(` Objective: ${campaign.objective}`);
618
+ if (campaign.daily_budget_micro) {
619
+ console.log(` Daily Budget: ${formatMicroCurrency(campaign.daily_budget_micro)}`);
620
+ }
621
+ console.log();
622
+ });
623
+ }
624
+ } catch (err) {
625
+ error(String(err));
626
+ process.exit(1);
627
+ }
628
+ });
629
+
630
+ campaignsCmd
631
+ .command('get <campaignId>')
632
+ .description('Get campaign details')
633
+ .action(async (campaignId: string) => {
634
+ try {
635
+ const client = getClient();
636
+ const result = await client.campaigns.get(campaignId);
637
+ print(result, getFormat(campaignsCmd));
638
+ } catch (err) {
639
+ error(String(err));
640
+ process.exit(1);
641
+ }
642
+ });
643
+
644
+ campaignsCmd
645
+ .command('create')
646
+ .description('Create a new campaign')
647
+ .requiredOption('-n, --name <name>', 'Campaign name')
648
+ .option('-a, --account <accountId>', 'Ad account ID')
649
+ .requiredOption('-o, --objective <objective>', 'Objective (AWARENESS, CONSIDERATION, CONVERSIONS, etc.)')
650
+ .option('-s, --status <status>', 'Status (ACTIVE, PAUSED)', 'PAUSED')
651
+ .option('--daily-budget <amount>', 'Daily budget in dollars')
652
+ .option('--start-time <time>', 'Start time (ISO 8601)')
653
+ .option('--end-time <time>', 'End time (ISO 8601)')
654
+ .action(async (opts) => {
655
+ try {
656
+ const client = getClient();
657
+ const accountId = resolveAdAccountId(opts.account);
658
+ const result = await client.campaigns.create({
659
+ name: opts.name,
660
+ ad_account_id: accountId,
661
+ objective: opts.objective,
662
+ status: opts.status,
663
+ daily_budget_micro: opts.dailyBudget ? parseFloat(opts.dailyBudget) * 1_000_000 : undefined,
664
+ start_time: opts.startTime,
665
+ end_time: opts.endTime,
666
+ });
667
+ success('Campaign created!');
668
+ print(result, getFormat(campaignsCmd));
669
+ } catch (err) {
670
+ error(String(err));
671
+ process.exit(1);
672
+ }
673
+ });
674
+
675
+ campaignsCmd
676
+ .command('update <campaignId>')
677
+ .description('Update a campaign')
678
+ .option('-n, --name <name>', 'Campaign name')
679
+ .option('-s, --status <status>', 'Status (ACTIVE, PAUSED)')
680
+ .option('--daily-budget <amount>', 'Daily budget in dollars')
681
+ .option('--start-time <time>', 'Start time (ISO 8601)')
682
+ .option('--end-time <time>', 'End time (ISO 8601)')
683
+ .action(async (campaignId: string, opts) => {
684
+ try {
685
+ const client = getClient();
686
+ const result = await client.campaigns.update(campaignId, {
687
+ name: opts.name,
688
+ status: opts.status,
689
+ daily_budget_micro: opts.dailyBudget ? parseFloat(opts.dailyBudget) * 1_000_000 : undefined,
690
+ start_time: opts.startTime,
691
+ end_time: opts.endTime,
692
+ });
693
+ success('Campaign updated!');
694
+ print(result, getFormat(campaignsCmd));
695
+ } catch (err) {
696
+ error(String(err));
697
+ process.exit(1);
698
+ }
699
+ });
700
+
701
+ campaignsCmd
702
+ .command('pause <campaignId>')
703
+ .description('Pause a campaign')
704
+ .action(async (campaignId: string) => {
705
+ try {
706
+ const client = getClient();
707
+ await client.campaigns.pause(campaignId);
708
+ success('Campaign paused');
709
+ } catch (err) {
710
+ error(String(err));
711
+ process.exit(1);
712
+ }
713
+ });
714
+
715
+ campaignsCmd
716
+ .command('activate <campaignId>')
717
+ .description('Activate a campaign')
718
+ .action(async (campaignId: string) => {
719
+ try {
720
+ const client = getClient();
721
+ await client.campaigns.activate(campaignId);
722
+ success('Campaign activated');
723
+ } catch (err) {
724
+ error(String(err));
725
+ process.exit(1);
726
+ }
727
+ });
728
+
729
+ campaignsCmd
730
+ .command('delete <campaignId>')
731
+ .description('Delete a campaign')
732
+ .action(async (campaignId: string) => {
733
+ try {
734
+ const client = getClient();
735
+ await client.campaigns.delete(campaignId);
736
+ success('Campaign deleted');
737
+ } catch (err) {
738
+ error(String(err));
739
+ process.exit(1);
740
+ }
741
+ });
742
+
743
+ // ============================================
744
+ // Ad Squads Commands
745
+ // ============================================
746
+ const adsquadsCmd = program
747
+ .command('adsquads')
748
+ .description('Manage ad squads');
749
+
750
+ adsquadsCmd
751
+ .command('list')
752
+ .description('List ad squads')
753
+ .option('-a, --account <accountId>', 'Ad account ID')
754
+ .option('-c, --campaign <campaignId>', 'Campaign ID')
755
+ .action(async (opts) => {
756
+ try {
757
+ const client = getClient();
758
+ let result;
759
+
760
+ if (opts.campaign) {
761
+ result = await client.adSquads.listByCampaign(opts.campaign);
762
+ } else {
763
+ const accountId = resolveAdAccountId(opts.account);
764
+ result = await client.adSquads.listByAccount(accountId);
765
+ }
766
+
767
+ if (getFormat(adsquadsCmd) === 'json') {
768
+ print(result, 'json');
769
+ } else {
770
+ success(`Ad Squads (${result.length} total):`);
771
+ result.forEach(adSquad => {
772
+ const status = adSquad.status === 'ACTIVE' ? chalk.green(adSquad.status) : chalk.yellow(adSquad.status);
773
+ console.log(` ${chalk.bold(adSquad.name)} (${status})`);
774
+ console.log(` ID: ${adSquad.id}`);
775
+ console.log(` Type: ${adSquad.type}`);
776
+ console.log(` Optimization: ${adSquad.optimization_goal}`);
777
+ if (adSquad.bid_micro) {
778
+ console.log(` Bid: ${formatMicroCurrency(adSquad.bid_micro)}`);
779
+ }
780
+ console.log();
781
+ });
782
+ }
783
+ } catch (err) {
784
+ error(String(err));
785
+ process.exit(1);
786
+ }
787
+ });
788
+
789
+ adsquadsCmd
790
+ .command('get <adSquadId>')
791
+ .description('Get ad squad details')
792
+ .action(async (adSquadId: string) => {
793
+ try {
794
+ const client = getClient();
795
+ const result = await client.adSquads.get(adSquadId);
796
+ print(result, getFormat(adsquadsCmd));
797
+ } catch (err) {
798
+ error(String(err));
799
+ process.exit(1);
800
+ }
801
+ });
802
+
803
+ adsquadsCmd
804
+ .command('create')
805
+ .description('Create a new ad squad')
806
+ .requiredOption('-n, --name <name>', 'Ad squad name')
807
+ .requiredOption('-c, --campaign <campaignId>', 'Campaign ID')
808
+ .requiredOption('--type <type>', 'Type (SNAP_ADS, STORY_ADS, LENS, FILTER)')
809
+ .requiredOption('--billing-event <event>', 'Billing event (IMPRESSION, SWIPE_UP, etc.)')
810
+ .requiredOption('--optimization-goal <goal>', 'Optimization goal')
811
+ .option('-s, --status <status>', 'Status (ACTIVE, PAUSED)', 'PAUSED')
812
+ .option('--bid <amount>', 'Bid amount in dollars')
813
+ .option('--auto-bid', 'Use auto bidding')
814
+ .option('--daily-budget <amount>', 'Daily budget in dollars')
815
+ .option('--start-time <time>', 'Start time (ISO 8601)')
816
+ .option('--end-time <time>', 'End time (ISO 8601)')
817
+ .action(async (opts) => {
818
+ try {
819
+ const client = getClient();
820
+ const result = await client.adSquads.create({
821
+ name: opts.name,
822
+ campaign_id: opts.campaign,
823
+ type: opts.type,
824
+ billing_event: opts.billingEvent,
825
+ optimization_goal: opts.optimizationGoal,
826
+ status: opts.status,
827
+ bid_micro: opts.bid ? parseFloat(opts.bid) * 1_000_000 : undefined,
828
+ auto_bid: opts.autoBid,
829
+ daily_budget_micro: opts.dailyBudget ? parseFloat(opts.dailyBudget) * 1_000_000 : undefined,
830
+ start_time: opts.startTime,
831
+ end_time: opts.endTime,
832
+ });
833
+ success('Ad squad created!');
834
+ print(result, getFormat(adsquadsCmd));
835
+ } catch (err) {
836
+ error(String(err));
837
+ process.exit(1);
838
+ }
839
+ });
840
+
841
+ adsquadsCmd
842
+ .command('update <adSquadId>')
843
+ .description('Update an ad squad')
844
+ .option('-n, --name <name>', 'Ad squad name')
845
+ .option('-s, --status <status>', 'Status (ACTIVE, PAUSED)')
846
+ .option('--bid <amount>', 'Bid amount in dollars')
847
+ .option('--auto-bid', 'Use auto bidding')
848
+ .option('--daily-budget <amount>', 'Daily budget in dollars')
849
+ .action(async (adSquadId: string, opts) => {
850
+ try {
851
+ const client = getClient();
852
+ const result = await client.adSquads.update(adSquadId, {
853
+ name: opts.name,
854
+ status: opts.status,
855
+ bid_micro: opts.bid ? parseFloat(opts.bid) * 1_000_000 : undefined,
856
+ auto_bid: opts.autoBid,
857
+ daily_budget_micro: opts.dailyBudget ? parseFloat(opts.dailyBudget) * 1_000_000 : undefined,
858
+ });
859
+ success('Ad squad updated!');
860
+ print(result, getFormat(adsquadsCmd));
861
+ } catch (err) {
862
+ error(String(err));
863
+ process.exit(1);
864
+ }
865
+ });
866
+
867
+ adsquadsCmd
868
+ .command('pause <adSquadId>')
869
+ .description('Pause an ad squad')
870
+ .action(async (adSquadId: string) => {
871
+ try {
872
+ const client = getClient();
873
+ await client.adSquads.pause(adSquadId);
874
+ success('Ad squad paused');
875
+ } catch (err) {
876
+ error(String(err));
877
+ process.exit(1);
878
+ }
879
+ });
880
+
881
+ adsquadsCmd
882
+ .command('activate <adSquadId>')
883
+ .description('Activate an ad squad')
884
+ .action(async (adSquadId: string) => {
885
+ try {
886
+ const client = getClient();
887
+ await client.adSquads.activate(adSquadId);
888
+ success('Ad squad activated');
889
+ } catch (err) {
890
+ error(String(err));
891
+ process.exit(1);
892
+ }
893
+ });
894
+
895
+ adsquadsCmd
896
+ .command('delete <adSquadId>')
897
+ .description('Delete an ad squad')
898
+ .action(async (adSquadId: string) => {
899
+ try {
900
+ const client = getClient();
901
+ await client.adSquads.delete(adSquadId);
902
+ success('Ad squad deleted');
903
+ } catch (err) {
904
+ error(String(err));
905
+ process.exit(1);
906
+ }
907
+ });
908
+
909
+ // ============================================
910
+ // Ads Commands
911
+ // ============================================
912
+ const adsCmd = program
913
+ .command('ads')
914
+ .description('Manage ads');
915
+
916
+ adsCmd
917
+ .command('list')
918
+ .description('List ads')
919
+ .option('-a, --account <accountId>', 'Ad account ID')
920
+ .option('-s, --adsquad <adSquadId>', 'Ad squad ID')
921
+ .action(async (opts) => {
922
+ try {
923
+ const client = getClient();
924
+ let result;
925
+
926
+ if (opts.adsquad) {
927
+ result = await client.ads.listByAdSquad(opts.adsquad);
928
+ } else {
929
+ const accountId = resolveAdAccountId(opts.account);
930
+ result = await client.ads.listByAccount(accountId);
931
+ }
932
+
933
+ if (getFormat(adsCmd) === 'json') {
934
+ print(result, 'json');
935
+ } else {
936
+ success(`Ads (${result.length} total):`);
937
+ result.forEach(ad => {
938
+ const status = ad.status === 'ACTIVE' ? chalk.green(ad.status) : chalk.yellow(ad.status);
939
+ const review = ad.review_status === 'APPROVED' ? chalk.green(ad.review_status) : chalk.yellow(ad.review_status);
940
+ console.log(` ${chalk.bold(ad.name)} (${status})`);
941
+ console.log(` ID: ${ad.id}`);
942
+ console.log(` Type: ${ad.type}`);
943
+ console.log(` Review: ${review}`);
944
+ console.log();
945
+ });
946
+ }
947
+ } catch (err) {
948
+ error(String(err));
949
+ process.exit(1);
950
+ }
951
+ });
952
+
953
+ adsCmd
954
+ .command('get <adId>')
955
+ .description('Get ad details')
956
+ .action(async (adId: string) => {
957
+ try {
958
+ const client = getClient();
959
+ const result = await client.ads.get(adId);
960
+ print(result, getFormat(adsCmd));
961
+ } catch (err) {
962
+ error(String(err));
963
+ process.exit(1);
964
+ }
965
+ });
966
+
967
+ adsCmd
968
+ .command('create')
969
+ .description('Create a new ad')
970
+ .requiredOption('-n, --name <name>', 'Ad name')
971
+ .requiredOption('-s, --adsquad <adSquadId>', 'Ad squad ID')
972
+ .requiredOption('-c, --creative <creativeId>', 'Creative ID')
973
+ .option('--status <status>', 'Status (ACTIVE, PAUSED)', 'PAUSED')
974
+ .action(async (opts) => {
975
+ try {
976
+ const client = getClient();
977
+ const result = await client.ads.create({
978
+ name: opts.name,
979
+ ad_squad_id: opts.adsquad,
980
+ creative_id: opts.creative,
981
+ status: opts.status,
982
+ });
983
+ success('Ad created!');
984
+ print(result, getFormat(adsCmd));
985
+ } catch (err) {
986
+ error(String(err));
987
+ process.exit(1);
988
+ }
989
+ });
990
+
991
+ adsCmd
992
+ .command('update <adId>')
993
+ .description('Update an ad')
994
+ .option('-n, --name <name>', 'Ad name')
995
+ .option('-s, --status <status>', 'Status (ACTIVE, PAUSED)')
996
+ .option('-c, --creative <creativeId>', 'Creative ID')
997
+ .action(async (adId: string, opts) => {
998
+ try {
999
+ const client = getClient();
1000
+ const result = await client.ads.update(adId, {
1001
+ name: opts.name,
1002
+ status: opts.status,
1003
+ creative_id: opts.creative,
1004
+ });
1005
+ success('Ad updated!');
1006
+ print(result, getFormat(adsCmd));
1007
+ } catch (err) {
1008
+ error(String(err));
1009
+ process.exit(1);
1010
+ }
1011
+ });
1012
+
1013
+ adsCmd
1014
+ .command('pause <adId>')
1015
+ .description('Pause an ad')
1016
+ .action(async (adId: string) => {
1017
+ try {
1018
+ const client = getClient();
1019
+ await client.ads.pause(adId);
1020
+ success('Ad paused');
1021
+ } catch (err) {
1022
+ error(String(err));
1023
+ process.exit(1);
1024
+ }
1025
+ });
1026
+
1027
+ adsCmd
1028
+ .command('activate <adId>')
1029
+ .description('Activate an ad')
1030
+ .action(async (adId: string) => {
1031
+ try {
1032
+ const client = getClient();
1033
+ await client.ads.activate(adId);
1034
+ success('Ad activated');
1035
+ } catch (err) {
1036
+ error(String(err));
1037
+ process.exit(1);
1038
+ }
1039
+ });
1040
+
1041
+ adsCmd
1042
+ .command('delete <adId>')
1043
+ .description('Delete an ad')
1044
+ .action(async (adId: string) => {
1045
+ try {
1046
+ const client = getClient();
1047
+ await client.ads.delete(adId);
1048
+ success('Ad deleted');
1049
+ } catch (err) {
1050
+ error(String(err));
1051
+ process.exit(1);
1052
+ }
1053
+ });
1054
+
1055
+ // ============================================
1056
+ // Creatives Commands
1057
+ // ============================================
1058
+ const creativesCmd = program
1059
+ .command('creatives')
1060
+ .description('Manage creatives');
1061
+
1062
+ creativesCmd
1063
+ .command('list [accountId]')
1064
+ .description('List creatives for an ad account')
1065
+ .action(async (accountId?: string) => {
1066
+ try {
1067
+ const client = getClient();
1068
+ const id = resolveAdAccountId(accountId);
1069
+ const result = await client.creatives.list(id);
1070
+
1071
+ if (getFormat(creativesCmd) === 'json') {
1072
+ print(result, 'json');
1073
+ } else {
1074
+ success(`Creatives (${result.length} total):`);
1075
+ result.forEach(creative => {
1076
+ console.log(` ${chalk.bold(creative.name)}`);
1077
+ console.log(` ID: ${creative.id}`);
1078
+ console.log(` Type: ${creative.type}`);
1079
+ if (creative.headline) console.log(` Headline: ${creative.headline}`);
1080
+ console.log();
1081
+ });
1082
+ }
1083
+ } catch (err) {
1084
+ error(String(err));
1085
+ process.exit(1);
1086
+ }
1087
+ });
1088
+
1089
+ creativesCmd
1090
+ .command('get <creativeId>')
1091
+ .description('Get creative details')
1092
+ .action(async (creativeId: string) => {
1093
+ try {
1094
+ const client = getClient();
1095
+ const result = await client.creatives.get(creativeId);
1096
+ print(result, getFormat(creativesCmd));
1097
+ } catch (err) {
1098
+ error(String(err));
1099
+ process.exit(1);
1100
+ }
1101
+ });
1102
+
1103
+ creativesCmd
1104
+ .command('create')
1105
+ .description('Create a new creative')
1106
+ .requiredOption('-n, --name <name>', 'Creative name')
1107
+ .option('-a, --account <accountId>', 'Ad account ID')
1108
+ .requiredOption('--type <type>', 'Type (SNAP_AD, WEB_VIEW, APP_INSTALL, etc.)')
1109
+ .requiredOption('--media <mediaId>', 'Top snap media ID')
1110
+ .option('--headline <headline>', 'Headline text')
1111
+ .option('--brand <brandName>', 'Brand name')
1112
+ .option('--cta <callToAction>', 'Call to action (LEARN_MORE, SHOP_NOW, etc.)')
1113
+ .option('--url <url>', 'Web view URL (for WEB_VIEW type)')
1114
+ .action(async (opts) => {
1115
+ try {
1116
+ const client = getClient();
1117
+ const accountId = resolveAdAccountId(opts.account);
1118
+ const result = await client.creatives.create({
1119
+ name: opts.name,
1120
+ ad_account_id: accountId,
1121
+ type: opts.type,
1122
+ top_snap_media_id: opts.media,
1123
+ headline: opts.headline,
1124
+ brand_name: opts.brand,
1125
+ call_to_action: opts.cta,
1126
+ web_view_properties: opts.url ? { url: opts.url } : undefined,
1127
+ });
1128
+ success('Creative created!');
1129
+ print(result, getFormat(creativesCmd));
1130
+ } catch (err) {
1131
+ error(String(err));
1132
+ process.exit(1);
1133
+ }
1134
+ });
1135
+
1136
+ creativesCmd
1137
+ .command('update <creativeId>')
1138
+ .description('Update a creative')
1139
+ .option('-n, --name <name>', 'Creative name')
1140
+ .option('--headline <headline>', 'Headline text')
1141
+ .option('--brand <brandName>', 'Brand name')
1142
+ .option('--cta <callToAction>', 'Call to action')
1143
+ .action(async (creativeId: string, opts) => {
1144
+ try {
1145
+ const client = getClient();
1146
+ const result = await client.creatives.update(creativeId, {
1147
+ name: opts.name,
1148
+ headline: opts.headline,
1149
+ brand_name: opts.brand,
1150
+ call_to_action: opts.cta,
1151
+ });
1152
+ success('Creative updated!');
1153
+ print(result, getFormat(creativesCmd));
1154
+ } catch (err) {
1155
+ error(String(err));
1156
+ process.exit(1);
1157
+ }
1158
+ });
1159
+
1160
+ creativesCmd
1161
+ .command('delete <creativeId>')
1162
+ .description('Delete a creative')
1163
+ .action(async (creativeId: string) => {
1164
+ try {
1165
+ const client = getClient();
1166
+ await client.creatives.delete(creativeId);
1167
+ success('Creative deleted');
1168
+ } catch (err) {
1169
+ error(String(err));
1170
+ process.exit(1);
1171
+ }
1172
+ });
1173
+
1174
+ // ============================================
1175
+ // Media Commands
1176
+ // ============================================
1177
+ const mediaCmd = program
1178
+ .command('media')
1179
+ .description('Manage media');
1180
+
1181
+ mediaCmd
1182
+ .command('list [accountId]')
1183
+ .description('List media for an ad account')
1184
+ .action(async (accountId?: string) => {
1185
+ try {
1186
+ const client = getClient();
1187
+ const id = resolveAdAccountId(accountId);
1188
+ const result = await client.media.list(id);
1189
+
1190
+ if (getFormat(mediaCmd) === 'json') {
1191
+ print(result, 'json');
1192
+ } else {
1193
+ success(`Media (${result.length} total):`);
1194
+ result.forEach(media => {
1195
+ console.log(` ${chalk.bold(media.name || media.id)}`);
1196
+ console.log(` ID: ${media.id}`);
1197
+ console.log(` Type: ${media.type}`);
1198
+ console.log(` Status: ${media.media_status}`);
1199
+ console.log();
1200
+ });
1201
+ }
1202
+ } catch (err) {
1203
+ error(String(err));
1204
+ process.exit(1);
1205
+ }
1206
+ });
1207
+
1208
+ mediaCmd
1209
+ .command('get <mediaId>')
1210
+ .description('Get media details')
1211
+ .action(async (mediaId: string) => {
1212
+ try {
1213
+ const client = getClient();
1214
+ const result = await client.media.get(mediaId);
1215
+ print(result, getFormat(mediaCmd));
1216
+ } catch (err) {
1217
+ error(String(err));
1218
+ process.exit(1);
1219
+ }
1220
+ });
1221
+
1222
+ mediaCmd
1223
+ .command('upload <filePath>')
1224
+ .description('Upload media file')
1225
+ .option('-a, --account <accountId>', 'Ad account ID')
1226
+ .requiredOption('--type <type>', 'Media type (VIDEO, IMAGE)')
1227
+ .option('-n, --name <name>', 'Media name')
1228
+ .action(async (filePath: string, opts) => {
1229
+ try {
1230
+ const client = getClient();
1231
+ const accountId = resolveAdAccountId(opts.account);
1232
+ info(`Uploading ${filePath}...`);
1233
+ const result = await client.media.uploadFile(accountId, filePath, opts.type, opts.name);
1234
+ success('Media uploaded!');
1235
+ print(result, getFormat(mediaCmd));
1236
+ } catch (err) {
1237
+ error(String(err));
1238
+ process.exit(1);
1239
+ }
1240
+ });
1241
+
1242
+ mediaCmd
1243
+ .command('status <mediaId>')
1244
+ .description('Check media processing status')
1245
+ .action(async (mediaId: string) => {
1246
+ try {
1247
+ const client = getClient();
1248
+ const result = await client.media.checkStatus(mediaId);
1249
+ if (result.ready) {
1250
+ success(`Media is ready (${result.status})`);
1251
+ } else {
1252
+ info(`Media status: ${result.status}`);
1253
+ }
1254
+ } catch (err) {
1255
+ error(String(err));
1256
+ process.exit(1);
1257
+ }
1258
+ });
1259
+
1260
+ mediaCmd
1261
+ .command('delete <mediaId>')
1262
+ .description('Delete media')
1263
+ .action(async (mediaId: string) => {
1264
+ try {
1265
+ const client = getClient();
1266
+ await client.media.delete(mediaId);
1267
+ success('Media deleted');
1268
+ } catch (err) {
1269
+ error(String(err));
1270
+ process.exit(1);
1271
+ }
1272
+ });
1273
+
1274
+ // ============================================
1275
+ // Audiences Commands
1276
+ // ============================================
1277
+ const audiencesCmd = program
1278
+ .command('audiences')
1279
+ .description('Manage audiences/segments');
1280
+
1281
+ audiencesCmd
1282
+ .command('list [accountId]')
1283
+ .description('List audiences for an ad account')
1284
+ .action(async (accountId?: string) => {
1285
+ try {
1286
+ const client = getClient();
1287
+ const id = resolveAdAccountId(accountId);
1288
+ const result = await client.audiences.list(id);
1289
+
1290
+ if (getFormat(audiencesCmd) === 'json') {
1291
+ print(result, 'json');
1292
+ } else {
1293
+ success(`Audiences (${result.length} total):`);
1294
+ result.forEach(segment => {
1295
+ console.log(` ${chalk.bold(segment.name)} (${segment.status})`);
1296
+ console.log(` ID: ${segment.id}`);
1297
+ console.log(` Type: ${segment.source_type}`);
1298
+ if (segment.approximate_count) {
1299
+ console.log(` Size: ~${segment.approximate_count.toLocaleString()}`);
1300
+ }
1301
+ console.log();
1302
+ });
1303
+ }
1304
+ } catch (err) {
1305
+ error(String(err));
1306
+ process.exit(1);
1307
+ }
1308
+ });
1309
+
1310
+ audiencesCmd
1311
+ .command('get <segmentId>')
1312
+ .description('Get audience details')
1313
+ .action(async (segmentId: string) => {
1314
+ try {
1315
+ const client = getClient();
1316
+ const result = await client.audiences.get(segmentId);
1317
+ print(result, getFormat(audiencesCmd));
1318
+ } catch (err) {
1319
+ error(String(err));
1320
+ process.exit(1);
1321
+ }
1322
+ });
1323
+
1324
+ audiencesCmd
1325
+ .command('create')
1326
+ .description('Create a new audience')
1327
+ .requiredOption('-n, --name <name>', 'Audience name')
1328
+ .option('-a, --account <accountId>', 'Ad account ID')
1329
+ .requiredOption('--source <source>', 'Source type (FIRST_PARTY, PIXEL, ENGAGEMENT, EMAIL, PHONE, MOBILE_AD_ID)')
1330
+ .option('--description <description>', 'Description')
1331
+ .option('--retention <days>', 'Retention in days')
1332
+ .action(async (opts) => {
1333
+ try {
1334
+ const client = getClient();
1335
+ const accountId = resolveAdAccountId(opts.account);
1336
+ const result = await client.audiences.create({
1337
+ name: opts.name,
1338
+ ad_account_id: accountId,
1339
+ source_type: opts.source,
1340
+ description: opts.description,
1341
+ retention_in_days: opts.retention ? parseInt(opts.retention) as 1 | 3 | 5 | 7 | 10 | 14 | 21 | 28 | 30 | 60 | 90 | 120 | 180 | 365 | 9999 : undefined,
1342
+ });
1343
+ success('Audience created!');
1344
+ print(result, getFormat(audiencesCmd));
1345
+ } catch (err) {
1346
+ error(String(err));
1347
+ process.exit(1);
1348
+ }
1349
+ });
1350
+
1351
+ audiencesCmd
1352
+ .command('update <segmentId>')
1353
+ .description('Update an audience')
1354
+ .option('-n, --name <name>', 'Audience name')
1355
+ .option('--description <description>', 'Description')
1356
+ .action(async (segmentId: string, opts) => {
1357
+ try {
1358
+ const client = getClient();
1359
+ const result = await client.audiences.update(segmentId, {
1360
+ name: opts.name,
1361
+ description: opts.description,
1362
+ });
1363
+ success('Audience updated!');
1364
+ print(result, getFormat(audiencesCmd));
1365
+ } catch (err) {
1366
+ error(String(err));
1367
+ process.exit(1);
1368
+ }
1369
+ });
1370
+
1371
+ audiencesCmd
1372
+ .command('delete <segmentId>')
1373
+ .description('Delete an audience')
1374
+ .action(async (segmentId: string) => {
1375
+ try {
1376
+ const client = getClient();
1377
+ await client.audiences.delete(segmentId);
1378
+ success('Audience deleted');
1379
+ } catch (err) {
1380
+ error(String(err));
1381
+ process.exit(1);
1382
+ }
1383
+ });
1384
+
1385
+ audiencesCmd
1386
+ .command('create-lookalike')
1387
+ .description('Create a lookalike audience')
1388
+ .requiredOption('-n, --name <name>', 'Audience name')
1389
+ .option('-a, --account <accountId>', 'Ad account ID')
1390
+ .requiredOption('--seed <segmentId>', 'Seed segment ID')
1391
+ .requiredOption('--country <country>', 'Country code')
1392
+ .option('--type <type>', 'Type (BALANCE, REACH, SIMILARITY)', 'BALANCE')
1393
+ .action(async (opts) => {
1394
+ try {
1395
+ const client = getClient();
1396
+ const accountId = resolveAdAccountId(opts.account);
1397
+ const result = await client.audiences.createLookalike({
1398
+ name: opts.name,
1399
+ ad_account_id: accountId,
1400
+ seed_segment_id: opts.seed,
1401
+ country: opts.country,
1402
+ type: opts.type,
1403
+ });
1404
+ success('Lookalike audience created!');
1405
+ print(result, getFormat(audiencesCmd));
1406
+ } catch (err) {
1407
+ error(String(err));
1408
+ process.exit(1);
1409
+ }
1410
+ });
1411
+
1412
+ // ============================================
1413
+ // Stats Commands
1414
+ // ============================================
1415
+ const statsCmd = program
1416
+ .command('stats')
1417
+ .description('Get performance stats');
1418
+
1419
+ statsCmd
1420
+ .command('account [accountId]')
1421
+ .description('Get ad account stats')
1422
+ .requiredOption('--start <date>', 'Start date (ISO 8601)')
1423
+ .requiredOption('--end <date>', 'End date (ISO 8601)')
1424
+ .option('--granularity <granularity>', 'Granularity (HOUR, DAY, WEEK, MONTH, TOTAL)', 'DAY')
1425
+ .action(async (accountId: string | undefined, opts) => {
1426
+ try {
1427
+ const client = getClient();
1428
+ const id = resolveAdAccountId(accountId);
1429
+ const result = await client.stats.getAccountStats(id, {
1430
+ start_time: opts.start,
1431
+ end_time: opts.end,
1432
+ granularity: opts.granularity,
1433
+ });
1434
+ print(result, getFormat(statsCmd));
1435
+ } catch (err) {
1436
+ error(String(err));
1437
+ process.exit(1);
1438
+ }
1439
+ });
1440
+
1441
+ statsCmd
1442
+ .command('campaign <campaignId>')
1443
+ .description('Get campaign stats')
1444
+ .requiredOption('--start <date>', 'Start date (ISO 8601)')
1445
+ .requiredOption('--end <date>', 'End date (ISO 8601)')
1446
+ .option('--granularity <granularity>', 'Granularity (HOUR, DAY, WEEK, MONTH, TOTAL)', 'DAY')
1447
+ .action(async (campaignId: string, opts) => {
1448
+ try {
1449
+ const client = getClient();
1450
+ const result = await client.stats.getCampaignStats(campaignId, {
1451
+ start_time: opts.start,
1452
+ end_time: opts.end,
1453
+ granularity: opts.granularity,
1454
+ });
1455
+ print(result, getFormat(statsCmd));
1456
+ } catch (err) {
1457
+ error(String(err));
1458
+ process.exit(1);
1459
+ }
1460
+ });
1461
+
1462
+ statsCmd
1463
+ .command('adsquad <adSquadId>')
1464
+ .description('Get ad squad stats')
1465
+ .requiredOption('--start <date>', 'Start date (ISO 8601)')
1466
+ .requiredOption('--end <date>', 'End date (ISO 8601)')
1467
+ .option('--granularity <granularity>', 'Granularity (HOUR, DAY, WEEK, MONTH, TOTAL)', 'DAY')
1468
+ .action(async (adSquadId: string, opts) => {
1469
+ try {
1470
+ const client = getClient();
1471
+ const result = await client.stats.getAdSquadStats(adSquadId, {
1472
+ start_time: opts.start,
1473
+ end_time: opts.end,
1474
+ granularity: opts.granularity,
1475
+ });
1476
+ print(result, getFormat(statsCmd));
1477
+ } catch (err) {
1478
+ error(String(err));
1479
+ process.exit(1);
1480
+ }
1481
+ });
1482
+
1483
+ statsCmd
1484
+ .command('ad <adId>')
1485
+ .description('Get ad stats')
1486
+ .requiredOption('--start <date>', 'Start date (ISO 8601)')
1487
+ .requiredOption('--end <date>', 'End date (ISO 8601)')
1488
+ .option('--granularity <granularity>', 'Granularity (HOUR, DAY, WEEK, MONTH, TOTAL)', 'DAY')
1489
+ .action(async (adId: string, opts) => {
1490
+ try {
1491
+ const client = getClient();
1492
+ const result = await client.stats.getAdStats(adId, {
1493
+ start_time: opts.start,
1494
+ end_time: opts.end,
1495
+ granularity: opts.granularity,
1496
+ });
1497
+ print(result, getFormat(statsCmd));
1498
+ } catch (err) {
1499
+ error(String(err));
1500
+ process.exit(1);
1501
+ }
1502
+ });
1503
+
1504
+ // ============================================
1505
+ // Pixels Commands
1506
+ // ============================================
1507
+ const pixelsCmd = program
1508
+ .command('pixels')
1509
+ .description('Manage Snap Pixels');
1510
+
1511
+ pixelsCmd
1512
+ .command('list [accountId]')
1513
+ .description('List pixels for an ad account')
1514
+ .action(async (accountId?: string) => {
1515
+ try {
1516
+ const client = getClient();
1517
+ const id = resolveAdAccountId(accountId);
1518
+ const result = await client.pixels.list(id);
1519
+
1520
+ if (getFormat(pixelsCmd) === 'json') {
1521
+ print(result, 'json');
1522
+ } else {
1523
+ success(`Pixels (${result.length} total):`);
1524
+ result.forEach(pixel => {
1525
+ const status = pixel.status === 'ACTIVE' ? chalk.green(pixel.status) : chalk.yellow(pixel.status);
1526
+ console.log(` ${chalk.bold(pixel.name)} (${status})`);
1527
+ console.log(` ID: ${pixel.id}`);
1528
+ console.log();
1529
+ });
1530
+ }
1531
+ } catch (err) {
1532
+ error(String(err));
1533
+ process.exit(1);
1534
+ }
1535
+ });
1536
+
1537
+ pixelsCmd
1538
+ .command('get <pixelId>')
1539
+ .description('Get pixel details')
1540
+ .action(async (pixelId: string) => {
1541
+ try {
1542
+ const client = getClient();
1543
+ const result = await client.pixels.get(pixelId);
1544
+ print(result, getFormat(pixelsCmd));
1545
+ } catch (err) {
1546
+ error(String(err));
1547
+ process.exit(1);
1548
+ }
1549
+ });
1550
+
1551
+ pixelsCmd
1552
+ .command('create')
1553
+ .description('Create a new pixel')
1554
+ .requiredOption('-n, --name <name>', 'Pixel name')
1555
+ .option('-a, --account <accountId>', 'Ad account ID')
1556
+ .action(async (opts) => {
1557
+ try {
1558
+ const client = getClient();
1559
+ const accountId = resolveAdAccountId(opts.account);
1560
+ const result = await client.pixels.create({
1561
+ name: opts.name,
1562
+ ad_account_id: accountId,
1563
+ });
1564
+ success('Pixel created!');
1565
+ print(result, getFormat(pixelsCmd));
1566
+ } catch (err) {
1567
+ error(String(err));
1568
+ process.exit(1);
1569
+ }
1570
+ });
1571
+
1572
+ pixelsCmd
1573
+ .command('code <pixelId>')
1574
+ .description('Get pixel JavaScript code')
1575
+ .action(async (pixelId: string) => {
1576
+ try {
1577
+ const client = getClient();
1578
+ const code = client.pixels.generateBaseCode(pixelId);
1579
+ console.log(code);
1580
+ } catch (err) {
1581
+ error(String(err));
1582
+ process.exit(1);
1583
+ }
1584
+ });
1585
+
1586
+ pixelsCmd
1587
+ .command('delete <pixelId>')
1588
+ .description('Delete a pixel')
1589
+ .action(async (pixelId: string) => {
1590
+ try {
1591
+ const client = getClient();
1592
+ await client.pixels.delete(pixelId);
1593
+ success('Pixel deleted');
1594
+ } catch (err) {
1595
+ error(String(err));
1596
+ process.exit(1);
1597
+ }
1598
+ });
1599
+
1600
+ // ============================================
1601
+ // Catalogs Commands
1602
+ // ============================================
1603
+ const catalogsCmd = program
1604
+ .command('catalogs')
1605
+ .description('Manage product catalogs');
1606
+
1607
+ catalogsCmd
1608
+ .command('list')
1609
+ .description('List catalogs')
1610
+ .option('-o, --org <orgId>', 'Organization ID')
1611
+ .option('-a, --account <accountId>', 'Ad account ID')
1612
+ .action(async (opts) => {
1613
+ try {
1614
+ const client = getClient();
1615
+ let result;
1616
+
1617
+ if (opts.org) {
1618
+ result = await client.catalogs.list(opts.org);
1619
+ } else {
1620
+ const accountId = resolveAdAccountId(opts.account);
1621
+ result = await client.catalogs.listByAdAccount(accountId);
1622
+ }
1623
+
1624
+ if (getFormat(catalogsCmd) === 'json') {
1625
+ print(result, 'json');
1626
+ } else {
1627
+ success(`Catalogs (${result.length} total):`);
1628
+ result.forEach(catalog => {
1629
+ const status = catalog.status === 'ACTIVE' ? chalk.green(catalog.status) : chalk.yellow(catalog.status);
1630
+ console.log(` ${chalk.bold(catalog.name)} (${status})`);
1631
+ console.log(` ID: ${catalog.id}`);
1632
+ if (catalog.product_count) {
1633
+ console.log(` Products: ${catalog.product_count.toLocaleString()}`);
1634
+ }
1635
+ console.log();
1636
+ });
1637
+ }
1638
+ } catch (err) {
1639
+ error(String(err));
1640
+ process.exit(1);
1641
+ }
1642
+ });
1643
+
1644
+ catalogsCmd
1645
+ .command('get <catalogId>')
1646
+ .description('Get catalog details')
1647
+ .action(async (catalogId: string) => {
1648
+ try {
1649
+ const client = getClient();
1650
+ const result = await client.catalogs.get(catalogId);
1651
+ print(result, getFormat(catalogsCmd));
1652
+ } catch (err) {
1653
+ error(String(err));
1654
+ process.exit(1);
1655
+ }
1656
+ });
1657
+
1658
+ catalogsCmd
1659
+ .command('create')
1660
+ .description('Create a new catalog')
1661
+ .requiredOption('-n, --name <name>', 'Catalog name')
1662
+ .option('-a, --account <accountId>', 'Ad account ID')
1663
+ .action(async (opts) => {
1664
+ try {
1665
+ const client = getClient();
1666
+ const accountId = resolveAdAccountId(opts.account);
1667
+ const result = await client.catalogs.create({
1668
+ name: opts.name,
1669
+ ad_account_id: accountId,
1670
+ });
1671
+ success('Catalog created!');
1672
+ print(result, getFormat(catalogsCmd));
1673
+ } catch (err) {
1674
+ error(String(err));
1675
+ process.exit(1);
1676
+ }
1677
+ });
1678
+
1679
+ catalogsCmd
1680
+ .command('products <catalogId>')
1681
+ .description('List products in a catalog')
1682
+ .option('-l, --limit <number>', 'Limit results')
1683
+ .action(async (catalogId: string, opts) => {
1684
+ try {
1685
+ const client = getClient();
1686
+ const result = await client.catalogs.listProducts(catalogId, opts.limit ? parseInt(opts.limit) : undefined);
1687
+ print(result, getFormat(catalogsCmd));
1688
+ } catch (err) {
1689
+ error(String(err));
1690
+ process.exit(1);
1691
+ }
1692
+ });
1693
+
1694
+ catalogsCmd
1695
+ .command('delete <catalogId>')
1696
+ .description('Delete a catalog')
1697
+ .action(async (catalogId: string) => {
1698
+ try {
1699
+ const client = getClient();
1700
+ await client.catalogs.delete(catalogId);
1701
+ success('Catalog deleted');
1702
+ } catch (err) {
1703
+ error(String(err));
1704
+ process.exit(1);
1705
+ }
1706
+ });
1707
+
1708
+ // ============================================
1709
+ // Leads Commands
1710
+ // ============================================
1711
+ const leadsCmd = program
1712
+ .command('leads')
1713
+ .description('Manage lead forms and leads');
1714
+
1715
+ leadsCmd
1716
+ .command('forms [accountId]')
1717
+ .description('List lead forms for an ad account')
1718
+ .action(async (accountId?: string) => {
1719
+ try {
1720
+ const client = getClient();
1721
+ const id = resolveAdAccountId(accountId);
1722
+ const result = await client.leads.listForms(id);
1723
+
1724
+ if (getFormat(leadsCmd) === 'json') {
1725
+ print(result, 'json');
1726
+ } else {
1727
+ success(`Lead Forms (${result.length} total):`);
1728
+ result.forEach(form => {
1729
+ const status = form.status === 'ACTIVE' ? chalk.green(form.status) : chalk.yellow(form.status);
1730
+ console.log(` ${chalk.bold(form.name)} (${status})`);
1731
+ console.log(` ID: ${form.id}`);
1732
+ console.log(` Fields: ${form.fields.map(f => f.type).join(', ')}`);
1733
+ console.log();
1734
+ });
1735
+ }
1736
+ } catch (err) {
1737
+ error(String(err));
1738
+ process.exit(1);
1739
+ }
1740
+ });
1741
+
1742
+ leadsCmd
1743
+ .command('form <formId>')
1744
+ .description('Get lead form details')
1745
+ .action(async (formId: string) => {
1746
+ try {
1747
+ const client = getClient();
1748
+ const result = await client.leads.getForm(formId);
1749
+ print(result, getFormat(leadsCmd));
1750
+ } catch (err) {
1751
+ error(String(err));
1752
+ process.exit(1);
1753
+ }
1754
+ });
1755
+
1756
+ leadsCmd
1757
+ .command('list <formId>')
1758
+ .description('List leads for a form')
1759
+ .option('-l, --limit <number>', 'Limit results')
1760
+ .option('--start <time>', 'Start time (ISO 8601)')
1761
+ .option('--end <time>', 'End time (ISO 8601)')
1762
+ .action(async (formId: string, opts) => {
1763
+ try {
1764
+ const client = getClient();
1765
+ const result = await client.leads.listLeads(formId, {
1766
+ limit: opts.limit ? parseInt(opts.limit) : undefined,
1767
+ startTime: opts.start,
1768
+ endTime: opts.end,
1769
+ });
1770
+ print(result, getFormat(leadsCmd));
1771
+ } catch (err) {
1772
+ error(String(err));
1773
+ process.exit(1);
1774
+ }
1775
+ });
1776
+
1777
+ leadsCmd
1778
+ .command('get <leadId>')
1779
+ .description('Get lead details')
1780
+ .action(async (leadId: string) => {
1781
+ try {
1782
+ const client = getClient();
1783
+ const result = await client.leads.getLead(leadId);
1784
+ print(result, getFormat(leadsCmd));
1785
+ } catch (err) {
1786
+ error(String(err));
1787
+ process.exit(1);
1788
+ }
1789
+ });
1790
+
1791
+ leadsCmd
1792
+ .command('export <formId>')
1793
+ .description('Export leads to CSV')
1794
+ .option('-l, --limit <number>', 'Limit results')
1795
+ .action(async (formId: string, opts) => {
1796
+ try {
1797
+ const client = getClient();
1798
+ const leads = await client.leads.listLeads(formId, {
1799
+ limit: opts.limit ? parseInt(opts.limit) : undefined,
1800
+ });
1801
+ const csv = client.leads.exportLeadsToCSV(leads);
1802
+ console.log(csv);
1803
+ } catch (err) {
1804
+ error(String(err));
1805
+ process.exit(1);
1806
+ }
1807
+ });
1808
+
1809
+ // Parse and execute
1810
+ program.parse();