@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,119 @@
1
+ import type { ModalConfig } from '../types';
2
+ import { ModalApiError } from '../types';
3
+
4
+ const DEFAULT_BASE_URL = 'https://api.modal.com/v1';
5
+
6
+ export interface RequestOptions {
7
+ method?: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';
8
+ params?: Record<string, string | number | boolean | undefined>;
9
+ body?: Record<string, unknown> | unknown[] | string;
10
+ headers?: Record<string, string>;
11
+ }
12
+
13
+ export class ModalClient {
14
+ private readonly tokenId: string;
15
+ private readonly tokenSecret: string;
16
+ private readonly baseUrl: string;
17
+
18
+ constructor(config: ModalConfig) {
19
+ if (!config.tokenId || !config.tokenSecret) {
20
+ throw new Error('Token ID and Token Secret are required');
21
+ }
22
+ this.tokenId = config.tokenId;
23
+ this.tokenSecret = config.tokenSecret;
24
+ this.baseUrl = config.baseUrl || DEFAULT_BASE_URL;
25
+ }
26
+
27
+ private buildUrl(path: string, params?: Record<string, string | number | boolean | undefined>): string {
28
+ const url = new URL(`${this.baseUrl}${path}`);
29
+ if (params) {
30
+ Object.entries(params).forEach(([key, value]) => {
31
+ if (value !== undefined && value !== null && value !== '') {
32
+ url.searchParams.append(key, String(value));
33
+ }
34
+ });
35
+ }
36
+ return url.toString();
37
+ }
38
+
39
+ private getAuthHeader(): string {
40
+ const credentials = Buffer.from(`${this.tokenId}:${this.tokenSecret}`).toString('base64');
41
+ return `Basic ${credentials}`;
42
+ }
43
+
44
+ async request<T>(path: string, options: RequestOptions = {}): Promise<T> {
45
+ const { method = 'GET', params, body, headers = {} } = options;
46
+ const url = this.buildUrl(path, params);
47
+
48
+ const requestHeaders: Record<string, string> = {
49
+ 'Authorization': this.getAuthHeader(),
50
+ 'Accept': 'application/json',
51
+ ...headers,
52
+ };
53
+
54
+ if (body && ['POST', 'PUT', 'PATCH'].includes(method)) {
55
+ requestHeaders['Content-Type'] = 'application/json';
56
+ }
57
+
58
+ const fetchOptions: RequestInit = {
59
+ method,
60
+ headers: requestHeaders,
61
+ };
62
+
63
+ if (body && ['POST', 'PUT', 'PATCH'].includes(method)) {
64
+ fetchOptions.body = typeof body === 'string' ? body : JSON.stringify(body);
65
+ }
66
+
67
+ const response = await fetch(url, fetchOptions);
68
+
69
+ if (response.status === 204) {
70
+ return {} as T;
71
+ }
72
+
73
+ let data: unknown;
74
+ const contentType = response.headers.get('content-type') || '';
75
+
76
+ if (contentType.includes('application/json')) {
77
+ const text = await response.text();
78
+ if (text) {
79
+ try {
80
+ data = JSON.parse(text);
81
+ } catch {
82
+ data = text;
83
+ }
84
+ }
85
+ } else {
86
+ data = await response.text();
87
+ }
88
+
89
+ if (!response.ok) {
90
+ let errorMessage = String(data || response.statusText);
91
+ if (typeof data === 'object' && data !== null) {
92
+ const errorObj = data as { error?: string; message?: string; detail?: string };
93
+ errorMessage = errorObj.error || errorObj.message || errorObj.detail || JSON.stringify(data);
94
+ }
95
+ throw new ModalApiError(errorMessage, response.status);
96
+ }
97
+
98
+ return data as T;
99
+ }
100
+
101
+ async get<T>(path: string, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
102
+ return this.request<T>(path, { method: 'GET', params });
103
+ }
104
+
105
+ async post<T>(path: string, body?: Record<string, unknown> | unknown[] | string | object): Promise<T> {
106
+ return this.request<T>(path, { method: 'POST', body: body as Record<string, unknown> });
107
+ }
108
+
109
+ async delete<T>(path: string): Promise<T> {
110
+ return this.request<T>(path, { method: 'DELETE' });
111
+ }
112
+
113
+ getTokenPreview(): string {
114
+ if (this.tokenId.length > 8) {
115
+ return `${this.tokenId.substring(0, 4)}...${this.tokenId.substring(this.tokenId.length - 4)}`;
116
+ }
117
+ return '***';
118
+ }
119
+ }
@@ -0,0 +1,69 @@
1
+ import type {
2
+ ModalConfig,
3
+ WebEndpointRequest,
4
+ WebEndpointResponse,
5
+ AppsListResponse,
6
+ SecretsListResponse
7
+ } from '../types';
8
+ import { ModalClient } from './client';
9
+
10
+ export class Modal {
11
+ private readonly client: ModalClient;
12
+
13
+ constructor(config: ModalConfig) {
14
+ this.client = new ModalClient(config);
15
+ }
16
+
17
+ static fromEnv(): Modal {
18
+ const tokenId = process.env.MODAL_TOKEN_ID;
19
+ const tokenSecret = process.env.MODAL_TOKEN_SECRET;
20
+ if (!tokenId || !tokenSecret) {
21
+ throw new Error('MODAL_TOKEN_ID and MODAL_TOKEN_SECRET environment variables are required');
22
+ }
23
+ return new Modal({ tokenId, tokenSecret });
24
+ }
25
+
26
+ getTokenPreview(): string {
27
+ return this.client.getTokenPreview();
28
+ }
29
+
30
+ async callWebEndpoint(url: string, data?: WebEndpointRequest): Promise<WebEndpointResponse> {
31
+ // Direct call to a Modal web endpoint
32
+ const response = await fetch(url, {
33
+ method: 'POST',
34
+ headers: {
35
+ 'Content-Type': 'application/json',
36
+ },
37
+ body: data ? JSON.stringify(data) : undefined,
38
+ });
39
+
40
+ if (!response.ok) {
41
+ const text = await response.text();
42
+ throw new Error(`Web endpoint error: ${response.status} - ${text}`);
43
+ }
44
+
45
+ return response.json();
46
+ }
47
+
48
+ async listApps(): Promise<AppsListResponse> {
49
+ return this.client.get<AppsListResponse>('/apps');
50
+ }
51
+
52
+ async listSecrets(): Promise<SecretsListResponse> {
53
+ return this.client.get<SecretsListResponse>('/secrets');
54
+ }
55
+
56
+ async createSecret(name: string, values: Record<string, string>): Promise<void> {
57
+ await this.client.post('/secrets', { name, values });
58
+ }
59
+
60
+ async deleteSecret(name: string): Promise<void> {
61
+ await this.client.delete(`/secrets/${name}`);
62
+ }
63
+
64
+ getClient(): ModalClient {
65
+ return this.client;
66
+ }
67
+ }
68
+
69
+ export { ModalClient } from './client';
@@ -0,0 +1,224 @@
1
+ #!/usr/bin/env bun
2
+ import { Command } from 'commander';
3
+ import chalk from 'chalk';
4
+ import { Modal } from '../api';
5
+ import {
6
+ getTokenId, getTokenSecret, setTokenId, setTokenSecret, clearConfig, getConfigDir, setProfileOverride,
7
+ getCurrentProfile, setCurrentProfile, listProfiles, createProfile,
8
+ deleteProfile, profileExists, loadProfile,
9
+ } from '../utils/config';
10
+ import type { OutputFormat } from '../utils/output';
11
+ import { success, error, info, print } from '../utils/output';
12
+
13
+ const CONNECTOR_NAME = 'connect-modal';
14
+ const VERSION = '0.0.1';
15
+
16
+ const program = new Command();
17
+
18
+ program
19
+ .name(CONNECTOR_NAME)
20
+ .description('Modal connector CLI - Serverless cloud functions')
21
+ .version(VERSION)
22
+ .option('-f, --format <format>', 'Output format (json, pretty)', 'pretty')
23
+ .option('-p, --profile <profile>', 'Use a specific profile')
24
+ .hook('preAction', (thisCommand) => {
25
+ const opts = thisCommand.opts();
26
+ if (opts.profile) {
27
+ if (!profileExists(opts.profile)) {
28
+ error(`Profile "${opts.profile}" does not exist`);
29
+ process.exit(1);
30
+ }
31
+ setProfileOverride(opts.profile);
32
+ }
33
+ });
34
+
35
+ function getFormat(cmd: Command): OutputFormat {
36
+ const parent = cmd.parent;
37
+ return (parent?.opts().format || 'pretty') as OutputFormat;
38
+ }
39
+
40
+ function getClient(): Modal {
41
+ const tokenId = getTokenId();
42
+ const tokenSecret = getTokenSecret();
43
+ if (!tokenId || !tokenSecret) {
44
+ error(`No credentials configured. Run "${CONNECTOR_NAME} config set-token" or set MODAL_TOKEN_ID and MODAL_TOKEN_SECRET`);
45
+ process.exit(1);
46
+ }
47
+ return new Modal({ tokenId, tokenSecret });
48
+ }
49
+
50
+ // Profile Commands
51
+ const profileCmd = program.command('profile').description('Manage profiles');
52
+
53
+ profileCmd.command('list').description('List profiles').action(() => {
54
+ const profiles = listProfiles();
55
+ const current = getCurrentProfile();
56
+ if (profiles.length === 0) { info('No profiles found'); return; }
57
+ profiles.forEach(p => {
58
+ console.log(` ${p}${p === current ? chalk.green(' (active)') : ''}`);
59
+ });
60
+ });
61
+
62
+ profileCmd.command('use <name>').description('Switch profile').action((name: string) => {
63
+ if (!profileExists(name)) { error(`Profile "${name}" does not exist`); process.exit(1); }
64
+ setCurrentProfile(name);
65
+ success(`Switched to profile: ${name}`);
66
+ });
67
+
68
+ profileCmd.command('create <name>').description('Create profile')
69
+ .option('--token-id <id>', 'Token ID')
70
+ .option('--token-secret <secret>', 'Token Secret')
71
+ .option('--use', 'Switch to this profile')
72
+ .action((name: string, opts) => {
73
+ if (profileExists(name)) { error(`Profile "${name}" already exists`); process.exit(1); }
74
+ createProfile(name, { tokenId: opts.tokenId, tokenSecret: opts.tokenSecret });
75
+ success(`Profile "${name}" created`);
76
+ if (opts.use) { setCurrentProfile(name); info(`Switched to profile: ${name}`); }
77
+ });
78
+
79
+ profileCmd.command('delete <name>').description('Delete profile').action((name: string) => {
80
+ if (name === 'default') { error('Cannot delete default profile'); process.exit(1); }
81
+ if (deleteProfile(name)) { success(`Profile "${name}" deleted`); }
82
+ else { error(`Profile "${name}" not found`); process.exit(1); }
83
+ });
84
+
85
+ profileCmd.command('show [name]').description('Show profile').action((name?: string) => {
86
+ const profileName = name || getCurrentProfile();
87
+ const config = loadProfile(profileName);
88
+ console.log(chalk.bold(`Profile: ${profileName}`));
89
+ info(`Token ID: ${config.tokenId ? config.tokenId.substring(0, 8) + '...' : chalk.gray('not set')}`);
90
+ info(`Token Secret: ${config.tokenSecret ? '********' : chalk.gray('not set')}`);
91
+ });
92
+
93
+ // Config Commands
94
+ const configCmd = program.command('config').description('Manage configuration');
95
+
96
+ configCmd.command('set-token')
97
+ .description('Set Modal tokens')
98
+ .requiredOption('--id <tokenId>', 'Token ID')
99
+ .requiredOption('--secret <tokenSecret>', 'Token Secret')
100
+ .action((opts) => {
101
+ setTokenId(opts.id);
102
+ setTokenSecret(opts.secret);
103
+ success(`Tokens saved`);
104
+ });
105
+
106
+ configCmd.command('show').description('Show config').action(() => {
107
+ console.log(chalk.bold(`Profile: ${getCurrentProfile()}`));
108
+ info(`Config dir: ${getConfigDir()}`);
109
+ const tokenId = getTokenId();
110
+ info(`Token ID: ${tokenId ? tokenId.substring(0, 8) + '...' : chalk.gray('not set')}`);
111
+ info(`Token Secret: ${getTokenSecret() ? '********' : chalk.gray('not set')}`);
112
+ });
113
+
114
+ configCmd.command('clear').description('Clear config').action(() => {
115
+ clearConfig();
116
+ success('Config cleared');
117
+ });
118
+
119
+ // Web Endpoint Command
120
+ program.command('call <url>')
121
+ .description('Call a Modal web endpoint')
122
+ .option('-d, --data <json>', 'Request data as JSON')
123
+ .action(async (url: string, opts) => {
124
+ try {
125
+ const client = getClient();
126
+ const data = opts.data ? JSON.parse(opts.data) : undefined;
127
+ const result = await client.callWebEndpoint(url, data);
128
+ if (getFormat(program) === 'json') {
129
+ print(result, 'json');
130
+ } else {
131
+ console.log(chalk.green('\nResponse:'));
132
+ console.log(JSON.stringify(result, null, 2));
133
+ }
134
+ } catch (err) {
135
+ error(String(err));
136
+ process.exit(1);
137
+ }
138
+ });
139
+
140
+ // Apps Commands
141
+ const appsCmd = program.command('apps').description('Manage apps');
142
+
143
+ appsCmd.command('list')
144
+ .description('List apps')
145
+ .action(async () => {
146
+ try {
147
+ const client = getClient();
148
+ const result = await client.listApps();
149
+ if (getFormat(appsCmd) === 'json') {
150
+ print(result.apps, 'json');
151
+ } else {
152
+ if (result.apps.length === 0) {
153
+ info('No apps found');
154
+ return;
155
+ }
156
+ result.apps.forEach(app => {
157
+ console.log(chalk.cyan(`\n${app.name}`));
158
+ console.log(` ID: ${app.app_id}`);
159
+ console.log(` State: ${app.state}`);
160
+ console.log(` Created: ${app.created_at}`);
161
+ });
162
+ }
163
+ } catch (err) {
164
+ error(String(err));
165
+ process.exit(1);
166
+ }
167
+ });
168
+
169
+ // Secrets Commands
170
+ const secretsCmd = program.command('secrets').description('Manage secrets');
171
+
172
+ secretsCmd.command('list')
173
+ .description('List secrets')
174
+ .action(async () => {
175
+ try {
176
+ const client = getClient();
177
+ const result = await client.listSecrets();
178
+ if (getFormat(secretsCmd) === 'json') {
179
+ print(result.secrets, 'json');
180
+ } else {
181
+ if (result.secrets.length === 0) {
182
+ info('No secrets found');
183
+ return;
184
+ }
185
+ result.secrets.forEach(secret => {
186
+ console.log(chalk.cyan(`\n${secret.name}`));
187
+ console.log(` Created: ${secret.created_at}`);
188
+ });
189
+ }
190
+ } catch (err) {
191
+ error(String(err));
192
+ process.exit(1);
193
+ }
194
+ });
195
+
196
+ secretsCmd.command('create <name>')
197
+ .description('Create a secret')
198
+ .requiredOption('-v, --values <json>', 'Secret values as JSON')
199
+ .action(async (name: string, opts) => {
200
+ try {
201
+ const client = getClient();
202
+ const values = JSON.parse(opts.values);
203
+ await client.createSecret(name, values);
204
+ success(`Secret "${name}" created`);
205
+ } catch (err) {
206
+ error(String(err));
207
+ process.exit(1);
208
+ }
209
+ });
210
+
211
+ secretsCmd.command('delete <name>')
212
+ .description('Delete a secret')
213
+ .action(async (name: string) => {
214
+ try {
215
+ const client = getClient();
216
+ await client.deleteSecret(name);
217
+ success(`Secret "${name}" deleted`);
218
+ } catch (err) {
219
+ error(String(err));
220
+ process.exit(1);
221
+ }
222
+ });
223
+
224
+ program.parse();
@@ -0,0 +1,21 @@
1
+ // Modal Connector
2
+ // TypeScript wrapper for Modal API
3
+
4
+ export { Modal } from './api';
5
+ export * from './types';
6
+ export { ModalClient } from './api';
7
+
8
+ export {
9
+ getTokenId,
10
+ setTokenId,
11
+ getTokenSecret,
12
+ setTokenSecret,
13
+ getCurrentProfile,
14
+ setCurrentProfile,
15
+ listProfiles,
16
+ createProfile,
17
+ deleteProfile,
18
+ loadProfile,
19
+ saveProfile,
20
+ clearConfig,
21
+ } from './utils/config';
@@ -0,0 +1,60 @@
1
+ // Modal API Types
2
+
3
+ export interface ModalConfig {
4
+ tokenId: string;
5
+ tokenSecret: string;
6
+ baseUrl?: string;
7
+ }
8
+
9
+ // Web Endpoint Types
10
+ export interface WebEndpointRequest {
11
+ [key: string]: unknown;
12
+ }
13
+
14
+ export interface WebEndpointResponse {
15
+ [key: string]: unknown;
16
+ }
17
+
18
+ // App Types
19
+ export interface ModalApp {
20
+ app_id: string;
21
+ name: string;
22
+ state: string;
23
+ created_at: string;
24
+ updated_at?: string;
25
+ }
26
+
27
+ export interface AppsListResponse {
28
+ apps: ModalApp[];
29
+ }
30
+
31
+ // Function Types
32
+ export interface ModalFunction {
33
+ function_id: string;
34
+ name: string;
35
+ app_id: string;
36
+ created_at: string;
37
+ }
38
+
39
+ // Secret Types
40
+ export interface ModalSecret {
41
+ name: string;
42
+ created_at: string;
43
+ updated_at?: string;
44
+ }
45
+
46
+ export interface SecretsListResponse {
47
+ secrets: ModalSecret[];
48
+ }
49
+
50
+ // Error Types
51
+ export class ModalApiError extends Error {
52
+ constructor(
53
+ message: string,
54
+ public readonly status: number,
55
+ public readonly detail?: string
56
+ ) {
57
+ super(message);
58
+ this.name = 'ModalApiError';
59
+ }
60
+ }
@@ -0,0 +1,114 @@
1
+ import { existsSync, readFileSync, writeFileSync, mkdirSync, readdirSync, rmSync } from 'fs';
2
+ import { homedir } from 'os';
3
+ import { join } from 'path';
4
+
5
+ const CONNECTOR_NAME = 'connect-modal';
6
+ const DEFAULT_PROFILE = 'default';
7
+
8
+ export interface ProfileConfig {
9
+ tokenId?: string;
10
+ tokenSecret?: string;
11
+ }
12
+
13
+ let profileOverride: string | undefined;
14
+
15
+ const CONFIG_DIR = join(homedir(), '.connect', CONNECTOR_NAME);
16
+ const PROFILES_DIR = join(CONFIG_DIR, 'profiles');
17
+ const CURRENT_PROFILE_FILE = join(CONFIG_DIR, 'current_profile');
18
+
19
+ export function setProfileOverride(profile: string | undefined): void {
20
+ profileOverride = profile;
21
+ }
22
+
23
+ export function ensureConfigDir(): void {
24
+ if (!existsSync(CONFIG_DIR)) mkdirSync(CONFIG_DIR, { recursive: true });
25
+ if (!existsSync(PROFILES_DIR)) mkdirSync(PROFILES_DIR, { recursive: true });
26
+ }
27
+
28
+ function getProfilePath(profile: string): string {
29
+ return join(PROFILES_DIR, `${profile}.json`);
30
+ }
31
+
32
+ export function getCurrentProfile(): string {
33
+ if (profileOverride) return profileOverride;
34
+ ensureConfigDir();
35
+ if (existsSync(CURRENT_PROFILE_FILE)) {
36
+ try {
37
+ const profile = readFileSync(CURRENT_PROFILE_FILE, 'utf-8').trim();
38
+ if (profile && profileExists(profile)) return profile;
39
+ } catch { /* fall through */ }
40
+ }
41
+ return DEFAULT_PROFILE;
42
+ }
43
+
44
+ export function setCurrentProfile(profile: string): void {
45
+ ensureConfigDir();
46
+ if (!profileExists(profile) && profile !== DEFAULT_PROFILE) {
47
+ throw new Error(`Profile "${profile}" does not exist`);
48
+ }
49
+ writeFileSync(CURRENT_PROFILE_FILE, profile);
50
+ }
51
+
52
+ export function profileExists(profile: string): boolean {
53
+ return existsSync(getProfilePath(profile));
54
+ }
55
+
56
+ export function listProfiles(): string[] {
57
+ ensureConfigDir();
58
+ if (!existsSync(PROFILES_DIR)) return [];
59
+ return readdirSync(PROFILES_DIR).filter(f => f.endsWith('.json')).map(f => f.replace('.json', '')).sort();
60
+ }
61
+
62
+ export function createProfile(profile: string, config: ProfileConfig = {}): boolean {
63
+ ensureConfigDir();
64
+ if (profileExists(profile)) return false;
65
+ if (!/^[a-zA-Z0-9_-]+$/.test(profile)) {
66
+ throw new Error('Profile name can only contain letters, numbers, hyphens, and underscores');
67
+ }
68
+ writeFileSync(getProfilePath(profile), JSON.stringify(config, null, 2));
69
+ return true;
70
+ }
71
+
72
+ export function deleteProfile(profile: string): boolean {
73
+ if (profile === DEFAULT_PROFILE) return false;
74
+ if (!profileExists(profile)) return false;
75
+ if (getCurrentProfile() === profile) setCurrentProfile(DEFAULT_PROFILE);
76
+ rmSync(getProfilePath(profile));
77
+ return true;
78
+ }
79
+
80
+ export function loadProfile(profile?: string): ProfileConfig {
81
+ ensureConfigDir();
82
+ const profilePath = getProfilePath(profile || getCurrentProfile());
83
+ if (!existsSync(profilePath)) return {};
84
+ try { return JSON.parse(readFileSync(profilePath, 'utf-8')); } catch { return {}; }
85
+ }
86
+
87
+ export function saveProfile(config: ProfileConfig, profile?: string): void {
88
+ ensureConfigDir();
89
+ writeFileSync(getProfilePath(profile || getCurrentProfile()), JSON.stringify(config, null, 2));
90
+ }
91
+
92
+ export function getTokenId(): string | undefined {
93
+ return process.env.MODAL_TOKEN_ID || loadProfile().tokenId;
94
+ }
95
+
96
+ export function setTokenId(tokenId: string): void {
97
+ const config = loadProfile();
98
+ config.tokenId = tokenId;
99
+ saveProfile(config);
100
+ }
101
+
102
+ export function getTokenSecret(): string | undefined {
103
+ return process.env.MODAL_TOKEN_SECRET || loadProfile().tokenSecret;
104
+ }
105
+
106
+ export function setTokenSecret(tokenSecret: string): void {
107
+ const config = loadProfile();
108
+ config.tokenSecret = tokenSecret;
109
+ saveProfile(config);
110
+ }
111
+
112
+ export function clearConfig(): void { saveProfile({}); }
113
+ export function getConfigDir(): string { return CONFIG_DIR; }
114
+ export function getActiveProfileName(): string { return getCurrentProfile(); }