@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 { PerplexityConfig, OutputFormat } from '../types';
2
+ import { PerplexityApiError } from '../types';
3
+
4
+ const DEFAULT_BASE_URL = 'https://api.perplexity.ai';
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
+ format?: OutputFormat;
12
+ }
13
+
14
+ export class PerplexityClient {
15
+ private readonly apiKey: string;
16
+ private readonly baseUrl: string;
17
+
18
+ constructor(config: PerplexityConfig) {
19
+ if (!config.apiKey) {
20
+ throw new Error('API key is required');
21
+ }
22
+ this.apiKey = config.apiKey;
23
+ this.baseUrl = config.baseUrl || DEFAULT_BASE_URL;
24
+ }
25
+
26
+ private buildUrl(path: string, params?: Record<string, string | number | boolean | undefined>): string {
27
+ const url = new URL(`${this.baseUrl}${path}`);
28
+
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
+
37
+ return url.toString();
38
+ }
39
+
40
+ /**
41
+ * Make an authenticated request to the Perplexity API
42
+ */
43
+ async request<T>(path: string, options: RequestOptions = {}): Promise<T> {
44
+ const { method = 'GET', params, body, headers = {} } = options;
45
+
46
+ const url = this.buildUrl(path, params);
47
+
48
+ const requestHeaders: Record<string, string> = {
49
+ 'Authorization': `Bearer ${this.apiKey}`,
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
+ // Handle 204 No Content
70
+ if (response.status === 204) {
71
+ return {} as T;
72
+ }
73
+
74
+ // Parse response
75
+ let data: unknown;
76
+ const contentType = response.headers.get('content-type') || '';
77
+
78
+ if (contentType.includes('application/json')) {
79
+ const text = await response.text();
80
+ if (text) {
81
+ try {
82
+ data = JSON.parse(text);
83
+ } catch {
84
+ data = text;
85
+ }
86
+ }
87
+ } else {
88
+ data = await response.text();
89
+ }
90
+
91
+ // Handle errors
92
+ if (!response.ok) {
93
+ const errorMessage = typeof data === 'object' && data !== null
94
+ ? JSON.stringify(data)
95
+ : String(data || response.statusText);
96
+ throw new PerplexityApiError(errorMessage, response.status);
97
+ }
98
+
99
+ return data as T;
100
+ }
101
+
102
+ async get<T>(path: string, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
103
+ return this.request<T>(path, { method: 'GET', params });
104
+ }
105
+
106
+ async post<T>(path: string, body?: Record<string, unknown> | unknown[] | string | object, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
107
+ return this.request<T>(path, { method: 'POST', body: body as Record<string, unknown>, params });
108
+ }
109
+
110
+ /**
111
+ * Get a preview of the API key (for display/debugging)
112
+ */
113
+ getApiKeyPreview(): string {
114
+ if (this.apiKey.length > 10) {
115
+ return `${this.apiKey.substring(0, 6)}...${this.apiKey.substring(this.apiKey.length - 4)}`;
116
+ }
117
+ return '***';
118
+ }
119
+ }
@@ -0,0 +1,118 @@
1
+ import type { PerplexityClient } from './client';
2
+ import type {
3
+ ChatCompletionRequest,
4
+ ChatCompletionResponse,
5
+ ChatMessage,
6
+ PerplexityModel,
7
+ } from '../types';
8
+
9
+ export interface ChatOptions {
10
+ model?: PerplexityModel;
11
+ maxTokens?: number;
12
+ temperature?: number;
13
+ topP?: number;
14
+ topK?: number;
15
+ presencePenalty?: number;
16
+ frequencyPenalty?: number;
17
+ searchDomainFilter?: string[];
18
+ returnImages?: boolean;
19
+ returnRelatedQuestions?: boolean;
20
+ searchRecencyFilter?: 'month' | 'week' | 'day' | 'hour';
21
+ systemPrompt?: string;
22
+ }
23
+
24
+ /**
25
+ * Chat Completions API
26
+ */
27
+ export class ChatApi {
28
+ constructor(private readonly client: PerplexityClient) {}
29
+
30
+ /**
31
+ * Create a chat completion
32
+ */
33
+ async create(
34
+ messages: ChatMessage[],
35
+ options: ChatOptions = {}
36
+ ): Promise<ChatCompletionResponse> {
37
+ const request: ChatCompletionRequest = {
38
+ model: options.model || 'sonar',
39
+ messages,
40
+ stream: false,
41
+ };
42
+
43
+ if (options.maxTokens !== undefined) request.max_tokens = options.maxTokens;
44
+ if (options.temperature !== undefined) request.temperature = options.temperature;
45
+ if (options.topP !== undefined) request.top_p = options.topP;
46
+ if (options.topK !== undefined) request.top_k = options.topK;
47
+ if (options.presencePenalty !== undefined) request.presence_penalty = options.presencePenalty;
48
+ if (options.frequencyPenalty !== undefined) request.frequency_penalty = options.frequencyPenalty;
49
+ if (options.searchDomainFilter !== undefined) request.search_domain_filter = options.searchDomainFilter;
50
+ if (options.returnImages !== undefined) request.return_images = options.returnImages;
51
+ if (options.returnRelatedQuestions !== undefined) request.return_related_questions = options.returnRelatedQuestions;
52
+ if (options.searchRecencyFilter !== undefined) request.search_recency_filter = options.searchRecencyFilter;
53
+
54
+ return this.client.post<ChatCompletionResponse>('/chat/completions', request);
55
+ }
56
+
57
+ /**
58
+ * Simple ask method - send a single question and get an answer
59
+ */
60
+ async ask(
61
+ question: string,
62
+ options: ChatOptions = {}
63
+ ): Promise<ChatCompletionResponse> {
64
+ const messages: ChatMessage[] = [];
65
+
66
+ if (options.systemPrompt) {
67
+ messages.push({ role: 'system', content: options.systemPrompt });
68
+ }
69
+
70
+ messages.push({ role: 'user', content: question });
71
+
72
+ return this.create(messages, options);
73
+ }
74
+
75
+ /**
76
+ * Search the web and get an answer grounded in search results
77
+ */
78
+ async search(
79
+ query: string,
80
+ options: Omit<ChatOptions, 'systemPrompt'> & { recency?: 'month' | 'week' | 'day' | 'hour' } = {}
81
+ ): Promise<ChatCompletionResponse> {
82
+ const { recency, ...restOptions } = options;
83
+
84
+ return this.ask(query, {
85
+ ...restOptions,
86
+ searchRecencyFilter: recency,
87
+ systemPrompt: 'You are a helpful search assistant. Provide accurate, well-researched answers based on the most recent and relevant information available.',
88
+ });
89
+ }
90
+
91
+ /**
92
+ * Deep research on a topic
93
+ */
94
+ async research(
95
+ topic: string,
96
+ options: Omit<ChatOptions, 'model' | 'systemPrompt'> = {}
97
+ ): Promise<ChatCompletionResponse> {
98
+ return this.ask(topic, {
99
+ ...options,
100
+ model: 'sonar-deep-research',
101
+ systemPrompt: 'You are a research assistant. Provide comprehensive, well-cited analysis on the given topic.',
102
+ });
103
+ }
104
+
105
+ /**
106
+ * Reasoning task
107
+ */
108
+ async reason(
109
+ prompt: string,
110
+ options: Omit<ChatOptions, 'model' | 'systemPrompt'> = {}
111
+ ): Promise<ChatCompletionResponse> {
112
+ return this.ask(prompt, {
113
+ ...options,
114
+ model: 'sonar-reasoning-pro',
115
+ systemPrompt: 'You are a logical reasoning assistant. Think through problems step by step and provide well-reasoned answers.',
116
+ });
117
+ }
118
+ }
@@ -0,0 +1,48 @@
1
+ import type { PerplexityConfig } from '../types';
2
+ import { PerplexityClient } from './client';
3
+ import { ChatApi } from './example';
4
+
5
+ /**
6
+ * Perplexity AI API Client
7
+ */
8
+ export class Perplexity {
9
+ private readonly client: PerplexityClient;
10
+
11
+ // API modules
12
+ public readonly chat: ChatApi;
13
+
14
+ constructor(config: PerplexityConfig) {
15
+ this.client = new PerplexityClient(config);
16
+ this.chat = new ChatApi(this.client);
17
+ }
18
+
19
+ /**
20
+ * Create a client from environment variables
21
+ * Looks for PERPLEXITY_API_KEY
22
+ */
23
+ static fromEnv(): Perplexity {
24
+ const apiKey = process.env.PERPLEXITY_API_KEY;
25
+
26
+ if (!apiKey) {
27
+ throw new Error('PERPLEXITY_API_KEY environment variable is required');
28
+ }
29
+ return new Perplexity({ apiKey });
30
+ }
31
+
32
+ /**
33
+ * Get a preview of the API key (for debugging)
34
+ */
35
+ getApiKeyPreview(): string {
36
+ return this.client.getApiKeyPreview();
37
+ }
38
+
39
+ /**
40
+ * Get the underlying client for direct API access
41
+ */
42
+ getClient(): PerplexityClient {
43
+ return this.client;
44
+ }
45
+ }
46
+
47
+ export { PerplexityClient } from './client';
48
+ export { ChatApi } from './example';
@@ -0,0 +1,421 @@
1
+ #!/usr/bin/env bun
2
+ import { Command } from 'commander';
3
+ import chalk from 'chalk';
4
+ import { Perplexity } from '../api';
5
+ import { PERPLEXITY_MODELS } from '../types';
6
+ import type { PerplexityModel } from '../types';
7
+ import {
8
+ getApiKey,
9
+ setApiKey,
10
+ clearConfig,
11
+ getConfigDir,
12
+ setProfileOverride,
13
+ getCurrentProfile,
14
+ setCurrentProfile,
15
+ listProfiles,
16
+ createProfile,
17
+ deleteProfile,
18
+ profileExists,
19
+ loadProfile,
20
+ getDefaultModel,
21
+ setDefaultModel,
22
+ } from '../utils/config';
23
+ import type { OutputFormat } from '../utils/output';
24
+ import { success, error, info, print, warn } from '../utils/output';
25
+
26
+ const CONNECTOR_NAME = 'connect-perplexity';
27
+ const VERSION = '0.1.0';
28
+
29
+ const program = new Command();
30
+
31
+ program
32
+ .name(CONNECTOR_NAME)
33
+ .description('Perplexity AI API connector - Chat completions with web search grounding')
34
+ .version(VERSION)
35
+ .option('-k, --api-key <key>', 'API key (overrides config)')
36
+ .option('-f, --format <format>', 'Output format (json, pretty)', 'pretty')
37
+ .option('-p, --profile <profile>', 'Use a specific profile')
38
+ .hook('preAction', (thisCommand) => {
39
+ const opts = thisCommand.opts();
40
+ // Set profile override before any command runs
41
+ if (opts.profile) {
42
+ if (!profileExists(opts.profile)) {
43
+ error(`Profile "${opts.profile}" does not exist. Create it with "${CONNECTOR_NAME} profile create ${opts.profile}"`);
44
+ process.exit(1);
45
+ }
46
+ setProfileOverride(opts.profile);
47
+ }
48
+ // Set API key from flag if provided
49
+ if (opts.apiKey) {
50
+ process.env.PERPLEXITY_API_KEY = opts.apiKey;
51
+ }
52
+ });
53
+
54
+ // Helper to get output format
55
+ function getFormat(cmd: Command): OutputFormat {
56
+ const parent = cmd.parent;
57
+ return (parent?.opts().format || 'pretty') as OutputFormat;
58
+ }
59
+
60
+ // Helper to get authenticated client
61
+ function getClient(): Perplexity {
62
+ const apiKey = getApiKey();
63
+ if (!apiKey) {
64
+ error(`No API key configured. Run "${CONNECTOR_NAME} config set-key <key>" or set PERPLEXITY_API_KEY environment variable.`);
65
+ process.exit(1);
66
+ }
67
+ return new Perplexity({ apiKey });
68
+ }
69
+
70
+ // ============================================
71
+ // Profile Commands
72
+ // ============================================
73
+ const profileCmd = program
74
+ .command('profile')
75
+ .description('Manage configuration profiles');
76
+
77
+ profileCmd
78
+ .command('list')
79
+ .description('List all profiles')
80
+ .action(() => {
81
+ const profiles = listProfiles();
82
+ const current = getCurrentProfile();
83
+
84
+ if (profiles.length === 0) {
85
+ info('No profiles found. Use "profile create <name>" to create one.');
86
+ return;
87
+ }
88
+
89
+ success(`Profiles:`);
90
+ profiles.forEach(p => {
91
+ const isActive = p === current ? chalk.green(' (active)') : '';
92
+ console.log(` ${p}${isActive}`);
93
+ });
94
+ });
95
+
96
+ profileCmd
97
+ .command('use <name>')
98
+ .description('Switch to a profile')
99
+ .action((name: string) => {
100
+ if (!profileExists(name)) {
101
+ error(`Profile "${name}" does not exist. Create it with "profile create ${name}"`);
102
+ process.exit(1);
103
+ }
104
+ setCurrentProfile(name);
105
+ success(`Switched to profile: ${name}`);
106
+ });
107
+
108
+ profileCmd
109
+ .command('create <name>')
110
+ .description('Create a new profile')
111
+ .option('--api-key <key>', 'API key')
112
+ .option('--use', 'Switch to this profile after creation')
113
+ .action((name: string, opts) => {
114
+ if (profileExists(name)) {
115
+ error(`Profile "${name}" already exists`);
116
+ process.exit(1);
117
+ }
118
+
119
+ createProfile(name, {
120
+ apiKey: opts.apiKey,
121
+ });
122
+ success(`Profile "${name}" created`);
123
+
124
+ if (opts.use) {
125
+ setCurrentProfile(name);
126
+ info(`Switched to profile: ${name}`);
127
+ }
128
+ });
129
+
130
+ profileCmd
131
+ .command('delete <name>')
132
+ .description('Delete a profile')
133
+ .action((name: string) => {
134
+ if (name === 'default') {
135
+ error('Cannot delete the default profile');
136
+ process.exit(1);
137
+ }
138
+ if (deleteProfile(name)) {
139
+ success(`Profile "${name}" deleted`);
140
+ } else {
141
+ error(`Profile "${name}" not found`);
142
+ process.exit(1);
143
+ }
144
+ });
145
+
146
+ profileCmd
147
+ .command('show [name]')
148
+ .description('Show profile configuration')
149
+ .action((name?: string) => {
150
+ const profileName = name || getCurrentProfile();
151
+ const config = loadProfile(profileName);
152
+ const active = getCurrentProfile();
153
+
154
+ console.log(chalk.bold(`Profile: ${profileName}${profileName === active ? chalk.green(' (active)') : ''}`));
155
+ info(`API Key: ${config.apiKey ? `${config.apiKey.substring(0, 8)}...` : chalk.gray('not set')}`);
156
+ info(`Default Model: ${config.defaultModel || chalk.gray('sonar')}`);
157
+ });
158
+
159
+ // ============================================
160
+ // Config Commands
161
+ // ============================================
162
+ const configCmd = program
163
+ .command('config')
164
+ .description('Manage CLI configuration (for active profile)');
165
+
166
+ configCmd
167
+ .command('set-key <apiKey>')
168
+ .description('Set API key')
169
+ .action((apiKey: string) => {
170
+ setApiKey(apiKey);
171
+ success(`API key saved to profile: ${getCurrentProfile()}`);
172
+ });
173
+
174
+ configCmd
175
+ .command('set-model <model>')
176
+ .description('Set default model')
177
+ .action((model: string) => {
178
+ if (!PERPLEXITY_MODELS.includes(model as PerplexityModel)) {
179
+ error(`Invalid model. Available models: ${PERPLEXITY_MODELS.join(', ')}`);
180
+ process.exit(1);
181
+ }
182
+ setDefaultModel(model);
183
+ success(`Default model set to: ${model}`);
184
+ });
185
+
186
+ configCmd
187
+ .command('show')
188
+ .description('Show current configuration')
189
+ .action(() => {
190
+ const profileName = getCurrentProfile();
191
+ const apiKey = getApiKey();
192
+ const model = getDefaultModel();
193
+
194
+ console.log(chalk.bold(`Active Profile: ${profileName}`));
195
+ info(`Config directory: ${getConfigDir()}`);
196
+ info(`API Key: ${apiKey ? `${apiKey.substring(0, 8)}...` : chalk.gray('not set')}`);
197
+ info(`Default Model: ${model || chalk.gray('sonar')}`);
198
+ });
199
+
200
+ configCmd
201
+ .command('clear')
202
+ .description('Clear configuration for active profile')
203
+ .action(() => {
204
+ clearConfig();
205
+ success(`Configuration cleared for profile: ${getCurrentProfile()}`);
206
+ });
207
+
208
+ // ============================================
209
+ // Chat Commands
210
+ // ============================================
211
+ const chatCmd = program
212
+ .command('chat')
213
+ .description('Chat completion commands');
214
+
215
+ chatCmd
216
+ .command('ask <question>')
217
+ .description('Ask a question')
218
+ .option('-m, --model <model>', `Model to use (${PERPLEXITY_MODELS.join(', ')})`, getDefaultModel() || 'sonar')
219
+ .option('-t, --temperature <temp>', 'Temperature (0-2)', '0.7')
220
+ .option('--max-tokens <tokens>', 'Maximum tokens')
221
+ .option('-s, --system <prompt>', 'System prompt')
222
+ .option('--recency <filter>', 'Search recency filter (hour, day, week, month)')
223
+ .action(async (question: string, opts) => {
224
+ try {
225
+ const client = getClient();
226
+ const response = await client.chat.ask(question, {
227
+ model: opts.model as PerplexityModel,
228
+ temperature: parseFloat(opts.temperature),
229
+ maxTokens: opts.maxTokens ? parseInt(opts.maxTokens) : undefined,
230
+ systemPrompt: opts.system,
231
+ searchRecencyFilter: opts.recency,
232
+ });
233
+
234
+ const format = getFormat(chatCmd);
235
+ if (format === 'json') {
236
+ print(response, format);
237
+ } else {
238
+ // Pretty print the response
239
+ const content = response.choices[0]?.message?.content || '';
240
+ console.log(chalk.cyan('\nAnswer:\n'));
241
+ console.log(content);
242
+
243
+ if (response.citations && response.citations.length > 0) {
244
+ console.log(chalk.cyan('\nCitations:'));
245
+ response.citations.forEach((citation, i) => {
246
+ console.log(chalk.gray(` [${i + 1}] ${citation}`));
247
+ });
248
+ }
249
+
250
+ console.log(chalk.gray(`\n(${response.usage.total_tokens} tokens, model: ${response.model})`));
251
+ }
252
+ } catch (err) {
253
+ error(String(err));
254
+ process.exit(1);
255
+ }
256
+ });
257
+
258
+ chatCmd
259
+ .command('search <query>')
260
+ .description('Search the web and get an answer')
261
+ .option('-m, --model <model>', `Model to use`, 'sonar-pro')
262
+ .option('--recency <filter>', 'Search recency filter (hour, day, week, month)')
263
+ .action(async (query: string, opts) => {
264
+ try {
265
+ const client = getClient();
266
+ const response = await client.chat.search(query, {
267
+ model: opts.model as PerplexityModel,
268
+ recency: opts.recency,
269
+ });
270
+
271
+ const format = getFormat(chatCmd);
272
+ if (format === 'json') {
273
+ print(response, format);
274
+ } else {
275
+ const content = response.choices[0]?.message?.content || '';
276
+ console.log(chalk.cyan('\nSearch Results:\n'));
277
+ console.log(content);
278
+
279
+ if (response.citations && response.citations.length > 0) {
280
+ console.log(chalk.cyan('\nSources:'));
281
+ response.citations.forEach((citation, i) => {
282
+ console.log(chalk.gray(` [${i + 1}] ${citation}`));
283
+ });
284
+ }
285
+
286
+ console.log(chalk.gray(`\n(${response.usage.total_tokens} tokens)`));
287
+ }
288
+ } catch (err) {
289
+ error(String(err));
290
+ process.exit(1);
291
+ }
292
+ });
293
+
294
+ chatCmd
295
+ .command('research <topic>')
296
+ .description('Deep research on a topic (uses sonar-deep-research)')
297
+ .option('--max-tokens <tokens>', 'Maximum tokens')
298
+ .action(async (topic: string, opts) => {
299
+ try {
300
+ info('Starting deep research (this may take a moment)...');
301
+ const client = getClient();
302
+ const response = await client.chat.research(topic, {
303
+ maxTokens: opts.maxTokens ? parseInt(opts.maxTokens) : undefined,
304
+ });
305
+
306
+ const format = getFormat(chatCmd);
307
+ if (format === 'json') {
308
+ print(response, format);
309
+ } else {
310
+ const content = response.choices[0]?.message?.content || '';
311
+ console.log(chalk.cyan('\nResearch Report:\n'));
312
+ console.log(content);
313
+
314
+ if (response.citations && response.citations.length > 0) {
315
+ console.log(chalk.cyan('\nReferences:'));
316
+ response.citations.forEach((citation, i) => {
317
+ console.log(chalk.gray(` [${i + 1}] ${citation}`));
318
+ });
319
+ }
320
+
321
+ console.log(chalk.gray(`\n(${response.usage.total_tokens} tokens, model: ${response.model})`));
322
+ }
323
+ } catch (err) {
324
+ error(String(err));
325
+ process.exit(1);
326
+ }
327
+ });
328
+
329
+ chatCmd
330
+ .command('reason <prompt>')
331
+ .description('Reasoning task (uses sonar-reasoning-pro)')
332
+ .option('--max-tokens <tokens>', 'Maximum tokens')
333
+ .action(async (prompt: string, opts) => {
334
+ try {
335
+ const client = getClient();
336
+ const response = await client.chat.reason(prompt, {
337
+ maxTokens: opts.maxTokens ? parseInt(opts.maxTokens) : undefined,
338
+ });
339
+
340
+ const format = getFormat(chatCmd);
341
+ if (format === 'json') {
342
+ print(response, format);
343
+ } else {
344
+ const content = response.choices[0]?.message?.content || '';
345
+ console.log(chalk.cyan('\nReasoning:\n'));
346
+ console.log(content);
347
+
348
+ console.log(chalk.gray(`\n(${response.usage.total_tokens} tokens, model: ${response.model})`));
349
+ }
350
+ } catch (err) {
351
+ error(String(err));
352
+ process.exit(1);
353
+ }
354
+ });
355
+
356
+ // ============================================
357
+ // Quick Commands (shortcuts)
358
+ // ============================================
359
+ program
360
+ .command('ask <question>')
361
+ .description('Quick ask (shortcut for "chat ask")')
362
+ .option('-m, --model <model>', `Model to use`, 'sonar')
363
+ .action(async (question: string, opts) => {
364
+ try {
365
+ const client = getClient();
366
+ const response = await client.chat.ask(question, {
367
+ model: opts.model as PerplexityModel,
368
+ });
369
+
370
+ const content = response.choices[0]?.message?.content || '';
371
+ console.log(content);
372
+
373
+ if (response.citations && response.citations.length > 0) {
374
+ console.log(chalk.cyan('\nSources:'));
375
+ response.citations.forEach((citation, i) => {
376
+ console.log(chalk.gray(` [${i + 1}] ${citation}`));
377
+ });
378
+ }
379
+ } catch (err) {
380
+ error(String(err));
381
+ process.exit(1);
382
+ }
383
+ });
384
+
385
+ program
386
+ .command('search <query>')
387
+ .description('Quick search (shortcut for "chat search")')
388
+ .action(async (query: string) => {
389
+ try {
390
+ const client = getClient();
391
+ const response = await client.chat.search(query);
392
+
393
+ const content = response.choices[0]?.message?.content || '';
394
+ console.log(content);
395
+
396
+ if (response.citations && response.citations.length > 0) {
397
+ console.log(chalk.cyan('\nSources:'));
398
+ response.citations.forEach((citation, i) => {
399
+ console.log(chalk.gray(` [${i + 1}] ${citation}`));
400
+ });
401
+ }
402
+ } catch (err) {
403
+ error(String(err));
404
+ process.exit(1);
405
+ }
406
+ });
407
+
408
+ program
409
+ .command('models')
410
+ .description('List available models')
411
+ .action(() => {
412
+ console.log(chalk.bold('Available Perplexity Models:\n'));
413
+ console.log(` ${chalk.cyan('sonar')} - Standard model for general queries`);
414
+ console.log(` ${chalk.cyan('sonar-pro')} - Enhanced model with better accuracy`);
415
+ console.log(` ${chalk.cyan('sonar-reasoning')} - Model optimized for reasoning tasks`);
416
+ console.log(` ${chalk.cyan('sonar-reasoning-pro')} - Enhanced reasoning model`);
417
+ console.log(` ${chalk.cyan('sonar-deep-research')} - Model for comprehensive research`);
418
+ });
419
+
420
+ // Parse and execute
421
+ program.parse();