@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.
- package/bin/index.js +204 -1
- package/bin/mcp.js +204 -1
- package/bin/serve.js +203 -0
- package/connectors/connect-ably/.env.example +11 -0
- package/connectors/connect-ably/CLAUDE.md +111 -0
- package/connectors/connect-ably/README.md +193 -0
- package/connectors/connect-ably/package.json +54 -0
- package/connectors/connect-ably/scripts/release.ts +179 -0
- package/connectors/connect-ably/src/api/channels.ts +33 -0
- package/connectors/connect-ably/src/api/client.ts +203 -0
- package/connectors/connect-ably/src/api/index.ts +59 -0
- package/connectors/connect-ably/src/api/messages.ts +48 -0
- package/connectors/connect-ably/src/api/presence.ts +39 -0
- package/connectors/connect-ably/src/api/stats.ts +29 -0
- package/connectors/connect-ably/src/cli/index.ts +397 -0
- package/connectors/connect-ably/src/index.ts +102 -0
- package/connectors/connect-ably/src/types/index.ts +294 -0
- package/connectors/connect-ably/src/utils/auth.ts +274 -0
- package/connectors/connect-ably/src/utils/bulk.ts +212 -0
- package/connectors/connect-ably/src/utils/config.ts +323 -0
- package/connectors/connect-ably/src/utils/output.ts +175 -0
- package/connectors/connect-ably/src/utils/settings.ts +114 -0
- package/connectors/connect-ably/src/utils/storage.ts +198 -0
- package/connectors/connect-ably/tsconfig.json +16 -0
- package/connectors/connect-assemblyai/.env.example +11 -0
- package/connectors/connect-assemblyai/CLAUDE.md +128 -0
- package/connectors/connect-assemblyai/README.md +193 -0
- package/connectors/connect-assemblyai/package.json +50 -0
- package/connectors/connect-assemblyai/src/api/client.ts +192 -0
- package/connectors/connect-assemblyai/src/api/index.ts +71 -0
- package/connectors/connect-assemblyai/src/cli/index.ts +384 -0
- package/connectors/connect-assemblyai/src/index.ts +19 -0
- package/connectors/connect-assemblyai/src/types/index.ts +277 -0
- package/connectors/connect-assemblyai/src/utils/config.ts +103 -0
- package/connectors/connect-assemblyai/src/utils/output.ts +119 -0
- package/connectors/connect-assemblyai/tsconfig.json +16 -0
- package/connectors/connect-baseten/.env.example +11 -0
- package/connectors/connect-baseten/CLAUDE.md +128 -0
- package/connectors/connect-baseten/README.md +193 -0
- package/connectors/connect-baseten/package.json +51 -0
- package/connectors/connect-baseten/src/api/client.ts +71 -0
- package/connectors/connect-baseten/src/api/index.ts +40 -0
- package/connectors/connect-baseten/src/cli/index.ts +244 -0
- package/connectors/connect-baseten/src/index.ts +19 -0
- package/connectors/connect-baseten/src/types/index.ts +55 -0
- package/connectors/connect-baseten/src/utils/config.ts +103 -0
- package/connectors/connect-baseten/src/utils/output.ts +119 -0
- package/connectors/connect-baseten/tsconfig.json +16 -0
- package/connectors/connect-box/.env.example +11 -0
- package/connectors/connect-box/CLAUDE.md +272 -0
- package/connectors/connect-box/README.md +193 -0
- package/connectors/connect-box/package.json +51 -0
- package/connectors/connect-box/scripts/release.ts +179 -0
- package/connectors/connect-box/src/api/client.ts +213 -0
- package/connectors/connect-box/src/api/example.ts +48 -0
- package/connectors/connect-box/src/api/index.ts +51 -0
- package/connectors/connect-box/src/cli/index.ts +254 -0
- package/connectors/connect-box/src/index.ts +103 -0
- package/connectors/connect-box/src/types/index.ts +237 -0
- package/connectors/connect-box/src/utils/auth.ts +274 -0
- package/connectors/connect-box/src/utils/bulk.ts +212 -0
- package/connectors/connect-box/src/utils/config.ts +326 -0
- package/connectors/connect-box/src/utils/output.ts +175 -0
- package/connectors/connect-box/src/utils/settings.ts +114 -0
- package/connectors/connect-box/src/utils/storage.ts +198 -0
- package/connectors/connect-box/tsconfig.json +16 -0
- package/connectors/connect-cerebras/.env.example +11 -0
- package/connectors/connect-cerebras/CLAUDE.md +128 -0
- package/connectors/connect-cerebras/README.md +193 -0
- package/connectors/connect-cerebras/package.json +51 -0
- package/connectors/connect-cerebras/src/api/client.ts +64 -0
- package/connectors/connect-cerebras/src/api/index.ts +32 -0
- package/connectors/connect-cerebras/src/cli/index.ts +244 -0
- package/connectors/connect-cerebras/src/index.ts +19 -0
- package/connectors/connect-cerebras/src/types/index.ts +65 -0
- package/connectors/connect-cerebras/src/utils/config.ts +103 -0
- package/connectors/connect-cerebras/src/utils/output.ts +119 -0
- package/connectors/connect-cerebras/tsconfig.json +16 -0
- package/connectors/connect-clearbit/.env.example +11 -0
- package/connectors/connect-clearbit/CLAUDE.md +272 -0
- package/connectors/connect-clearbit/README.md +193 -0
- package/connectors/connect-clearbit/package.json +51 -0
- package/connectors/connect-clearbit/scripts/release.ts +179 -0
- package/connectors/connect-clearbit/src/api/client.ts +213 -0
- package/connectors/connect-clearbit/src/api/example.ts +48 -0
- package/connectors/connect-clearbit/src/api/index.ts +51 -0
- package/connectors/connect-clearbit/src/cli/index.ts +254 -0
- package/connectors/connect-clearbit/src/index.ts +103 -0
- package/connectors/connect-clearbit/src/types/index.ts +237 -0
- package/connectors/connect-clearbit/src/utils/auth.ts +274 -0
- package/connectors/connect-clearbit/src/utils/bulk.ts +212 -0
- package/connectors/connect-clearbit/src/utils/config.ts +326 -0
- package/connectors/connect-clearbit/src/utils/output.ts +175 -0
- package/connectors/connect-clearbit/src/utils/settings.ts +114 -0
- package/connectors/connect-clearbit/src/utils/storage.ts +198 -0
- package/connectors/connect-clearbit/tsconfig.json +16 -0
- package/connectors/connect-coda/.env.example +11 -0
- package/connectors/connect-coda/CLAUDE.md +272 -0
- package/connectors/connect-coda/README.md +193 -0
- package/connectors/connect-coda/package.json +51 -0
- package/connectors/connect-coda/scripts/release.ts +179 -0
- package/connectors/connect-coda/src/api/client.ts +213 -0
- package/connectors/connect-coda/src/api/example.ts +48 -0
- package/connectors/connect-coda/src/api/index.ts +51 -0
- package/connectors/connect-coda/src/cli/index.ts +254 -0
- package/connectors/connect-coda/src/index.ts +103 -0
- package/connectors/connect-coda/src/types/index.ts +237 -0
- package/connectors/connect-coda/src/utils/auth.ts +274 -0
- package/connectors/connect-coda/src/utils/bulk.ts +212 -0
- package/connectors/connect-coda/src/utils/config.ts +326 -0
- package/connectors/connect-coda/src/utils/output.ts +175 -0
- package/connectors/connect-coda/src/utils/settings.ts +114 -0
- package/connectors/connect-coda/src/utils/storage.ts +198 -0
- package/connectors/connect-coda/tsconfig.json +16 -0
- package/connectors/connect-cohere/.env.example +11 -0
- package/connectors/connect-cohere/CLAUDE.md +128 -0
- package/connectors/connect-cohere/README.md +193 -0
- package/connectors/connect-cohere/package.json +53 -0
- package/connectors/connect-cohere/src/api/client.ts +109 -0
- package/connectors/connect-cohere/src/api/index.ts +59 -0
- package/connectors/connect-cohere/src/cli/index.ts +255 -0
- package/connectors/connect-cohere/src/index.ts +19 -0
- package/connectors/connect-cohere/src/types/index.ts +132 -0
- package/connectors/connect-cohere/src/utils/config.ts +197 -0
- package/connectors/connect-cohere/src/utils/output.ts +119 -0
- package/connectors/connect-cohere/tsconfig.json +16 -0
- package/connectors/connect-deepgram/.env.example +11 -0
- package/connectors/connect-deepgram/CLAUDE.md +128 -0
- package/connectors/connect-deepgram/README.md +193 -0
- package/connectors/connect-deepgram/package.json +51 -0
- package/connectors/connect-deepgram/src/api/client.ts +235 -0
- package/connectors/connect-deepgram/src/api/index.ts +57 -0
- package/connectors/connect-deepgram/src/cli/index.ts +339 -0
- package/connectors/connect-deepgram/src/index.ts +19 -0
- package/connectors/connect-deepgram/src/types/index.ts +232 -0
- package/connectors/connect-deepgram/src/utils/config.ts +103 -0
- package/connectors/connect-deepgram/src/utils/output.ts +119 -0
- package/connectors/connect-deepgram/tsconfig.json +16 -0
- package/connectors/connect-deepseek/.env.example +11 -0
- package/connectors/connect-deepseek/CLAUDE.md +128 -0
- package/connectors/connect-deepseek/README.md +193 -0
- package/connectors/connect-deepseek/package.json +51 -0
- package/connectors/connect-deepseek/src/api/client.ts +108 -0
- package/connectors/connect-deepseek/src/api/index.ts +36 -0
- package/connectors/connect-deepseek/src/cli/index.ts +167 -0
- package/connectors/connect-deepseek/src/index.ts +19 -0
- package/connectors/connect-deepseek/src/types/index.ts +72 -0
- package/connectors/connect-deepseek/src/utils/config.ts +103 -0
- package/connectors/connect-deepseek/src/utils/output.ts +119 -0
- package/connectors/connect-deepseek/tsconfig.json +16 -0
- package/connectors/connect-dropbox/.env.example +11 -0
- package/connectors/connect-dropbox/CLAUDE.md +119 -0
- package/connectors/connect-dropbox/README.md +193 -0
- package/connectors/connect-dropbox/package.json +51 -0
- package/connectors/connect-dropbox/src/api/client.ts +222 -0
- package/connectors/connect-dropbox/src/api/index.ts +395 -0
- package/connectors/connect-dropbox/src/cli/index.ts +627 -0
- package/connectors/connect-dropbox/src/index.ts +20 -0
- package/connectors/connect-dropbox/src/types/index.ts +516 -0
- package/connectors/connect-dropbox/src/utils/config.ts +197 -0
- package/connectors/connect-dropbox/tsconfig.json +16 -0
- package/connectors/connect-fal/.env.example +11 -0
- package/connectors/connect-fal/CLAUDE.md +128 -0
- package/connectors/connect-fal/README.md +193 -0
- package/connectors/connect-fal/package.json +51 -0
- package/connectors/connect-fal/src/api/client.ts +172 -0
- package/connectors/connect-fal/src/api/index.ts +55 -0
- package/connectors/connect-fal/src/cli/index.ts +341 -0
- package/connectors/connect-fal/src/index.ts +19 -0
- package/connectors/connect-fal/src/types/index.ts +135 -0
- package/connectors/connect-fal/src/utils/config.ts +103 -0
- package/connectors/connect-fal/src/utils/output.ts +119 -0
- package/connectors/connect-fal/tsconfig.json +16 -0
- package/connectors/connect-fireworks/.env.example +11 -0
- package/connectors/connect-fireworks/CLAUDE.md +128 -0
- package/connectors/connect-fireworks/README.md +193 -0
- package/connectors/connect-fireworks/package.json +51 -0
- package/connectors/connect-fireworks/src/api/client.ts +63 -0
- package/connectors/connect-fireworks/src/api/index.ts +36 -0
- package/connectors/connect-fireworks/src/cli/index.ts +244 -0
- package/connectors/connect-fireworks/src/index.ts +19 -0
- package/connectors/connect-fireworks/src/types/index.ts +70 -0
- package/connectors/connect-fireworks/src/utils/config.ts +103 -0
- package/connectors/connect-fireworks/src/utils/output.ts +119 -0
- package/connectors/connect-fireworks/tsconfig.json +16 -0
- package/connectors/connect-groq/.env.example +11 -0
- package/connectors/connect-groq/CLAUDE.md +128 -0
- package/connectors/connect-groq/README.md +193 -0
- package/connectors/connect-groq/package.json +52 -0
- package/connectors/connect-groq/src/api/client.ts +108 -0
- package/connectors/connect-groq/src/api/index.ts +36 -0
- package/connectors/connect-groq/src/cli/index.ts +171 -0
- package/connectors/connect-groq/src/index.ts +19 -0
- package/connectors/connect-groq/src/types/index.ts +69 -0
- package/connectors/connect-groq/src/utils/config.ts +103 -0
- package/connectors/connect-groq/src/utils/output.ts +119 -0
- package/connectors/connect-groq/tsconfig.json +16 -0
- package/connectors/connect-linode/.env.example +11 -0
- package/connectors/connect-linode/CLAUDE.md +272 -0
- package/connectors/connect-linode/README.md +193 -0
- package/connectors/connect-linode/package.json +51 -0
- package/connectors/connect-linode/scripts/release.ts +179 -0
- package/connectors/connect-linode/src/api/client.ts +213 -0
- package/connectors/connect-linode/src/api/example.ts +48 -0
- package/connectors/connect-linode/src/api/index.ts +51 -0
- package/connectors/connect-linode/src/cli/index.ts +254 -0
- package/connectors/connect-linode/src/index.ts +103 -0
- package/connectors/connect-linode/src/types/index.ts +237 -0
- package/connectors/connect-linode/src/utils/auth.ts +274 -0
- package/connectors/connect-linode/src/utils/bulk.ts +212 -0
- package/connectors/connect-linode/src/utils/config.ts +326 -0
- package/connectors/connect-linode/src/utils/output.ts +175 -0
- package/connectors/connect-linode/src/utils/settings.ts +114 -0
- package/connectors/connect-linode/src/utils/storage.ts +198 -0
- package/connectors/connect-linode/tsconfig.json +16 -0
- package/connectors/connect-luma/.env.example +11 -0
- package/connectors/connect-luma/CLAUDE.md +128 -0
- package/connectors/connect-luma/README.md +193 -0
- package/connectors/connect-luma/package.json +53 -0
- package/connectors/connect-luma/src/api/client.ts +85 -0
- package/connectors/connect-luma/src/api/index.ts +44 -0
- package/connectors/connect-luma/src/cli/index.ts +300 -0
- package/connectors/connect-luma/src/index.ts +19 -0
- package/connectors/connect-luma/src/types/index.ts +60 -0
- package/connectors/connect-luma/src/utils/config.ts +103 -0
- package/connectors/connect-luma/src/utils/output.ts +119 -0
- package/connectors/connect-luma/tsconfig.json +16 -0
- package/connectors/connect-mailgun/.env.example +11 -0
- package/connectors/connect-mailgun/CLAUDE.md +272 -0
- package/connectors/connect-mailgun/README.md +193 -0
- package/connectors/connect-mailgun/package.json +51 -0
- package/connectors/connect-mailgun/scripts/release.ts +179 -0
- package/connectors/connect-mailgun/src/api/client.ts +213 -0
- package/connectors/connect-mailgun/src/api/example.ts +48 -0
- package/connectors/connect-mailgun/src/api/index.ts +51 -0
- package/connectors/connect-mailgun/src/cli/index.ts +254 -0
- package/connectors/connect-mailgun/src/index.ts +103 -0
- package/connectors/connect-mailgun/src/types/index.ts +237 -0
- package/connectors/connect-mailgun/src/utils/auth.ts +274 -0
- package/connectors/connect-mailgun/src/utils/bulk.ts +212 -0
- package/connectors/connect-mailgun/src/utils/config.ts +326 -0
- package/connectors/connect-mailgun/src/utils/output.ts +175 -0
- package/connectors/connect-mailgun/src/utils/settings.ts +114 -0
- package/connectors/connect-mailgun/src/utils/storage.ts +198 -0
- package/connectors/connect-mailgun/tsconfig.json +16 -0
- package/connectors/connect-messagebird/.env.example +11 -0
- package/connectors/connect-messagebird/CLAUDE.md +272 -0
- package/connectors/connect-messagebird/README.md +193 -0
- package/connectors/connect-messagebird/package.json +51 -0
- package/connectors/connect-messagebird/scripts/release.ts +179 -0
- package/connectors/connect-messagebird/src/api/client.ts +213 -0
- package/connectors/connect-messagebird/src/api/example.ts +48 -0
- package/connectors/connect-messagebird/src/api/index.ts +51 -0
- package/connectors/connect-messagebird/src/cli/index.ts +254 -0
- package/connectors/connect-messagebird/src/index.ts +103 -0
- package/connectors/connect-messagebird/src/types/index.ts +237 -0
- package/connectors/connect-messagebird/src/utils/auth.ts +274 -0
- package/connectors/connect-messagebird/src/utils/bulk.ts +212 -0
- package/connectors/connect-messagebird/src/utils/config.ts +326 -0
- package/connectors/connect-messagebird/src/utils/output.ts +175 -0
- package/connectors/connect-messagebird/src/utils/settings.ts +114 -0
- package/connectors/connect-messagebird/src/utils/storage.ts +198 -0
- package/connectors/connect-messagebird/tsconfig.json +16 -0
- package/connectors/connect-miro/.env.example +11 -0
- package/connectors/connect-miro/CLAUDE.md +272 -0
- package/connectors/connect-miro/README.md +193 -0
- package/connectors/connect-miro/package.json +51 -0
- package/connectors/connect-miro/scripts/release.ts +179 -0
- package/connectors/connect-miro/src/api/client.ts +213 -0
- package/connectors/connect-miro/src/api/example.ts +48 -0
- package/connectors/connect-miro/src/api/index.ts +51 -0
- package/connectors/connect-miro/src/cli/index.ts +254 -0
- package/connectors/connect-miro/src/index.ts +103 -0
- package/connectors/connect-miro/src/types/index.ts +237 -0
- package/connectors/connect-miro/src/utils/auth.ts +274 -0
- package/connectors/connect-miro/src/utils/bulk.ts +212 -0
- package/connectors/connect-miro/src/utils/config.ts +326 -0
- package/connectors/connect-miro/src/utils/output.ts +175 -0
- package/connectors/connect-miro/src/utils/settings.ts +114 -0
- package/connectors/connect-miro/src/utils/storage.ts +198 -0
- package/connectors/connect-miro/tsconfig.json +16 -0
- package/connectors/connect-modal/.env.example +11 -0
- package/connectors/connect-modal/CLAUDE.md +128 -0
- package/connectors/connect-modal/README.md +193 -0
- package/connectors/connect-modal/package.json +51 -0
- package/connectors/connect-modal/src/api/client.ts +119 -0
- package/connectors/connect-modal/src/api/index.ts +69 -0
- package/connectors/connect-modal/src/cli/index.ts +224 -0
- package/connectors/connect-modal/src/index.ts +21 -0
- package/connectors/connect-modal/src/types/index.ts +60 -0
- package/connectors/connect-modal/src/utils/config.ts +114 -0
- package/connectors/connect-modal/src/utils/output.ts +119 -0
- package/connectors/connect-modal/tsconfig.json +16 -0
- package/connectors/connect-monday/.env.example +11 -0
- package/connectors/connect-monday/CLAUDE.md +128 -0
- package/connectors/connect-monday/README.md +193 -0
- package/connectors/connect-monday/package.json +52 -0
- package/connectors/connect-monday/src/api/client.ts +59 -0
- package/connectors/connect-monday/src/api/index.ts +539 -0
- package/connectors/connect-monday/src/cli/index.ts +479 -0
- package/connectors/connect-monday/src/index.ts +19 -0
- package/connectors/connect-monday/src/types/index.ts +274 -0
- package/connectors/connect-monday/src/utils/config.ts +197 -0
- package/connectors/connect-monday/src/utils/output.ts +119 -0
- package/connectors/connect-monday/tsconfig.json +16 -0
- package/connectors/connect-perplexity/.env.example +4 -0
- package/connectors/connect-perplexity/CLAUDE.md +156 -0
- package/connectors/connect-perplexity/README.md +184 -0
- package/connectors/connect-perplexity/package.json +58 -0
- package/connectors/connect-perplexity/scripts/publish.ts +210 -0
- package/connectors/connect-perplexity/src/api/client.ts +119 -0
- package/connectors/connect-perplexity/src/api/example.ts +118 -0
- package/connectors/connect-perplexity/src/api/index.ts +48 -0
- package/connectors/connect-perplexity/src/cli/index.ts +421 -0
- package/connectors/connect-perplexity/src/index.ts +24 -0
- package/connectors/connect-perplexity/src/types/index.ts +140 -0
- package/connectors/connect-perplexity/src/utils/config.ts +208 -0
- package/connectors/connect-perplexity/src/utils/output.ts +119 -0
- package/connectors/connect-perplexity/tsconfig.json +16 -0
- package/connectors/connect-pipedrive/.env.example +11 -0
- package/connectors/connect-pipedrive/CLAUDE.md +128 -0
- package/connectors/connect-pipedrive/README.md +193 -0
- package/connectors/connect-pipedrive/package.json +52 -0
- package/connectors/connect-pipedrive/src/api/client.ts +121 -0
- package/connectors/connect-pipedrive/src/api/index.ts +306 -0
- package/connectors/connect-pipedrive/src/cli/index.ts +824 -0
- package/connectors/connect-pipedrive/src/index.ts +19 -0
- package/connectors/connect-pipedrive/src/types/index.ts +335 -0
- package/connectors/connect-pipedrive/src/utils/config.ts +171 -0
- package/connectors/connect-pipedrive/src/utils/output.ts +119 -0
- package/connectors/connect-pipedrive/tsconfig.json +16 -0
- package/connectors/connect-pusher/.env.example +11 -0
- package/connectors/connect-pusher/CLAUDE.md +272 -0
- package/connectors/connect-pusher/README.md +193 -0
- package/connectors/connect-pusher/package.json +51 -0
- package/connectors/connect-pusher/scripts/release.ts +179 -0
- package/connectors/connect-pusher/src/api/client.ts +213 -0
- package/connectors/connect-pusher/src/api/example.ts +48 -0
- package/connectors/connect-pusher/src/api/index.ts +51 -0
- package/connectors/connect-pusher/src/cli/index.ts +254 -0
- package/connectors/connect-pusher/src/index.ts +103 -0
- package/connectors/connect-pusher/src/types/index.ts +237 -0
- package/connectors/connect-pusher/src/utils/auth.ts +274 -0
- package/connectors/connect-pusher/src/utils/bulk.ts +212 -0
- package/connectors/connect-pusher/src/utils/config.ts +326 -0
- package/connectors/connect-pusher/src/utils/output.ts +175 -0
- package/connectors/connect-pusher/src/utils/settings.ts +114 -0
- package/connectors/connect-pusher/src/utils/storage.ts +198 -0
- package/connectors/connect-pusher/tsconfig.json +16 -0
- package/connectors/connect-replicate/.env.example +11 -0
- package/connectors/connect-replicate/CLAUDE.md +128 -0
- package/connectors/connect-replicate/README.md +193 -0
- package/connectors/connect-replicate/package.json +51 -0
- package/connectors/connect-replicate/src/api/client.ts +109 -0
- package/connectors/connect-replicate/src/api/index.ts +71 -0
- package/connectors/connect-replicate/src/cli/index.ts +250 -0
- package/connectors/connect-replicate/src/index.ts +19 -0
- package/connectors/connect-replicate/src/types/index.ts +85 -0
- package/connectors/connect-replicate/src/utils/config.ts +103 -0
- package/connectors/connect-replicate/src/utils/output.ts +119 -0
- package/connectors/connect-replicate/tsconfig.json +16 -0
- package/connectors/connect-roboflow/.env.example +11 -0
- package/connectors/connect-roboflow/CLAUDE.md +272 -0
- package/connectors/connect-roboflow/README.md +193 -0
- package/connectors/connect-roboflow/package.json +51 -0
- package/connectors/connect-roboflow/scripts/release.ts +179 -0
- package/connectors/connect-roboflow/src/api/client.ts +213 -0
- package/connectors/connect-roboflow/src/api/example.ts +48 -0
- package/connectors/connect-roboflow/src/api/index.ts +51 -0
- package/connectors/connect-roboflow/src/cli/index.ts +254 -0
- package/connectors/connect-roboflow/src/index.ts +103 -0
- package/connectors/connect-roboflow/src/types/index.ts +237 -0
- package/connectors/connect-roboflow/src/utils/auth.ts +274 -0
- package/connectors/connect-roboflow/src/utils/bulk.ts +212 -0
- package/connectors/connect-roboflow/src/utils/config.ts +326 -0
- package/connectors/connect-roboflow/src/utils/output.ts +175 -0
- package/connectors/connect-roboflow/src/utils/settings.ts +114 -0
- package/connectors/connect-roboflow/src/utils/storage.ts +198 -0
- package/connectors/connect-roboflow/tsconfig.json +16 -0
- package/connectors/connect-runway/.env.example +11 -0
- package/connectors/connect-runway/CLAUDE.md +128 -0
- package/connectors/connect-runway/README.md +193 -0
- package/connectors/connect-runway/package.json +52 -0
- package/connectors/connect-runway/src/api/client.ts +78 -0
- package/connectors/connect-runway/src/api/index.ts +40 -0
- package/connectors/connect-runway/src/cli/index.ts +283 -0
- package/connectors/connect-runway/src/index.ts +19 -0
- package/connectors/connect-runway/src/types/index.ts +52 -0
- package/connectors/connect-runway/src/utils/config.ts +103 -0
- package/connectors/connect-runway/src/utils/output.ts +119 -0
- package/connectors/connect-runway/tsconfig.json +16 -0
- package/connectors/connect-together/.env.example +11 -0
- package/connectors/connect-together/CLAUDE.md +128 -0
- package/connectors/connect-together/README.md +193 -0
- package/connectors/connect-together/package.json +52 -0
- package/connectors/connect-together/src/api/client.ts +106 -0
- package/connectors/connect-together/src/api/index.ts +47 -0
- package/connectors/connect-together/src/cli/index.ts +228 -0
- package/connectors/connect-together/src/index.ts +19 -0
- package/connectors/connect-together/src/types/index.ts +91 -0
- package/connectors/connect-together/src/utils/config.ts +142 -0
- package/connectors/connect-together/src/utils/output.ts +119 -0
- package/connectors/connect-together/tsconfig.json +16 -0
- package/connectors/connect-vonage/.env.example +11 -0
- package/connectors/connect-vonage/CLAUDE.md +272 -0
- package/connectors/connect-vonage/README.md +193 -0
- package/connectors/connect-vonage/package.json +51 -0
- package/connectors/connect-vonage/scripts/release.ts +179 -0
- package/connectors/connect-vonage/src/api/client.ts +213 -0
- package/connectors/connect-vonage/src/api/example.ts +48 -0
- package/connectors/connect-vonage/src/api/index.ts +51 -0
- package/connectors/connect-vonage/src/cli/index.ts +254 -0
- package/connectors/connect-vonage/src/index.ts +103 -0
- package/connectors/connect-vonage/src/types/index.ts +237 -0
- package/connectors/connect-vonage/src/utils/auth.ts +274 -0
- package/connectors/connect-vonage/src/utils/bulk.ts +212 -0
- package/connectors/connect-vonage/src/utils/config.ts +326 -0
- package/connectors/connect-vonage/src/utils/output.ts +175 -0
- package/connectors/connect-vonage/src/utils/settings.ts +114 -0
- package/connectors/connect-vonage/src/utils/storage.ts +198 -0
- package/connectors/connect-vonage/tsconfig.json +16 -0
- package/dist/index.js +203 -0
- package/package.json +1 -1
|
@@ -0,0 +1,274 @@
|
|
|
1
|
+
import { createServer } from 'http';
|
|
2
|
+
import type { OAuth2Tokens, OAuth2Config } from '../types';
|
|
3
|
+
import { saveOAuthTokens, loadOAuthTokens, getOAuthConfig } from './config';
|
|
4
|
+
|
|
5
|
+
// ============================================
|
|
6
|
+
// OAuth2 Authentication Utility
|
|
7
|
+
// ============================================
|
|
8
|
+
|
|
9
|
+
// TODO: Replace with your OAuth provider's endpoints
|
|
10
|
+
const DEFAULT_AUTH_URL = 'https://accounts.example.com/oauth2/authorize';
|
|
11
|
+
const DEFAULT_TOKEN_URL = 'https://accounts.example.com/oauth2/token';
|
|
12
|
+
|
|
13
|
+
// TODO: Define your OAuth scopes
|
|
14
|
+
const DEFAULT_SCOPES = ['read', 'write'].join(' ');
|
|
15
|
+
|
|
16
|
+
const REDIRECT_PORT = 8089;
|
|
17
|
+
const REDIRECT_URI = `http://localhost:${REDIRECT_PORT}/callback`;
|
|
18
|
+
|
|
19
|
+
export interface AuthResult {
|
|
20
|
+
success: boolean;
|
|
21
|
+
tokens?: OAuth2Tokens;
|
|
22
|
+
error?: string;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export interface AuthUrlOptions {
|
|
26
|
+
authUrl?: string;
|
|
27
|
+
scopes?: string;
|
|
28
|
+
state?: string;
|
|
29
|
+
extraParams?: Record<string, string>;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* Generate the OAuth2 authorization URL
|
|
34
|
+
*/
|
|
35
|
+
export function getAuthUrl(options: AuthUrlOptions = {}): string {
|
|
36
|
+
const config = getOAuthConfig();
|
|
37
|
+
if (!config?.clientId) {
|
|
38
|
+
throw new Error('OAuth client ID not configured. Run "config set-credentials" first.');
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
const authUrl = options.authUrl || DEFAULT_AUTH_URL;
|
|
42
|
+
const scopes = options.scopes || DEFAULT_SCOPES;
|
|
43
|
+
|
|
44
|
+
const params = new URLSearchParams({
|
|
45
|
+
client_id: config.clientId,
|
|
46
|
+
redirect_uri: REDIRECT_URI,
|
|
47
|
+
response_type: 'code',
|
|
48
|
+
scope: scopes,
|
|
49
|
+
access_type: 'offline',
|
|
50
|
+
prompt: 'consent', // Force consent to get refresh token
|
|
51
|
+
...(options.state && { state: options.state }),
|
|
52
|
+
...options.extraParams,
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
return `${authUrl}?${params.toString()}`;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* Exchange authorization code for tokens
|
|
60
|
+
*/
|
|
61
|
+
export async function exchangeCodeForTokens(
|
|
62
|
+
code: string,
|
|
63
|
+
tokenUrl: string = DEFAULT_TOKEN_URL
|
|
64
|
+
): Promise<OAuth2Tokens> {
|
|
65
|
+
const config = getOAuthConfig();
|
|
66
|
+
|
|
67
|
+
if (!config?.clientId || !config?.clientSecret) {
|
|
68
|
+
throw new Error('OAuth credentials not configured');
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
const response = await fetch(tokenUrl, {
|
|
72
|
+
method: 'POST',
|
|
73
|
+
headers: {
|
|
74
|
+
'Content-Type': 'application/x-www-form-urlencoded',
|
|
75
|
+
},
|
|
76
|
+
body: new URLSearchParams({
|
|
77
|
+
code,
|
|
78
|
+
client_id: config.clientId,
|
|
79
|
+
client_secret: config.clientSecret,
|
|
80
|
+
redirect_uri: REDIRECT_URI,
|
|
81
|
+
grant_type: 'authorization_code',
|
|
82
|
+
}),
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
if (!response.ok) {
|
|
86
|
+
const error = await response.json().catch(() => ({ error: response.statusText }));
|
|
87
|
+
throw new Error(`Token exchange failed: ${error.error_description || error.error}`);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
const data = await response.json();
|
|
91
|
+
|
|
92
|
+
const tokens: OAuth2Tokens = {
|
|
93
|
+
accessToken: data.access_token,
|
|
94
|
+
refreshToken: data.refresh_token,
|
|
95
|
+
expiresAt: Date.now() + data.expires_in * 1000,
|
|
96
|
+
tokenType: data.token_type,
|
|
97
|
+
scope: data.scope,
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
return tokens;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* Refresh the access token using the refresh token
|
|
105
|
+
*/
|
|
106
|
+
export async function refreshAccessToken(
|
|
107
|
+
tokenUrl: string = DEFAULT_TOKEN_URL
|
|
108
|
+
): Promise<OAuth2Tokens> {
|
|
109
|
+
const config = getOAuthConfig();
|
|
110
|
+
const currentTokens = loadOAuthTokens();
|
|
111
|
+
|
|
112
|
+
if (!config?.clientId || !config?.clientSecret) {
|
|
113
|
+
throw new Error('OAuth credentials not configured');
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
if (!currentTokens?.refreshToken) {
|
|
117
|
+
throw new Error('No refresh token available. Please login again.');
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
const response = await fetch(tokenUrl, {
|
|
121
|
+
method: 'POST',
|
|
122
|
+
headers: {
|
|
123
|
+
'Content-Type': 'application/x-www-form-urlencoded',
|
|
124
|
+
},
|
|
125
|
+
body: new URLSearchParams({
|
|
126
|
+
client_id: config.clientId,
|
|
127
|
+
client_secret: config.clientSecret,
|
|
128
|
+
refresh_token: currentTokens.refreshToken,
|
|
129
|
+
grant_type: 'refresh_token',
|
|
130
|
+
}),
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
if (!response.ok) {
|
|
134
|
+
const error = await response.json().catch(() => ({ error: response.statusText }));
|
|
135
|
+
throw new Error(`Token refresh failed: ${error.error_description || error.error}`);
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
const data = await response.json();
|
|
139
|
+
|
|
140
|
+
const tokens: OAuth2Tokens = {
|
|
141
|
+
accessToken: data.access_token,
|
|
142
|
+
refreshToken: data.refresh_token || currentTokens.refreshToken, // Keep original if not returned
|
|
143
|
+
expiresAt: Date.now() + data.expires_in * 1000,
|
|
144
|
+
tokenType: data.token_type,
|
|
145
|
+
scope: data.scope || currentTokens.scope,
|
|
146
|
+
};
|
|
147
|
+
|
|
148
|
+
saveOAuthTokens(tokens);
|
|
149
|
+
return tokens;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
/**
|
|
153
|
+
* Start a local HTTP server to receive the OAuth callback
|
|
154
|
+
*/
|
|
155
|
+
export function startCallbackServer(): Promise<AuthResult> {
|
|
156
|
+
return new Promise((resolve) => {
|
|
157
|
+
const server = createServer(async (req, res) => {
|
|
158
|
+
const url = new URL(req.url || '', `http://localhost:${REDIRECT_PORT}`);
|
|
159
|
+
|
|
160
|
+
if (url.pathname === '/callback') {
|
|
161
|
+
const code = url.searchParams.get('code');
|
|
162
|
+
const error = url.searchParams.get('error');
|
|
163
|
+
|
|
164
|
+
if (error) {
|
|
165
|
+
res.writeHead(200, { 'Content-Type': 'text/html' });
|
|
166
|
+
res.end(`
|
|
167
|
+
<html>
|
|
168
|
+
<body style="font-family: sans-serif; display: flex; justify-content: center; align-items: center; height: 100vh; margin: 0;">
|
|
169
|
+
<div style="text-align: center;">
|
|
170
|
+
<h1 style="color: #dc3545;">Authentication Failed</h1>
|
|
171
|
+
<p>Error: ${error}</p>
|
|
172
|
+
<p>You can close this window.</p>
|
|
173
|
+
</div>
|
|
174
|
+
</body>
|
|
175
|
+
</html>
|
|
176
|
+
`);
|
|
177
|
+
server.close();
|
|
178
|
+
resolve({ success: false, error });
|
|
179
|
+
return;
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
if (code) {
|
|
183
|
+
try {
|
|
184
|
+
const tokens = await exchangeCodeForTokens(code);
|
|
185
|
+
res.writeHead(200, { 'Content-Type': 'text/html' });
|
|
186
|
+
res.end(`
|
|
187
|
+
<html>
|
|
188
|
+
<body style="font-family: sans-serif; display: flex; justify-content: center; align-items: center; height: 100vh; margin: 0;">
|
|
189
|
+
<div style="text-align: center;">
|
|
190
|
+
<h1 style="color: #28a745;">Authentication Successful!</h1>
|
|
191
|
+
<p>You can close this window and return to the terminal.</p>
|
|
192
|
+
</div>
|
|
193
|
+
</body>
|
|
194
|
+
</html>
|
|
195
|
+
`);
|
|
196
|
+
server.close();
|
|
197
|
+
resolve({ success: true, tokens });
|
|
198
|
+
} catch (err) {
|
|
199
|
+
res.writeHead(200, { 'Content-Type': 'text/html' });
|
|
200
|
+
res.end(`
|
|
201
|
+
<html>
|
|
202
|
+
<body style="font-family: sans-serif; display: flex; justify-content: center; align-items: center; height: 100vh; margin: 0;">
|
|
203
|
+
<div style="text-align: center;">
|
|
204
|
+
<h1 style="color: #dc3545;">Authentication Failed</h1>
|
|
205
|
+
<p>Error: ${String(err)}</p>
|
|
206
|
+
<p>You can close this window.</p>
|
|
207
|
+
</div>
|
|
208
|
+
</body>
|
|
209
|
+
</html>
|
|
210
|
+
`);
|
|
211
|
+
server.close();
|
|
212
|
+
resolve({ success: false, error: String(err) });
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
server.listen(REDIRECT_PORT, () => {
|
|
219
|
+
// Server is ready
|
|
220
|
+
});
|
|
221
|
+
|
|
222
|
+
// Timeout after 5 minutes
|
|
223
|
+
setTimeout(() => {
|
|
224
|
+
server.close();
|
|
225
|
+
resolve({ success: false, error: 'Authentication timed out' });
|
|
226
|
+
}, 5 * 60 * 1000);
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
/**
|
|
231
|
+
* Get a valid access token, refreshing if necessary
|
|
232
|
+
* @param tokenUrl - Token endpoint URL for refresh
|
|
233
|
+
* @param bufferMs - Refresh buffer in ms (default: 5 minutes)
|
|
234
|
+
*/
|
|
235
|
+
export async function getValidAccessToken(
|
|
236
|
+
tokenUrl: string = DEFAULT_TOKEN_URL,
|
|
237
|
+
bufferMs: number = 5 * 60 * 1000
|
|
238
|
+
): Promise<string> {
|
|
239
|
+
const tokens = loadOAuthTokens();
|
|
240
|
+
|
|
241
|
+
if (!tokens) {
|
|
242
|
+
throw new Error('Not authenticated. Run "auth login" first.');
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
// Check if token is expired or will expire within buffer time
|
|
246
|
+
if (Date.now() >= tokens.expiresAt - bufferMs) {
|
|
247
|
+
const newTokens = await refreshAccessToken(tokenUrl);
|
|
248
|
+
return newTokens.accessToken;
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
return tokens.accessToken;
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
/**
|
|
255
|
+
* Check if the user is authenticated
|
|
256
|
+
*/
|
|
257
|
+
export function isAuthenticated(): boolean {
|
|
258
|
+
const tokens = loadOAuthTokens();
|
|
259
|
+
return !!tokens?.accessToken;
|
|
260
|
+
}
|
|
261
|
+
|
|
262
|
+
/**
|
|
263
|
+
* Get the redirect URI for OAuth configuration
|
|
264
|
+
*/
|
|
265
|
+
export function getRedirectUri(): string {
|
|
266
|
+
return REDIRECT_URI;
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
/**
|
|
270
|
+
* Get the redirect port for OAuth callback
|
|
271
|
+
*/
|
|
272
|
+
export function getRedirectPort(): number {
|
|
273
|
+
return REDIRECT_PORT;
|
|
274
|
+
}
|
|
@@ -0,0 +1,212 @@
|
|
|
1
|
+
// ============================================
|
|
2
|
+
// Bulk Operations Utility
|
|
3
|
+
// ============================================
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Options for bulk operations
|
|
7
|
+
*/
|
|
8
|
+
export interface BulkOperationOptions<T> {
|
|
9
|
+
/** Items to process */
|
|
10
|
+
items: T[];
|
|
11
|
+
/** Maximum concurrent operations (default: 10) */
|
|
12
|
+
concurrency?: number;
|
|
13
|
+
/** Dry run - preview without making changes */
|
|
14
|
+
dryRun?: boolean;
|
|
15
|
+
/** Progress callback */
|
|
16
|
+
onProgress?: (current: number, total: number, item: T) => void;
|
|
17
|
+
/** Error callback (return true to continue, false to stop) */
|
|
18
|
+
onError?: (error: Error, item: T) => boolean | void;
|
|
19
|
+
/** Delay between batches in ms (useful for rate limiting) */
|
|
20
|
+
batchDelay?: number;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Result of a bulk operation
|
|
25
|
+
*/
|
|
26
|
+
export interface BulkOperationResult<T, R = void> {
|
|
27
|
+
/** Total items processed */
|
|
28
|
+
total: number;
|
|
29
|
+
/** Successfully processed count */
|
|
30
|
+
success: number;
|
|
31
|
+
/** Failed count */
|
|
32
|
+
failed: number;
|
|
33
|
+
/** Skipped count (dry run) */
|
|
34
|
+
skipped: number;
|
|
35
|
+
/** List of errors */
|
|
36
|
+
errors: Array<{ item: T; error: string }>;
|
|
37
|
+
/** Successfully processed items with results */
|
|
38
|
+
results: Array<{ item: T; result: R }>;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Split an array into chunks of a given size
|
|
43
|
+
*/
|
|
44
|
+
export function chunkArray<T>(array: T[], size: number): T[][] {
|
|
45
|
+
const chunks: T[][] = [];
|
|
46
|
+
for (let i = 0; i < array.length; i += size) {
|
|
47
|
+
chunks.push(array.slice(i, i + size));
|
|
48
|
+
}
|
|
49
|
+
return chunks;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* Sleep for a given number of milliseconds
|
|
54
|
+
*/
|
|
55
|
+
export function sleep(ms: number): Promise<void> {
|
|
56
|
+
return new Promise(resolve => setTimeout(resolve, ms));
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* Execute a bulk operation with concurrency control
|
|
61
|
+
*
|
|
62
|
+
* @param options - Bulk operation options
|
|
63
|
+
* @param operation - Async function to execute for each item
|
|
64
|
+
* @returns Result summary
|
|
65
|
+
*
|
|
66
|
+
* @example
|
|
67
|
+
* ```typescript
|
|
68
|
+
* const result = await executeBulk(
|
|
69
|
+
* {
|
|
70
|
+
* items: users,
|
|
71
|
+
* concurrency: 5,
|
|
72
|
+
* onProgress: (current, total, user) => {
|
|
73
|
+
* console.log(`Processing ${current}/${total}: ${user.email}`);
|
|
74
|
+
* },
|
|
75
|
+
* },
|
|
76
|
+
* async (user) => {
|
|
77
|
+
* await api.updateUser(user.id, { status: 'active' });
|
|
78
|
+
* }
|
|
79
|
+
* );
|
|
80
|
+
* console.log(`Success: ${result.success}, Failed: ${result.failed}`);
|
|
81
|
+
* ```
|
|
82
|
+
*/
|
|
83
|
+
export async function executeBulk<T, R = void>(
|
|
84
|
+
options: BulkOperationOptions<T>,
|
|
85
|
+
operation: (item: T) => Promise<R>
|
|
86
|
+
): Promise<BulkOperationResult<T, R>> {
|
|
87
|
+
const {
|
|
88
|
+
items,
|
|
89
|
+
concurrency = 10,
|
|
90
|
+
dryRun = false,
|
|
91
|
+
onProgress,
|
|
92
|
+
onError,
|
|
93
|
+
batchDelay = 0,
|
|
94
|
+
} = options;
|
|
95
|
+
|
|
96
|
+
const result: BulkOperationResult<T, R> = {
|
|
97
|
+
total: items.length,
|
|
98
|
+
success: 0,
|
|
99
|
+
failed: 0,
|
|
100
|
+
skipped: 0,
|
|
101
|
+
errors: [],
|
|
102
|
+
results: [],
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
if (items.length === 0) {
|
|
106
|
+
return result;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
// Process in batches with concurrency control
|
|
110
|
+
const chunks = chunkArray(items, concurrency);
|
|
111
|
+
let shouldStop = false;
|
|
112
|
+
|
|
113
|
+
for (let chunkIndex = 0; chunkIndex < chunks.length && !shouldStop; chunkIndex++) {
|
|
114
|
+
const chunk = chunks[chunkIndex];
|
|
115
|
+
|
|
116
|
+
await Promise.all(
|
|
117
|
+
chunk.map(async (item) => {
|
|
118
|
+
if (shouldStop) return;
|
|
119
|
+
|
|
120
|
+
try {
|
|
121
|
+
if (dryRun) {
|
|
122
|
+
result.skipped++;
|
|
123
|
+
result.results.push({ item, result: undefined as R });
|
|
124
|
+
} else {
|
|
125
|
+
const opResult = await operation(item);
|
|
126
|
+
result.success++;
|
|
127
|
+
result.results.push({ item, result: opResult });
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
if (onProgress) {
|
|
131
|
+
onProgress(result.success + result.failed + result.skipped, result.total, item);
|
|
132
|
+
}
|
|
133
|
+
} catch (err) {
|
|
134
|
+
result.failed++;
|
|
135
|
+
const errorMessage = err instanceof Error ? err.message : String(err);
|
|
136
|
+
result.errors.push({ item, error: errorMessage });
|
|
137
|
+
|
|
138
|
+
if (onError) {
|
|
139
|
+
const shouldContinue = onError(err instanceof Error ? err : new Error(errorMessage), item);
|
|
140
|
+
if (shouldContinue === false) {
|
|
141
|
+
shouldStop = true;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
})
|
|
146
|
+
);
|
|
147
|
+
|
|
148
|
+
// Add delay between batches if specified (for rate limiting)
|
|
149
|
+
if (batchDelay > 0 && chunkIndex < chunks.length - 1) {
|
|
150
|
+
await sleep(batchDelay);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
return result;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
/**
|
|
158
|
+
* Execute operations sequentially (one at a time)
|
|
159
|
+
* Useful when operations must be processed in order
|
|
160
|
+
*/
|
|
161
|
+
export async function executeSequential<T, R = void>(
|
|
162
|
+
options: Omit<BulkOperationOptions<T>, 'concurrency'>,
|
|
163
|
+
operation: (item: T) => Promise<R>
|
|
164
|
+
): Promise<BulkOperationResult<T, R>> {
|
|
165
|
+
return executeBulk({ ...options, concurrency: 1 }, operation);
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
/**
|
|
169
|
+
* Create a progress reporter for bulk operations
|
|
170
|
+
*/
|
|
171
|
+
export function createProgressReporter(prefix: string = 'Processing') {
|
|
172
|
+
let lastPercent = -1;
|
|
173
|
+
|
|
174
|
+
return (current: number, total: number, _item: unknown): void => {
|
|
175
|
+
const percent = Math.floor((current / total) * 100);
|
|
176
|
+
if (percent !== lastPercent) {
|
|
177
|
+
lastPercent = percent;
|
|
178
|
+
process.stdout.write(`\r${prefix}: ${current}/${total} (${percent}%)`);
|
|
179
|
+
if (current === total) {
|
|
180
|
+
process.stdout.write('\n');
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
};
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
/**
|
|
187
|
+
* Format bulk operation result for display
|
|
188
|
+
*/
|
|
189
|
+
export function formatBulkResult<T>(result: BulkOperationResult<T, unknown>): string {
|
|
190
|
+
const lines: string[] = [
|
|
191
|
+
`Total: ${result.total}`,
|
|
192
|
+
`Success: ${result.success}`,
|
|
193
|
+
`Failed: ${result.failed}`,
|
|
194
|
+
];
|
|
195
|
+
|
|
196
|
+
if (result.skipped > 0) {
|
|
197
|
+
lines.push(`Skipped (dry run): ${result.skipped}`);
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
if (result.errors.length > 0) {
|
|
201
|
+
lines.push('');
|
|
202
|
+
lines.push('Errors:');
|
|
203
|
+
for (const { error } of result.errors.slice(0, 10)) {
|
|
204
|
+
lines.push(` - ${error}`);
|
|
205
|
+
}
|
|
206
|
+
if (result.errors.length > 10) {
|
|
207
|
+
lines.push(` ... and ${result.errors.length - 10} more errors`);
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
return lines.join('\n');
|
|
212
|
+
}
|