@hasna/connectors 0.4.2 → 0.5.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 (423) hide show
  1. package/bin/index.js +204 -1
  2. package/bin/mcp.js +204 -1
  3. package/bin/serve.js +203 -0
  4. package/connectors/connect-ably/.env.example +11 -0
  5. package/connectors/connect-ably/CLAUDE.md +111 -0
  6. package/connectors/connect-ably/README.md +193 -0
  7. package/connectors/connect-ably/package.json +54 -0
  8. package/connectors/connect-ably/scripts/release.ts +179 -0
  9. package/connectors/connect-ably/src/api/channels.ts +33 -0
  10. package/connectors/connect-ably/src/api/client.ts +203 -0
  11. package/connectors/connect-ably/src/api/index.ts +59 -0
  12. package/connectors/connect-ably/src/api/messages.ts +48 -0
  13. package/connectors/connect-ably/src/api/presence.ts +39 -0
  14. package/connectors/connect-ably/src/api/stats.ts +29 -0
  15. package/connectors/connect-ably/src/cli/index.ts +397 -0
  16. package/connectors/connect-ably/src/index.ts +102 -0
  17. package/connectors/connect-ably/src/types/index.ts +294 -0
  18. package/connectors/connect-ably/src/utils/auth.ts +274 -0
  19. package/connectors/connect-ably/src/utils/bulk.ts +212 -0
  20. package/connectors/connect-ably/src/utils/config.ts +323 -0
  21. package/connectors/connect-ably/src/utils/output.ts +175 -0
  22. package/connectors/connect-ably/src/utils/settings.ts +114 -0
  23. package/connectors/connect-ably/src/utils/storage.ts +198 -0
  24. package/connectors/connect-ably/tsconfig.json +16 -0
  25. package/connectors/connect-assemblyai/.env.example +11 -0
  26. package/connectors/connect-assemblyai/CLAUDE.md +128 -0
  27. package/connectors/connect-assemblyai/README.md +193 -0
  28. package/connectors/connect-assemblyai/package.json +50 -0
  29. package/connectors/connect-assemblyai/src/api/client.ts +192 -0
  30. package/connectors/connect-assemblyai/src/api/index.ts +71 -0
  31. package/connectors/connect-assemblyai/src/cli/index.ts +384 -0
  32. package/connectors/connect-assemblyai/src/index.ts +19 -0
  33. package/connectors/connect-assemblyai/src/types/index.ts +277 -0
  34. package/connectors/connect-assemblyai/src/utils/config.ts +103 -0
  35. package/connectors/connect-assemblyai/src/utils/output.ts +119 -0
  36. package/connectors/connect-assemblyai/tsconfig.json +16 -0
  37. package/connectors/connect-baseten/.env.example +11 -0
  38. package/connectors/connect-baseten/CLAUDE.md +128 -0
  39. package/connectors/connect-baseten/README.md +193 -0
  40. package/connectors/connect-baseten/package.json +51 -0
  41. package/connectors/connect-baseten/src/api/client.ts +71 -0
  42. package/connectors/connect-baseten/src/api/index.ts +40 -0
  43. package/connectors/connect-baseten/src/cli/index.ts +244 -0
  44. package/connectors/connect-baseten/src/index.ts +19 -0
  45. package/connectors/connect-baseten/src/types/index.ts +55 -0
  46. package/connectors/connect-baseten/src/utils/config.ts +103 -0
  47. package/connectors/connect-baseten/src/utils/output.ts +119 -0
  48. package/connectors/connect-baseten/tsconfig.json +16 -0
  49. package/connectors/connect-box/.env.example +11 -0
  50. package/connectors/connect-box/CLAUDE.md +272 -0
  51. package/connectors/connect-box/README.md +193 -0
  52. package/connectors/connect-box/package.json +51 -0
  53. package/connectors/connect-box/scripts/release.ts +179 -0
  54. package/connectors/connect-box/src/api/client.ts +213 -0
  55. package/connectors/connect-box/src/api/example.ts +48 -0
  56. package/connectors/connect-box/src/api/index.ts +51 -0
  57. package/connectors/connect-box/src/cli/index.ts +254 -0
  58. package/connectors/connect-box/src/index.ts +103 -0
  59. package/connectors/connect-box/src/types/index.ts +237 -0
  60. package/connectors/connect-box/src/utils/auth.ts +274 -0
  61. package/connectors/connect-box/src/utils/bulk.ts +212 -0
  62. package/connectors/connect-box/src/utils/config.ts +326 -0
  63. package/connectors/connect-box/src/utils/output.ts +175 -0
  64. package/connectors/connect-box/src/utils/settings.ts +114 -0
  65. package/connectors/connect-box/src/utils/storage.ts +198 -0
  66. package/connectors/connect-box/tsconfig.json +16 -0
  67. package/connectors/connect-cerebras/.env.example +11 -0
  68. package/connectors/connect-cerebras/CLAUDE.md +128 -0
  69. package/connectors/connect-cerebras/README.md +193 -0
  70. package/connectors/connect-cerebras/package.json +51 -0
  71. package/connectors/connect-cerebras/src/api/client.ts +64 -0
  72. package/connectors/connect-cerebras/src/api/index.ts +32 -0
  73. package/connectors/connect-cerebras/src/cli/index.ts +244 -0
  74. package/connectors/connect-cerebras/src/index.ts +19 -0
  75. package/connectors/connect-cerebras/src/types/index.ts +65 -0
  76. package/connectors/connect-cerebras/src/utils/config.ts +103 -0
  77. package/connectors/connect-cerebras/src/utils/output.ts +119 -0
  78. package/connectors/connect-cerebras/tsconfig.json +16 -0
  79. package/connectors/connect-clearbit/.env.example +11 -0
  80. package/connectors/connect-clearbit/CLAUDE.md +272 -0
  81. package/connectors/connect-clearbit/README.md +193 -0
  82. package/connectors/connect-clearbit/package.json +51 -0
  83. package/connectors/connect-clearbit/scripts/release.ts +179 -0
  84. package/connectors/connect-clearbit/src/api/client.ts +213 -0
  85. package/connectors/connect-clearbit/src/api/example.ts +48 -0
  86. package/connectors/connect-clearbit/src/api/index.ts +51 -0
  87. package/connectors/connect-clearbit/src/cli/index.ts +254 -0
  88. package/connectors/connect-clearbit/src/index.ts +103 -0
  89. package/connectors/connect-clearbit/src/types/index.ts +237 -0
  90. package/connectors/connect-clearbit/src/utils/auth.ts +274 -0
  91. package/connectors/connect-clearbit/src/utils/bulk.ts +212 -0
  92. package/connectors/connect-clearbit/src/utils/config.ts +326 -0
  93. package/connectors/connect-clearbit/src/utils/output.ts +175 -0
  94. package/connectors/connect-clearbit/src/utils/settings.ts +114 -0
  95. package/connectors/connect-clearbit/src/utils/storage.ts +198 -0
  96. package/connectors/connect-clearbit/tsconfig.json +16 -0
  97. package/connectors/connect-coda/.env.example +11 -0
  98. package/connectors/connect-coda/CLAUDE.md +272 -0
  99. package/connectors/connect-coda/README.md +193 -0
  100. package/connectors/connect-coda/package.json +51 -0
  101. package/connectors/connect-coda/scripts/release.ts +179 -0
  102. package/connectors/connect-coda/src/api/client.ts +213 -0
  103. package/connectors/connect-coda/src/api/example.ts +48 -0
  104. package/connectors/connect-coda/src/api/index.ts +51 -0
  105. package/connectors/connect-coda/src/cli/index.ts +254 -0
  106. package/connectors/connect-coda/src/index.ts +103 -0
  107. package/connectors/connect-coda/src/types/index.ts +237 -0
  108. package/connectors/connect-coda/src/utils/auth.ts +274 -0
  109. package/connectors/connect-coda/src/utils/bulk.ts +212 -0
  110. package/connectors/connect-coda/src/utils/config.ts +326 -0
  111. package/connectors/connect-coda/src/utils/output.ts +175 -0
  112. package/connectors/connect-coda/src/utils/settings.ts +114 -0
  113. package/connectors/connect-coda/src/utils/storage.ts +198 -0
  114. package/connectors/connect-coda/tsconfig.json +16 -0
  115. package/connectors/connect-cohere/.env.example +11 -0
  116. package/connectors/connect-cohere/CLAUDE.md +128 -0
  117. package/connectors/connect-cohere/README.md +193 -0
  118. package/connectors/connect-cohere/package.json +53 -0
  119. package/connectors/connect-cohere/src/api/client.ts +109 -0
  120. package/connectors/connect-cohere/src/api/index.ts +59 -0
  121. package/connectors/connect-cohere/src/cli/index.ts +255 -0
  122. package/connectors/connect-cohere/src/index.ts +19 -0
  123. package/connectors/connect-cohere/src/types/index.ts +132 -0
  124. package/connectors/connect-cohere/src/utils/config.ts +197 -0
  125. package/connectors/connect-cohere/src/utils/output.ts +119 -0
  126. package/connectors/connect-cohere/tsconfig.json +16 -0
  127. package/connectors/connect-deepgram/.env.example +11 -0
  128. package/connectors/connect-deepgram/CLAUDE.md +128 -0
  129. package/connectors/connect-deepgram/README.md +193 -0
  130. package/connectors/connect-deepgram/package.json +51 -0
  131. package/connectors/connect-deepgram/src/api/client.ts +235 -0
  132. package/connectors/connect-deepgram/src/api/index.ts +57 -0
  133. package/connectors/connect-deepgram/src/cli/index.ts +339 -0
  134. package/connectors/connect-deepgram/src/index.ts +19 -0
  135. package/connectors/connect-deepgram/src/types/index.ts +232 -0
  136. package/connectors/connect-deepgram/src/utils/config.ts +103 -0
  137. package/connectors/connect-deepgram/src/utils/output.ts +119 -0
  138. package/connectors/connect-deepgram/tsconfig.json +16 -0
  139. package/connectors/connect-deepseek/.env.example +11 -0
  140. package/connectors/connect-deepseek/CLAUDE.md +128 -0
  141. package/connectors/connect-deepseek/README.md +193 -0
  142. package/connectors/connect-deepseek/package.json +51 -0
  143. package/connectors/connect-deepseek/src/api/client.ts +108 -0
  144. package/connectors/connect-deepseek/src/api/index.ts +36 -0
  145. package/connectors/connect-deepseek/src/cli/index.ts +167 -0
  146. package/connectors/connect-deepseek/src/index.ts +19 -0
  147. package/connectors/connect-deepseek/src/types/index.ts +72 -0
  148. package/connectors/connect-deepseek/src/utils/config.ts +103 -0
  149. package/connectors/connect-deepseek/src/utils/output.ts +119 -0
  150. package/connectors/connect-deepseek/tsconfig.json +16 -0
  151. package/connectors/connect-dropbox/.env.example +11 -0
  152. package/connectors/connect-dropbox/CLAUDE.md +119 -0
  153. package/connectors/connect-dropbox/README.md +193 -0
  154. package/connectors/connect-dropbox/package.json +51 -0
  155. package/connectors/connect-dropbox/src/api/client.ts +222 -0
  156. package/connectors/connect-dropbox/src/api/index.ts +395 -0
  157. package/connectors/connect-dropbox/src/cli/index.ts +627 -0
  158. package/connectors/connect-dropbox/src/index.ts +20 -0
  159. package/connectors/connect-dropbox/src/types/index.ts +516 -0
  160. package/connectors/connect-dropbox/src/utils/config.ts +197 -0
  161. package/connectors/connect-dropbox/tsconfig.json +16 -0
  162. package/connectors/connect-fal/.env.example +11 -0
  163. package/connectors/connect-fal/CLAUDE.md +128 -0
  164. package/connectors/connect-fal/README.md +193 -0
  165. package/connectors/connect-fal/package.json +51 -0
  166. package/connectors/connect-fal/src/api/client.ts +172 -0
  167. package/connectors/connect-fal/src/api/index.ts +55 -0
  168. package/connectors/connect-fal/src/cli/index.ts +341 -0
  169. package/connectors/connect-fal/src/index.ts +19 -0
  170. package/connectors/connect-fal/src/types/index.ts +135 -0
  171. package/connectors/connect-fal/src/utils/config.ts +103 -0
  172. package/connectors/connect-fal/src/utils/output.ts +119 -0
  173. package/connectors/connect-fal/tsconfig.json +16 -0
  174. package/connectors/connect-fireworks/.env.example +11 -0
  175. package/connectors/connect-fireworks/CLAUDE.md +128 -0
  176. package/connectors/connect-fireworks/README.md +193 -0
  177. package/connectors/connect-fireworks/package.json +51 -0
  178. package/connectors/connect-fireworks/src/api/client.ts +63 -0
  179. package/connectors/connect-fireworks/src/api/index.ts +36 -0
  180. package/connectors/connect-fireworks/src/cli/index.ts +244 -0
  181. package/connectors/connect-fireworks/src/index.ts +19 -0
  182. package/connectors/connect-fireworks/src/types/index.ts +70 -0
  183. package/connectors/connect-fireworks/src/utils/config.ts +103 -0
  184. package/connectors/connect-fireworks/src/utils/output.ts +119 -0
  185. package/connectors/connect-fireworks/tsconfig.json +16 -0
  186. package/connectors/connect-groq/.env.example +11 -0
  187. package/connectors/connect-groq/CLAUDE.md +128 -0
  188. package/connectors/connect-groq/README.md +193 -0
  189. package/connectors/connect-groq/package.json +52 -0
  190. package/connectors/connect-groq/src/api/client.ts +108 -0
  191. package/connectors/connect-groq/src/api/index.ts +36 -0
  192. package/connectors/connect-groq/src/cli/index.ts +171 -0
  193. package/connectors/connect-groq/src/index.ts +19 -0
  194. package/connectors/connect-groq/src/types/index.ts +69 -0
  195. package/connectors/connect-groq/src/utils/config.ts +103 -0
  196. package/connectors/connect-groq/src/utils/output.ts +119 -0
  197. package/connectors/connect-groq/tsconfig.json +16 -0
  198. package/connectors/connect-linode/.env.example +11 -0
  199. package/connectors/connect-linode/CLAUDE.md +272 -0
  200. package/connectors/connect-linode/README.md +193 -0
  201. package/connectors/connect-linode/package.json +51 -0
  202. package/connectors/connect-linode/scripts/release.ts +179 -0
  203. package/connectors/connect-linode/src/api/client.ts +213 -0
  204. package/connectors/connect-linode/src/api/example.ts +48 -0
  205. package/connectors/connect-linode/src/api/index.ts +51 -0
  206. package/connectors/connect-linode/src/cli/index.ts +254 -0
  207. package/connectors/connect-linode/src/index.ts +103 -0
  208. package/connectors/connect-linode/src/types/index.ts +237 -0
  209. package/connectors/connect-linode/src/utils/auth.ts +274 -0
  210. package/connectors/connect-linode/src/utils/bulk.ts +212 -0
  211. package/connectors/connect-linode/src/utils/config.ts +326 -0
  212. package/connectors/connect-linode/src/utils/output.ts +175 -0
  213. package/connectors/connect-linode/src/utils/settings.ts +114 -0
  214. package/connectors/connect-linode/src/utils/storage.ts +198 -0
  215. package/connectors/connect-linode/tsconfig.json +16 -0
  216. package/connectors/connect-luma/.env.example +11 -0
  217. package/connectors/connect-luma/CLAUDE.md +128 -0
  218. package/connectors/connect-luma/README.md +193 -0
  219. package/connectors/connect-luma/package.json +53 -0
  220. package/connectors/connect-luma/src/api/client.ts +85 -0
  221. package/connectors/connect-luma/src/api/index.ts +44 -0
  222. package/connectors/connect-luma/src/cli/index.ts +300 -0
  223. package/connectors/connect-luma/src/index.ts +19 -0
  224. package/connectors/connect-luma/src/types/index.ts +60 -0
  225. package/connectors/connect-luma/src/utils/config.ts +103 -0
  226. package/connectors/connect-luma/src/utils/output.ts +119 -0
  227. package/connectors/connect-luma/tsconfig.json +16 -0
  228. package/connectors/connect-mailgun/.env.example +11 -0
  229. package/connectors/connect-mailgun/CLAUDE.md +272 -0
  230. package/connectors/connect-mailgun/README.md +193 -0
  231. package/connectors/connect-mailgun/package.json +51 -0
  232. package/connectors/connect-mailgun/scripts/release.ts +179 -0
  233. package/connectors/connect-mailgun/src/api/client.ts +213 -0
  234. package/connectors/connect-mailgun/src/api/example.ts +48 -0
  235. package/connectors/connect-mailgun/src/api/index.ts +51 -0
  236. package/connectors/connect-mailgun/src/cli/index.ts +254 -0
  237. package/connectors/connect-mailgun/src/index.ts +103 -0
  238. package/connectors/connect-mailgun/src/types/index.ts +237 -0
  239. package/connectors/connect-mailgun/src/utils/auth.ts +274 -0
  240. package/connectors/connect-mailgun/src/utils/bulk.ts +212 -0
  241. package/connectors/connect-mailgun/src/utils/config.ts +326 -0
  242. package/connectors/connect-mailgun/src/utils/output.ts +175 -0
  243. package/connectors/connect-mailgun/src/utils/settings.ts +114 -0
  244. package/connectors/connect-mailgun/src/utils/storage.ts +198 -0
  245. package/connectors/connect-mailgun/tsconfig.json +16 -0
  246. package/connectors/connect-messagebird/.env.example +11 -0
  247. package/connectors/connect-messagebird/CLAUDE.md +272 -0
  248. package/connectors/connect-messagebird/README.md +193 -0
  249. package/connectors/connect-messagebird/package.json +51 -0
  250. package/connectors/connect-messagebird/scripts/release.ts +179 -0
  251. package/connectors/connect-messagebird/src/api/client.ts +213 -0
  252. package/connectors/connect-messagebird/src/api/example.ts +48 -0
  253. package/connectors/connect-messagebird/src/api/index.ts +51 -0
  254. package/connectors/connect-messagebird/src/cli/index.ts +254 -0
  255. package/connectors/connect-messagebird/src/index.ts +103 -0
  256. package/connectors/connect-messagebird/src/types/index.ts +237 -0
  257. package/connectors/connect-messagebird/src/utils/auth.ts +274 -0
  258. package/connectors/connect-messagebird/src/utils/bulk.ts +212 -0
  259. package/connectors/connect-messagebird/src/utils/config.ts +326 -0
  260. package/connectors/connect-messagebird/src/utils/output.ts +175 -0
  261. package/connectors/connect-messagebird/src/utils/settings.ts +114 -0
  262. package/connectors/connect-messagebird/src/utils/storage.ts +198 -0
  263. package/connectors/connect-messagebird/tsconfig.json +16 -0
  264. package/connectors/connect-miro/.env.example +11 -0
  265. package/connectors/connect-miro/CLAUDE.md +272 -0
  266. package/connectors/connect-miro/README.md +193 -0
  267. package/connectors/connect-miro/package.json +51 -0
  268. package/connectors/connect-miro/scripts/release.ts +179 -0
  269. package/connectors/connect-miro/src/api/client.ts +213 -0
  270. package/connectors/connect-miro/src/api/example.ts +48 -0
  271. package/connectors/connect-miro/src/api/index.ts +51 -0
  272. package/connectors/connect-miro/src/cli/index.ts +254 -0
  273. package/connectors/connect-miro/src/index.ts +103 -0
  274. package/connectors/connect-miro/src/types/index.ts +237 -0
  275. package/connectors/connect-miro/src/utils/auth.ts +274 -0
  276. package/connectors/connect-miro/src/utils/bulk.ts +212 -0
  277. package/connectors/connect-miro/src/utils/config.ts +326 -0
  278. package/connectors/connect-miro/src/utils/output.ts +175 -0
  279. package/connectors/connect-miro/src/utils/settings.ts +114 -0
  280. package/connectors/connect-miro/src/utils/storage.ts +198 -0
  281. package/connectors/connect-miro/tsconfig.json +16 -0
  282. package/connectors/connect-modal/.env.example +11 -0
  283. package/connectors/connect-modal/CLAUDE.md +128 -0
  284. package/connectors/connect-modal/README.md +193 -0
  285. package/connectors/connect-modal/package.json +51 -0
  286. package/connectors/connect-modal/src/api/client.ts +119 -0
  287. package/connectors/connect-modal/src/api/index.ts +69 -0
  288. package/connectors/connect-modal/src/cli/index.ts +224 -0
  289. package/connectors/connect-modal/src/index.ts +21 -0
  290. package/connectors/connect-modal/src/types/index.ts +60 -0
  291. package/connectors/connect-modal/src/utils/config.ts +114 -0
  292. package/connectors/connect-modal/src/utils/output.ts +119 -0
  293. package/connectors/connect-modal/tsconfig.json +16 -0
  294. package/connectors/connect-monday/.env.example +11 -0
  295. package/connectors/connect-monday/CLAUDE.md +128 -0
  296. package/connectors/connect-monday/README.md +193 -0
  297. package/connectors/connect-monday/package.json +52 -0
  298. package/connectors/connect-monday/src/api/client.ts +59 -0
  299. package/connectors/connect-monday/src/api/index.ts +539 -0
  300. package/connectors/connect-monday/src/cli/index.ts +479 -0
  301. package/connectors/connect-monday/src/index.ts +19 -0
  302. package/connectors/connect-monday/src/types/index.ts +274 -0
  303. package/connectors/connect-monday/src/utils/config.ts +197 -0
  304. package/connectors/connect-monday/src/utils/output.ts +119 -0
  305. package/connectors/connect-monday/tsconfig.json +16 -0
  306. package/connectors/connect-perplexity/.env.example +4 -0
  307. package/connectors/connect-perplexity/CLAUDE.md +156 -0
  308. package/connectors/connect-perplexity/README.md +184 -0
  309. package/connectors/connect-perplexity/package.json +58 -0
  310. package/connectors/connect-perplexity/scripts/publish.ts +210 -0
  311. package/connectors/connect-perplexity/src/api/client.ts +119 -0
  312. package/connectors/connect-perplexity/src/api/example.ts +118 -0
  313. package/connectors/connect-perplexity/src/api/index.ts +48 -0
  314. package/connectors/connect-perplexity/src/cli/index.ts +421 -0
  315. package/connectors/connect-perplexity/src/index.ts +24 -0
  316. package/connectors/connect-perplexity/src/types/index.ts +140 -0
  317. package/connectors/connect-perplexity/src/utils/config.ts +208 -0
  318. package/connectors/connect-perplexity/src/utils/output.ts +119 -0
  319. package/connectors/connect-perplexity/tsconfig.json +16 -0
  320. package/connectors/connect-pipedrive/.env.example +11 -0
  321. package/connectors/connect-pipedrive/CLAUDE.md +128 -0
  322. package/connectors/connect-pipedrive/README.md +193 -0
  323. package/connectors/connect-pipedrive/package.json +52 -0
  324. package/connectors/connect-pipedrive/src/api/client.ts +121 -0
  325. package/connectors/connect-pipedrive/src/api/index.ts +306 -0
  326. package/connectors/connect-pipedrive/src/cli/index.ts +824 -0
  327. package/connectors/connect-pipedrive/src/index.ts +19 -0
  328. package/connectors/connect-pipedrive/src/types/index.ts +335 -0
  329. package/connectors/connect-pipedrive/src/utils/config.ts +171 -0
  330. package/connectors/connect-pipedrive/src/utils/output.ts +119 -0
  331. package/connectors/connect-pipedrive/tsconfig.json +16 -0
  332. package/connectors/connect-pusher/.env.example +11 -0
  333. package/connectors/connect-pusher/CLAUDE.md +272 -0
  334. package/connectors/connect-pusher/README.md +193 -0
  335. package/connectors/connect-pusher/package.json +51 -0
  336. package/connectors/connect-pusher/scripts/release.ts +179 -0
  337. package/connectors/connect-pusher/src/api/client.ts +213 -0
  338. package/connectors/connect-pusher/src/api/example.ts +48 -0
  339. package/connectors/connect-pusher/src/api/index.ts +51 -0
  340. package/connectors/connect-pusher/src/cli/index.ts +254 -0
  341. package/connectors/connect-pusher/src/index.ts +103 -0
  342. package/connectors/connect-pusher/src/types/index.ts +237 -0
  343. package/connectors/connect-pusher/src/utils/auth.ts +274 -0
  344. package/connectors/connect-pusher/src/utils/bulk.ts +212 -0
  345. package/connectors/connect-pusher/src/utils/config.ts +326 -0
  346. package/connectors/connect-pusher/src/utils/output.ts +175 -0
  347. package/connectors/connect-pusher/src/utils/settings.ts +114 -0
  348. package/connectors/connect-pusher/src/utils/storage.ts +198 -0
  349. package/connectors/connect-pusher/tsconfig.json +16 -0
  350. package/connectors/connect-replicate/.env.example +11 -0
  351. package/connectors/connect-replicate/CLAUDE.md +128 -0
  352. package/connectors/connect-replicate/README.md +193 -0
  353. package/connectors/connect-replicate/package.json +51 -0
  354. package/connectors/connect-replicate/src/api/client.ts +109 -0
  355. package/connectors/connect-replicate/src/api/index.ts +71 -0
  356. package/connectors/connect-replicate/src/cli/index.ts +250 -0
  357. package/connectors/connect-replicate/src/index.ts +19 -0
  358. package/connectors/connect-replicate/src/types/index.ts +85 -0
  359. package/connectors/connect-replicate/src/utils/config.ts +103 -0
  360. package/connectors/connect-replicate/src/utils/output.ts +119 -0
  361. package/connectors/connect-replicate/tsconfig.json +16 -0
  362. package/connectors/connect-roboflow/.env.example +11 -0
  363. package/connectors/connect-roboflow/CLAUDE.md +272 -0
  364. package/connectors/connect-roboflow/README.md +193 -0
  365. package/connectors/connect-roboflow/package.json +51 -0
  366. package/connectors/connect-roboflow/scripts/release.ts +179 -0
  367. package/connectors/connect-roboflow/src/api/client.ts +213 -0
  368. package/connectors/connect-roboflow/src/api/example.ts +48 -0
  369. package/connectors/connect-roboflow/src/api/index.ts +51 -0
  370. package/connectors/connect-roboflow/src/cli/index.ts +254 -0
  371. package/connectors/connect-roboflow/src/index.ts +103 -0
  372. package/connectors/connect-roboflow/src/types/index.ts +237 -0
  373. package/connectors/connect-roboflow/src/utils/auth.ts +274 -0
  374. package/connectors/connect-roboflow/src/utils/bulk.ts +212 -0
  375. package/connectors/connect-roboflow/src/utils/config.ts +326 -0
  376. package/connectors/connect-roboflow/src/utils/output.ts +175 -0
  377. package/connectors/connect-roboflow/src/utils/settings.ts +114 -0
  378. package/connectors/connect-roboflow/src/utils/storage.ts +198 -0
  379. package/connectors/connect-roboflow/tsconfig.json +16 -0
  380. package/connectors/connect-runway/.env.example +11 -0
  381. package/connectors/connect-runway/CLAUDE.md +128 -0
  382. package/connectors/connect-runway/README.md +193 -0
  383. package/connectors/connect-runway/package.json +52 -0
  384. package/connectors/connect-runway/src/api/client.ts +78 -0
  385. package/connectors/connect-runway/src/api/index.ts +40 -0
  386. package/connectors/connect-runway/src/cli/index.ts +283 -0
  387. package/connectors/connect-runway/src/index.ts +19 -0
  388. package/connectors/connect-runway/src/types/index.ts +52 -0
  389. package/connectors/connect-runway/src/utils/config.ts +103 -0
  390. package/connectors/connect-runway/src/utils/output.ts +119 -0
  391. package/connectors/connect-runway/tsconfig.json +16 -0
  392. package/connectors/connect-together/.env.example +11 -0
  393. package/connectors/connect-together/CLAUDE.md +128 -0
  394. package/connectors/connect-together/README.md +193 -0
  395. package/connectors/connect-together/package.json +52 -0
  396. package/connectors/connect-together/src/api/client.ts +106 -0
  397. package/connectors/connect-together/src/api/index.ts +47 -0
  398. package/connectors/connect-together/src/cli/index.ts +228 -0
  399. package/connectors/connect-together/src/index.ts +19 -0
  400. package/connectors/connect-together/src/types/index.ts +91 -0
  401. package/connectors/connect-together/src/utils/config.ts +142 -0
  402. package/connectors/connect-together/src/utils/output.ts +119 -0
  403. package/connectors/connect-together/tsconfig.json +16 -0
  404. package/connectors/connect-vonage/.env.example +11 -0
  405. package/connectors/connect-vonage/CLAUDE.md +272 -0
  406. package/connectors/connect-vonage/README.md +193 -0
  407. package/connectors/connect-vonage/package.json +51 -0
  408. package/connectors/connect-vonage/scripts/release.ts +179 -0
  409. package/connectors/connect-vonage/src/api/client.ts +213 -0
  410. package/connectors/connect-vonage/src/api/example.ts +48 -0
  411. package/connectors/connect-vonage/src/api/index.ts +51 -0
  412. package/connectors/connect-vonage/src/cli/index.ts +254 -0
  413. package/connectors/connect-vonage/src/index.ts +103 -0
  414. package/connectors/connect-vonage/src/types/index.ts +237 -0
  415. package/connectors/connect-vonage/src/utils/auth.ts +274 -0
  416. package/connectors/connect-vonage/src/utils/bulk.ts +212 -0
  417. package/connectors/connect-vonage/src/utils/config.ts +326 -0
  418. package/connectors/connect-vonage/src/utils/output.ts +175 -0
  419. package/connectors/connect-vonage/src/utils/settings.ts +114 -0
  420. package/connectors/connect-vonage/src/utils/storage.ts +198 -0
  421. package/connectors/connect-vonage/tsconfig.json +16 -0
  422. package/dist/index.js +203 -0
  423. package/package.json +1 -1
@@ -0,0 +1,212 @@
1
+ // ============================================
2
+ // Bulk Operations Utility
3
+ // ============================================
4
+
5
+ /**
6
+ * Options for bulk operations
7
+ */
8
+ export interface BulkOperationOptions<T> {
9
+ /** Items to process */
10
+ items: T[];
11
+ /** Maximum concurrent operations (default: 10) */
12
+ concurrency?: number;
13
+ /** Dry run - preview without making changes */
14
+ dryRun?: boolean;
15
+ /** Progress callback */
16
+ onProgress?: (current: number, total: number, item: T) => void;
17
+ /** Error callback (return true to continue, false to stop) */
18
+ onError?: (error: Error, item: T) => boolean | void;
19
+ /** Delay between batches in ms (useful for rate limiting) */
20
+ batchDelay?: number;
21
+ }
22
+
23
+ /**
24
+ * Result of a bulk operation
25
+ */
26
+ export interface BulkOperationResult<T, R = void> {
27
+ /** Total items processed */
28
+ total: number;
29
+ /** Successfully processed count */
30
+ success: number;
31
+ /** Failed count */
32
+ failed: number;
33
+ /** Skipped count (dry run) */
34
+ skipped: number;
35
+ /** List of errors */
36
+ errors: Array<{ item: T; error: string }>;
37
+ /** Successfully processed items with results */
38
+ results: Array<{ item: T; result: R }>;
39
+ }
40
+
41
+ /**
42
+ * Split an array into chunks of a given size
43
+ */
44
+ export function chunkArray<T>(array: T[], size: number): T[][] {
45
+ const chunks: T[][] = [];
46
+ for (let i = 0; i < array.length; i += size) {
47
+ chunks.push(array.slice(i, i + size));
48
+ }
49
+ return chunks;
50
+ }
51
+
52
+ /**
53
+ * Sleep for a given number of milliseconds
54
+ */
55
+ export function sleep(ms: number): Promise<void> {
56
+ return new Promise(resolve => setTimeout(resolve, ms));
57
+ }
58
+
59
+ /**
60
+ * Execute a bulk operation with concurrency control
61
+ *
62
+ * @param options - Bulk operation options
63
+ * @param operation - Async function to execute for each item
64
+ * @returns Result summary
65
+ *
66
+ * @example
67
+ * ```typescript
68
+ * const result = await executeBulk(
69
+ * {
70
+ * items: users,
71
+ * concurrency: 5,
72
+ * onProgress: (current, total, user) => {
73
+ * console.log(`Processing ${current}/${total}: ${user.email}`);
74
+ * },
75
+ * },
76
+ * async (user) => {
77
+ * await api.updateUser(user.id, { status: 'active' });
78
+ * }
79
+ * );
80
+ * console.log(`Success: ${result.success}, Failed: ${result.failed}`);
81
+ * ```
82
+ */
83
+ export async function executeBulk<T, R = void>(
84
+ options: BulkOperationOptions<T>,
85
+ operation: (item: T) => Promise<R>
86
+ ): Promise<BulkOperationResult<T, R>> {
87
+ const {
88
+ items,
89
+ concurrency = 10,
90
+ dryRun = false,
91
+ onProgress,
92
+ onError,
93
+ batchDelay = 0,
94
+ } = options;
95
+
96
+ const result: BulkOperationResult<T, R> = {
97
+ total: items.length,
98
+ success: 0,
99
+ failed: 0,
100
+ skipped: 0,
101
+ errors: [],
102
+ results: [],
103
+ };
104
+
105
+ if (items.length === 0) {
106
+ return result;
107
+ }
108
+
109
+ // Process in batches with concurrency control
110
+ const chunks = chunkArray(items, concurrency);
111
+ let shouldStop = false;
112
+
113
+ for (let chunkIndex = 0; chunkIndex < chunks.length && !shouldStop; chunkIndex++) {
114
+ const chunk = chunks[chunkIndex];
115
+
116
+ await Promise.all(
117
+ chunk.map(async (item) => {
118
+ if (shouldStop) return;
119
+
120
+ try {
121
+ if (dryRun) {
122
+ result.skipped++;
123
+ result.results.push({ item, result: undefined as R });
124
+ } else {
125
+ const opResult = await operation(item);
126
+ result.success++;
127
+ result.results.push({ item, result: opResult });
128
+ }
129
+
130
+ if (onProgress) {
131
+ onProgress(result.success + result.failed + result.skipped, result.total, item);
132
+ }
133
+ } catch (err) {
134
+ result.failed++;
135
+ const errorMessage = err instanceof Error ? err.message : String(err);
136
+ result.errors.push({ item, error: errorMessage });
137
+
138
+ if (onError) {
139
+ const shouldContinue = onError(err instanceof Error ? err : new Error(errorMessage), item);
140
+ if (shouldContinue === false) {
141
+ shouldStop = true;
142
+ }
143
+ }
144
+ }
145
+ })
146
+ );
147
+
148
+ // Add delay between batches if specified (for rate limiting)
149
+ if (batchDelay > 0 && chunkIndex < chunks.length - 1) {
150
+ await sleep(batchDelay);
151
+ }
152
+ }
153
+
154
+ return result;
155
+ }
156
+
157
+ /**
158
+ * Execute operations sequentially (one at a time)
159
+ * Useful when operations must be processed in order
160
+ */
161
+ export async function executeSequential<T, R = void>(
162
+ options: Omit<BulkOperationOptions<T>, 'concurrency'>,
163
+ operation: (item: T) => Promise<R>
164
+ ): Promise<BulkOperationResult<T, R>> {
165
+ return executeBulk({ ...options, concurrency: 1 }, operation);
166
+ }
167
+
168
+ /**
169
+ * Create a progress reporter for bulk operations
170
+ */
171
+ export function createProgressReporter(prefix: string = 'Processing') {
172
+ let lastPercent = -1;
173
+
174
+ return (current: number, total: number, _item: unknown): void => {
175
+ const percent = Math.floor((current / total) * 100);
176
+ if (percent !== lastPercent) {
177
+ lastPercent = percent;
178
+ process.stdout.write(`\r${prefix}: ${current}/${total} (${percent}%)`);
179
+ if (current === total) {
180
+ process.stdout.write('\n');
181
+ }
182
+ }
183
+ };
184
+ }
185
+
186
+ /**
187
+ * Format bulk operation result for display
188
+ */
189
+ export function formatBulkResult<T>(result: BulkOperationResult<T, unknown>): string {
190
+ const lines: string[] = [
191
+ `Total: ${result.total}`,
192
+ `Success: ${result.success}`,
193
+ `Failed: ${result.failed}`,
194
+ ];
195
+
196
+ if (result.skipped > 0) {
197
+ lines.push(`Skipped (dry run): ${result.skipped}`);
198
+ }
199
+
200
+ if (result.errors.length > 0) {
201
+ lines.push('');
202
+ lines.push('Errors:');
203
+ for (const { error } of result.errors.slice(0, 10)) {
204
+ lines.push(` - ${error}`);
205
+ }
206
+ if (result.errors.length > 10) {
207
+ lines.push(` ... and ${result.errors.length - 10} more errors`);
208
+ }
209
+ }
210
+
211
+ return lines.join('\n');
212
+ }
@@ -0,0 +1,323 @@
1
+ import { existsSync, readFileSync, writeFileSync, mkdirSync, readdirSync, rmSync } from 'fs';
2
+ import { homedir } from 'os';
3
+ import { join } from 'path';
4
+ import type { OAuth2Config, OAuth2Tokens } from '../types';
5
+
6
+ const CONNECTOR_NAME = 'connect-ably';
7
+ const DEFAULT_PROFILE = 'default';
8
+
9
+ export interface ProfileConfig {
10
+ // API Key authentication
11
+ apiKey?: string;
12
+ token?: string; // Alias for apiKey
13
+ apiSecret?: string;
14
+
15
+ // OAuth2 authentication
16
+ accessToken?: string;
17
+ refreshToken?: string;
18
+ expiresAt?: number;
19
+ tokenType?: string;
20
+ scope?: string;
21
+
22
+ // OAuth2 client credentials (stored separately for security)
23
+ clientId?: string;
24
+ clientSecret?: string;
25
+
26
+ // Add more config fields as needed for your API
27
+ }
28
+
29
+ // Store for --profile flag override (set by CLI before commands run)
30
+ let profileOverride: string | undefined;
31
+
32
+ // Config directory: ~/.connect/{connector-name}/
33
+ const CONFIG_DIR = join(homedir(), '.connect', CONNECTOR_NAME);
34
+ const PROFILES_DIR = join(CONFIG_DIR, 'profiles');
35
+ const CURRENT_PROFILE_FILE = join(CONFIG_DIR, 'current_profile');
36
+
37
+ // ============================================
38
+ // Profile Management
39
+ // ============================================
40
+
41
+ export function setProfileOverride(profile: string | undefined): void {
42
+ profileOverride = profile;
43
+ }
44
+
45
+ export function ensureConfigDir(): void {
46
+ if (!existsSync(CONFIG_DIR)) {
47
+ mkdirSync(CONFIG_DIR, { recursive: true });
48
+ }
49
+ if (!existsSync(PROFILES_DIR)) {
50
+ mkdirSync(PROFILES_DIR, { recursive: true });
51
+ }
52
+ }
53
+
54
+ function getProfilePath(profile: string): string {
55
+ return join(PROFILES_DIR, `${profile}.json`);
56
+ }
57
+
58
+ /**
59
+ * Get the current active profile name
60
+ */
61
+ export function getCurrentProfile(): string {
62
+ if (profileOverride) {
63
+ return profileOverride;
64
+ }
65
+
66
+ ensureConfigDir();
67
+
68
+ if (existsSync(CURRENT_PROFILE_FILE)) {
69
+ try {
70
+ const profile = readFileSync(CURRENT_PROFILE_FILE, 'utf-8').trim();
71
+ if (profile && profileExists(profile)) {
72
+ return profile;
73
+ }
74
+ } catch {
75
+ // Fall through to default
76
+ }
77
+ }
78
+
79
+ return DEFAULT_PROFILE;
80
+ }
81
+
82
+ /**
83
+ * Set the current active profile
84
+ */
85
+ export function setCurrentProfile(profile: string): void {
86
+ ensureConfigDir();
87
+
88
+ if (!profileExists(profile) && profile !== DEFAULT_PROFILE) {
89
+ throw new Error(`Profile "${profile}" does not exist`);
90
+ }
91
+
92
+ writeFileSync(CURRENT_PROFILE_FILE, profile);
93
+ }
94
+
95
+ /**
96
+ * Check if a profile exists
97
+ */
98
+ export function profileExists(profile: string): boolean {
99
+ return existsSync(getProfilePath(profile));
100
+ }
101
+
102
+ /**
103
+ * List all available profiles
104
+ */
105
+ export function listProfiles(): string[] {
106
+ ensureConfigDir();
107
+
108
+ if (!existsSync(PROFILES_DIR)) {
109
+ return [];
110
+ }
111
+
112
+ return readdirSync(PROFILES_DIR)
113
+ .filter(f => f.endsWith('.json'))
114
+ .map(f => f.replace('.json', ''))
115
+ .sort();
116
+ }
117
+
118
+ /**
119
+ * Create a new profile
120
+ */
121
+ export function createProfile(profile: string, config: ProfileConfig = {}): boolean {
122
+ ensureConfigDir();
123
+
124
+ if (profileExists(profile)) {
125
+ return false;
126
+ }
127
+
128
+ // Validate profile name
129
+ if (!/^[a-zA-Z0-9_-]+$/.test(profile)) {
130
+ throw new Error('Profile name can only contain letters, numbers, hyphens, and underscores');
131
+ }
132
+
133
+ writeFileSync(getProfilePath(profile), JSON.stringify(config, null, 2));
134
+ return true;
135
+ }
136
+
137
+ /**
138
+ * Delete a profile
139
+ */
140
+ export function deleteProfile(profile: string): boolean {
141
+ if (profile === DEFAULT_PROFILE) {
142
+ return false;
143
+ }
144
+
145
+ if (!profileExists(profile)) {
146
+ return false;
147
+ }
148
+
149
+ // Switch to default if deleting current profile
150
+ if (getCurrentProfile() === profile) {
151
+ setCurrentProfile(DEFAULT_PROFILE);
152
+ }
153
+
154
+ rmSync(getProfilePath(profile));
155
+ return true;
156
+ }
157
+
158
+ /**
159
+ * Load profile config
160
+ */
161
+ export function loadProfile(profile?: string): ProfileConfig {
162
+ ensureConfigDir();
163
+ const profileName = profile || getCurrentProfile();
164
+ const profilePath = getProfilePath(profileName);
165
+
166
+ if (!existsSync(profilePath)) {
167
+ return {};
168
+ }
169
+
170
+ try {
171
+ return JSON.parse(readFileSync(profilePath, 'utf-8'));
172
+ } catch {
173
+ return {};
174
+ }
175
+ }
176
+
177
+ /**
178
+ * Save profile config
179
+ */
180
+ export function saveProfile(config: ProfileConfig, profile?: string): void {
181
+ ensureConfigDir();
182
+ const profileName = profile || getCurrentProfile();
183
+ writeFileSync(getProfilePath(profileName), JSON.stringify(config, null, 2));
184
+ }
185
+
186
+ // ============================================
187
+ // API Key Management
188
+ // ============================================
189
+
190
+ export function getApiKey(): string | undefined {
191
+ return process.env.ABLY_API_KEY || loadProfile().apiKey;
192
+ }
193
+
194
+ export function setApiKey(apiKey: string): void {
195
+ const config = loadProfile();
196
+ config.apiKey = apiKey;
197
+ saveProfile(config);
198
+ }
199
+
200
+ export function getApiSecret(): string | undefined {
201
+ return process.env.ABLY_API_SECRET || loadProfile().apiSecret;
202
+ }
203
+
204
+ export function setApiSecret(apiSecret: string): void {
205
+ const config = loadProfile();
206
+ config.apiSecret = apiSecret;
207
+ saveProfile(config);
208
+ }
209
+
210
+ // ============================================
211
+ // Utility Functions
212
+ // ============================================
213
+
214
+ export function clearConfig(): void {
215
+ saveProfile({});
216
+ }
217
+
218
+ export function getConfigDir(): string {
219
+ return CONFIG_DIR;
220
+ }
221
+
222
+ export function getActiveProfileName(): string {
223
+ return getCurrentProfile();
224
+ }
225
+
226
+ // ============================================
227
+ // Token/API Key Alias Functions
228
+ // ============================================
229
+
230
+ /**
231
+ * Get token (alias for getApiKey)
232
+ */
233
+ export function getToken(): string | undefined {
234
+ return process.env.ABLY_TOKEN || process.env.ABLY_API_KEY || loadProfile().token || loadProfile().apiKey;
235
+ }
236
+
237
+ /**
238
+ * Set token (alias for setApiKey)
239
+ */
240
+ export function setToken(token: string): void {
241
+ const config = loadProfile();
242
+ config.token = token;
243
+ config.apiKey = token; // Keep both in sync
244
+ saveProfile(config);
245
+ }
246
+
247
+ // ============================================
248
+ // OAuth2 Configuration Functions
249
+ // ============================================
250
+
251
+ /**
252
+ * Get OAuth2 client configuration
253
+ */
254
+ export function getOAuthConfig(): OAuth2Config | null {
255
+ const profile = loadProfile();
256
+ if (profile.clientId && profile.clientSecret) {
257
+ return {
258
+ clientId: profile.clientId,
259
+ clientSecret: profile.clientSecret,
260
+ };
261
+ }
262
+ return null;
263
+ }
264
+
265
+ /**
266
+ * Set OAuth2 client credentials
267
+ */
268
+ export function setOAuthConfig(config: OAuth2Config): void {
269
+ const profile = loadProfile();
270
+ profile.clientId = config.clientId;
271
+ profile.clientSecret = config.clientSecret;
272
+ saveProfile(profile);
273
+ }
274
+
275
+ /**
276
+ * Load OAuth2 tokens
277
+ */
278
+ export function loadOAuthTokens(): OAuth2Tokens | null {
279
+ const profile = loadProfile();
280
+ if (profile.accessToken) {
281
+ return {
282
+ accessToken: profile.accessToken,
283
+ refreshToken: profile.refreshToken,
284
+ expiresAt: profile.expiresAt || 0,
285
+ tokenType: profile.tokenType,
286
+ scope: profile.scope,
287
+ };
288
+ }
289
+ return null;
290
+ }
291
+
292
+ /**
293
+ * Save OAuth2 tokens
294
+ */
295
+ export function saveOAuthTokens(tokens: OAuth2Tokens): void {
296
+ const profile = loadProfile();
297
+ profile.accessToken = tokens.accessToken;
298
+ profile.refreshToken = tokens.refreshToken;
299
+ profile.expiresAt = tokens.expiresAt;
300
+ profile.tokenType = tokens.tokenType;
301
+ profile.scope = tokens.scope;
302
+ saveProfile(profile);
303
+ }
304
+
305
+ /**
306
+ * Clear OAuth2 tokens (logout)
307
+ */
308
+ export function clearOAuthTokens(): void {
309
+ const profile = loadProfile();
310
+ delete profile.accessToken;
311
+ delete profile.refreshToken;
312
+ delete profile.expiresAt;
313
+ delete profile.tokenType;
314
+ delete profile.scope;
315
+ saveProfile(profile);
316
+ }
317
+
318
+ /**
319
+ * Get the access token (for OAuth2 authentication)
320
+ */
321
+ export function getAccessToken(): string | undefined {
322
+ return loadProfile().accessToken;
323
+ }
@@ -0,0 +1,175 @@
1
+ import chalk from 'chalk';
2
+
3
+ export type OutputFormat = 'json' | 'table' | 'pretty';
4
+
5
+ // Global verbose mode flag
6
+ let verboseMode = false;
7
+
8
+ /**
9
+ * Enable or disable verbose mode
10
+ */
11
+ export function setVerboseMode(enabled: boolean): void {
12
+ verboseMode = enabled;
13
+ }
14
+
15
+ /**
16
+ * Check if verbose mode is enabled
17
+ */
18
+ export function isVerboseMode(): boolean {
19
+ return verboseMode;
20
+ }
21
+
22
+ /**
23
+ * Log a debug message (only shown in verbose mode)
24
+ */
25
+ export function debug(message: string, data?: unknown): void {
26
+ if (!verboseMode) return;
27
+ const timestamp = new Date().toISOString().split('T')[1].slice(0, 12);
28
+ console.log(chalk.gray(`[${timestamp}]`), chalk.dim(message));
29
+ if (data !== undefined) {
30
+ if (typeof data === 'object') {
31
+ console.log(chalk.gray(JSON.stringify(data, null, 2)));
32
+ } else {
33
+ console.log(chalk.gray(String(data)));
34
+ }
35
+ }
36
+ }
37
+
38
+ /**
39
+ * Log a request (only shown in verbose mode)
40
+ */
41
+ export function debugRequest(method: string, url: string, body?: unknown): void {
42
+ if (!verboseMode) return;
43
+ debug(`→ ${method} ${url}`);
44
+ if (body) {
45
+ debug(' Body:', body);
46
+ }
47
+ }
48
+
49
+ /**
50
+ * Log a response (only shown in verbose mode)
51
+ */
52
+ export function debugResponse(status: number, duration: number, body?: unknown): void {
53
+ if (!verboseMode) return;
54
+ const statusColor = status >= 400 ? chalk.red : status >= 300 ? chalk.yellow : chalk.green;
55
+ debug(`← ${statusColor(status)} (${duration}ms)`);
56
+ if (body && verboseMode) {
57
+ debug(' Response:', body);
58
+ }
59
+ }
60
+
61
+ export function formatOutput(data: unknown, format: OutputFormat = 'pretty'): string {
62
+ switch (format) {
63
+ case 'json':
64
+ return JSON.stringify(data, null, 2);
65
+ case 'table':
66
+ return formatAsTable(data);
67
+ case 'pretty':
68
+ default:
69
+ return formatPretty(data);
70
+ }
71
+ }
72
+
73
+ function formatAsTable(data: unknown): string {
74
+ if (!Array.isArray(data)) {
75
+ data = [data];
76
+ }
77
+
78
+ const items = data as Record<string, unknown>[];
79
+ if (items.length === 0) {
80
+ return 'No data';
81
+ }
82
+
83
+ const firstItem = items[0];
84
+ if (!firstItem || typeof firstItem !== 'object') {
85
+ return 'No data';
86
+ }
87
+
88
+ const keys = Object.keys(firstItem);
89
+ const colWidths = keys.map(key => {
90
+ const maxValue = Math.max(
91
+ key.length,
92
+ ...items.map(item => String(item[key] ?? '').length)
93
+ );
94
+ return Math.min(maxValue, 40);
95
+ });
96
+
97
+ const header = keys.map((key, i) => key.padEnd(colWidths[i] ?? 10)).join(' | ');
98
+ const separator = colWidths.map(w => '-'.repeat(w)).join('-+-');
99
+
100
+ const rows = items.map(item =>
101
+ keys.map((key, i) => {
102
+ const value = String(item[key] ?? '');
103
+ const width = colWidths[i] ?? 10;
104
+ return value.length > width
105
+ ? value.substring(0, width - 3) + '...'
106
+ : value.padEnd(width);
107
+ }).join(' | ')
108
+ );
109
+
110
+ return [header, separator, ...rows].join('\n');
111
+ }
112
+
113
+ function formatPretty(data: unknown): string {
114
+ if (Array.isArray(data)) {
115
+ return data.map((item, i) => `${chalk.cyan(`[${i + 1}]`)} ${formatPrettyItem(item)}`).join('\n\n');
116
+ }
117
+ return formatPrettyItem(data);
118
+ }
119
+
120
+ function formatPrettyItem(item: unknown, indent = 0): string {
121
+ if (item === null || item === undefined) {
122
+ return chalk.gray('null');
123
+ }
124
+
125
+ if (typeof item !== 'object') {
126
+ return String(item);
127
+ }
128
+
129
+ const spaces = ' '.repeat(indent);
130
+ const entries = Object.entries(item as Record<string, unknown>);
131
+
132
+ return entries
133
+ .map(([key, value]) => {
134
+ if (Array.isArray(value)) {
135
+ if (value.length === 0) {
136
+ return `${spaces}${chalk.blue(key)}: ${chalk.gray('[]')}`;
137
+ }
138
+ if (typeof value[0] === 'object') {
139
+ return `${spaces}${chalk.blue(key)}:\n${value.map(v => formatPrettyItem(v, indent + 1)).join('\n')}`;
140
+ }
141
+ return `${spaces}${chalk.blue(key)}: ${value.join(', ')}`;
142
+ }
143
+
144
+ if (typeof value === 'object' && value !== null) {
145
+ return `${spaces}${chalk.blue(key)}:\n${formatPrettyItem(value, indent + 1)}`;
146
+ }
147
+
148
+ return `${spaces}${chalk.blue(key)}: ${chalk.white(String(value))}`;
149
+ })
150
+ .join('\n');
151
+ }
152
+
153
+ export function success(message: string): void {
154
+ console.log(chalk.green('✓'), message);
155
+ }
156
+
157
+ export function error(message: string): void {
158
+ console.error(chalk.red('✗'), message);
159
+ }
160
+
161
+ export function warn(message: string): void {
162
+ console.warn(chalk.yellow('⚠'), message);
163
+ }
164
+
165
+ export function info(message: string): void {
166
+ console.log(chalk.blue('ℹ'), message);
167
+ }
168
+
169
+ export function heading(message: string): void {
170
+ console.log(chalk.bold.cyan(`\n${message}\n`));
171
+ }
172
+
173
+ export function print(data: unknown, format: OutputFormat = 'pretty'): void {
174
+ console.log(formatOutput(data, format));
175
+ }