@hasna/connectors 0.4.0 → 0.4.2
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 +189 -2
- package/bin/mcp.js +176 -1
- package/bin/serve.js +175 -0
- package/connectors/connect-airtable/.env.example +11 -0
- package/connectors/connect-airtable/CLAUDE.md +121 -0
- package/connectors/connect-airtable/README.md +193 -0
- package/connectors/connect-airtable/package.json +50 -0
- package/connectors/connect-airtable/src/api/client.ts +139 -0
- package/connectors/connect-airtable/src/api/index.ts +405 -0
- package/connectors/connect-airtable/src/cli/index.ts +637 -0
- package/connectors/connect-airtable/src/index.ts +20 -0
- package/connectors/connect-airtable/src/types/index.ts +349 -0
- package/connectors/connect-airtable/src/utils/config.ts +197 -0
- package/connectors/connect-airtable/tsconfig.json +16 -0
- package/connectors/connect-amplitude/.env.example +11 -0
- package/connectors/connect-amplitude/CLAUDE.md +121 -0
- package/connectors/connect-amplitude/README.md +193 -0
- package/connectors/connect-amplitude/package.json +51 -0
- package/connectors/connect-amplitude/src/api/client.ts +144 -0
- package/connectors/connect-amplitude/src/api/index.ts +215 -0
- package/connectors/connect-amplitude/src/cli/index.ts +532 -0
- package/connectors/connect-amplitude/src/index.ts +22 -0
- package/connectors/connect-amplitude/src/types/index.ts +329 -0
- package/connectors/connect-amplitude/src/utils/config.ts +208 -0
- package/connectors/connect-amplitude/tsconfig.json +16 -0
- package/connectors/connect-calendly/.env.example +11 -0
- package/connectors/connect-calendly/CLAUDE.md +272 -0
- package/connectors/connect-calendly/README.md +193 -0
- package/connectors/connect-calendly/package.json +51 -0
- package/connectors/connect-calendly/scripts/release.ts +179 -0
- package/connectors/connect-calendly/src/api/client.ts +213 -0
- package/connectors/connect-calendly/src/api/example.ts +48 -0
- package/connectors/connect-calendly/src/api/index.ts +51 -0
- package/connectors/connect-calendly/src/cli/index.ts +254 -0
- package/connectors/connect-calendly/src/index.ts +103 -0
- package/connectors/connect-calendly/src/types/index.ts +237 -0
- package/connectors/connect-calendly/src/utils/auth.ts +274 -0
- package/connectors/connect-calendly/src/utils/bulk.ts +212 -0
- package/connectors/connect-calendly/src/utils/config.ts +326 -0
- package/connectors/connect-calendly/src/utils/output.ts +175 -0
- package/connectors/connect-calendly/src/utils/settings.ts +114 -0
- package/connectors/connect-calendly/src/utils/storage.ts +198 -0
- package/connectors/connect-calendly/tsconfig.json +16 -0
- package/connectors/connect-convertkit/.env.example +11 -0
- package/connectors/connect-convertkit/CLAUDE.md +272 -0
- package/connectors/connect-convertkit/README.md +193 -0
- package/connectors/connect-convertkit/package.json +51 -0
- package/connectors/connect-convertkit/scripts/release.ts +179 -0
- package/connectors/connect-convertkit/src/api/client.ts +213 -0
- package/connectors/connect-convertkit/src/api/example.ts +48 -0
- package/connectors/connect-convertkit/src/api/index.ts +51 -0
- package/connectors/connect-convertkit/src/cli/index.ts +254 -0
- package/connectors/connect-convertkit/src/index.ts +103 -0
- package/connectors/connect-convertkit/src/types/index.ts +237 -0
- package/connectors/connect-convertkit/src/utils/auth.ts +274 -0
- package/connectors/connect-convertkit/src/utils/bulk.ts +212 -0
- package/connectors/connect-convertkit/src/utils/config.ts +326 -0
- package/connectors/connect-convertkit/src/utils/output.ts +175 -0
- package/connectors/connect-convertkit/src/utils/settings.ts +114 -0
- package/connectors/connect-convertkit/src/utils/storage.ts +198 -0
- package/connectors/connect-convertkit/tsconfig.json +16 -0
- package/connectors/connect-crisp/.env.example +11 -0
- package/connectors/connect-crisp/CLAUDE.md +272 -0
- package/connectors/connect-crisp/README.md +193 -0
- package/connectors/connect-crisp/package.json +51 -0
- package/connectors/connect-crisp/scripts/release.ts +179 -0
- package/connectors/connect-crisp/src/api/client.ts +213 -0
- package/connectors/connect-crisp/src/api/example.ts +48 -0
- package/connectors/connect-crisp/src/api/index.ts +51 -0
- package/connectors/connect-crisp/src/cli/index.ts +254 -0
- package/connectors/connect-crisp/src/index.ts +103 -0
- package/connectors/connect-crisp/src/types/index.ts +237 -0
- package/connectors/connect-crisp/src/utils/auth.ts +274 -0
- package/connectors/connect-crisp/src/utils/bulk.ts +212 -0
- package/connectors/connect-crisp/src/utils/config.ts +326 -0
- package/connectors/connect-crisp/src/utils/output.ts +175 -0
- package/connectors/connect-crisp/src/utils/settings.ts +114 -0
- package/connectors/connect-crisp/src/utils/storage.ts +198 -0
- package/connectors/connect-crisp/tsconfig.json +16 -0
- package/connectors/connect-docusign/.env.example +11 -0
- package/connectors/connect-docusign/CLAUDE.md +128 -0
- package/connectors/connect-docusign/README.md +193 -0
- package/connectors/connect-docusign/package.json +52 -0
- package/connectors/connect-docusign/src/api/client.ts +133 -0
- package/connectors/connect-docusign/src/api/index.ts +178 -0
- package/connectors/connect-docusign/src/cli/index.ts +381 -0
- package/connectors/connect-docusign/src/index.ts +23 -0
- package/connectors/connect-docusign/src/types/index.ts +208 -0
- package/connectors/connect-docusign/src/utils/config.ts +125 -0
- package/connectors/connect-docusign/src/utils/output.ts +119 -0
- package/connectors/connect-docusign/tsconfig.json +16 -0
- package/connectors/connect-drift/.env.example +11 -0
- package/connectors/connect-drift/CLAUDE.md +272 -0
- package/connectors/connect-drift/README.md +193 -0
- package/connectors/connect-drift/package.json +51 -0
- package/connectors/connect-drift/scripts/release.ts +179 -0
- package/connectors/connect-drift/src/api/client.ts +213 -0
- package/connectors/connect-drift/src/api/example.ts +48 -0
- package/connectors/connect-drift/src/api/index.ts +51 -0
- package/connectors/connect-drift/src/cli/index.ts +254 -0
- package/connectors/connect-drift/src/index.ts +103 -0
- package/connectors/connect-drift/src/types/index.ts +237 -0
- package/connectors/connect-drift/src/utils/auth.ts +274 -0
- package/connectors/connect-drift/src/utils/bulk.ts +212 -0
- package/connectors/connect-drift/src/utils/config.ts +326 -0
- package/connectors/connect-drift/src/utils/output.ts +175 -0
- package/connectors/connect-drift/src/utils/settings.ts +114 -0
- package/connectors/connect-drift/src/utils/storage.ts +198 -0
- package/connectors/connect-drift/tsconfig.json +16 -0
- package/connectors/connect-freshdesk/.env.example +11 -0
- package/connectors/connect-freshdesk/CLAUDE.md +272 -0
- package/connectors/connect-freshdesk/README.md +193 -0
- package/connectors/connect-freshdesk/package.json +51 -0
- package/connectors/connect-freshdesk/scripts/release.ts +179 -0
- package/connectors/connect-freshdesk/src/api/client.ts +213 -0
- package/connectors/connect-freshdesk/src/api/example.ts +48 -0
- package/connectors/connect-freshdesk/src/api/index.ts +51 -0
- package/connectors/connect-freshdesk/src/cli/index.ts +254 -0
- package/connectors/connect-freshdesk/src/index.ts +103 -0
- package/connectors/connect-freshdesk/src/types/index.ts +237 -0
- package/connectors/connect-freshdesk/src/utils/auth.ts +274 -0
- package/connectors/connect-freshdesk/src/utils/bulk.ts +212 -0
- package/connectors/connect-freshdesk/src/utils/config.ts +326 -0
- package/connectors/connect-freshdesk/src/utils/output.ts +175 -0
- package/connectors/connect-freshdesk/src/utils/settings.ts +114 -0
- package/connectors/connect-freshdesk/src/utils/storage.ts +198 -0
- package/connectors/connect-freshdesk/tsconfig.json +16 -0
- package/connectors/connect-gumroad/.env.example +11 -0
- package/connectors/connect-gumroad/CLAUDE.md +272 -0
- package/connectors/connect-gumroad/README.md +193 -0
- package/connectors/connect-gumroad/package.json +51 -0
- package/connectors/connect-gumroad/scripts/release.ts +179 -0
- package/connectors/connect-gumroad/src/api/client.ts +213 -0
- package/connectors/connect-gumroad/src/api/example.ts +48 -0
- package/connectors/connect-gumroad/src/api/index.ts +51 -0
- package/connectors/connect-gumroad/src/cli/index.ts +254 -0
- package/connectors/connect-gumroad/src/index.ts +103 -0
- package/connectors/connect-gumroad/src/types/index.ts +237 -0
- package/connectors/connect-gumroad/src/utils/auth.ts +274 -0
- package/connectors/connect-gumroad/src/utils/bulk.ts +212 -0
- package/connectors/connect-gumroad/src/utils/config.ts +326 -0
- package/connectors/connect-gumroad/src/utils/output.ts +175 -0
- package/connectors/connect-gumroad/src/utils/settings.ts +114 -0
- package/connectors/connect-gumroad/src/utils/storage.ts +198 -0
- package/connectors/connect-gumroad/tsconfig.json +16 -0
- package/connectors/connect-hubspot/.env.example +11 -0
- package/connectors/connect-hubspot/CLAUDE.md +128 -0
- package/connectors/connect-hubspot/README.md +193 -0
- package/connectors/connect-hubspot/package.json +52 -0
- package/connectors/connect-hubspot/src/api/client.ts +136 -0
- package/connectors/connect-hubspot/src/api/index.ts +379 -0
- package/connectors/connect-hubspot/src/cli/index.ts +589 -0
- package/connectors/connect-hubspot/src/index.ts +21 -0
- package/connectors/connect-hubspot/src/types/index.ts +285 -0
- package/connectors/connect-hubspot/src/utils/config.ts +205 -0
- package/connectors/connect-hubspot/src/utils/output.ts +119 -0
- package/connectors/connect-hubspot/tsconfig.json +16 -0
- package/connectors/connect-intercom/.env.example +11 -0
- package/connectors/connect-intercom/CLAUDE.md +131 -0
- package/connectors/connect-intercom/README.md +193 -0
- package/connectors/connect-intercom/package.json +52 -0
- package/connectors/connect-intercom/src/api/client.ts +132 -0
- package/connectors/connect-intercom/src/api/index.ts +366 -0
- package/connectors/connect-intercom/src/cli/index.ts +831 -0
- package/connectors/connect-intercom/src/index.ts +21 -0
- package/connectors/connect-intercom/src/types/index.ts +650 -0
- package/connectors/connect-intercom/src/utils/config.ts +157 -0
- package/connectors/connect-intercom/src/utils/output.ts +119 -0
- package/connectors/connect-intercom/tsconfig.json +16 -0
- package/connectors/connect-lemonsqueezy/.env.example +11 -0
- package/connectors/connect-lemonsqueezy/CLAUDE.md +128 -0
- package/connectors/connect-lemonsqueezy/README.md +193 -0
- package/connectors/connect-lemonsqueezy/package.json +52 -0
- package/connectors/connect-lemonsqueezy/src/api/client.ts +133 -0
- package/connectors/connect-lemonsqueezy/src/api/index.ts +502 -0
- package/connectors/connect-lemonsqueezy/src/cli/index.ts +723 -0
- package/connectors/connect-lemonsqueezy/src/index.ts +21 -0
- package/connectors/connect-lemonsqueezy/src/types/index.ts +353 -0
- package/connectors/connect-lemonsqueezy/src/utils/config.ts +205 -0
- package/connectors/connect-lemonsqueezy/src/utils/output.ts +119 -0
- package/connectors/connect-lemonsqueezy/tsconfig.json +16 -0
- package/connectors/connect-linkedin/.env.example +11 -0
- package/connectors/connect-linkedin/CLAUDE.md +124 -0
- package/connectors/connect-linkedin/README.md +193 -0
- package/connectors/connect-linkedin/package.json +52 -0
- package/connectors/connect-linkedin/src/api/client.ts +132 -0
- package/connectors/connect-linkedin/src/api/index.ts +313 -0
- package/connectors/connect-linkedin/src/cli/index.ts +548 -0
- package/connectors/connect-linkedin/src/index.ts +21 -0
- package/connectors/connect-linkedin/src/types/index.ts +472 -0
- package/connectors/connect-linkedin/src/utils/config.ts +157 -0
- package/connectors/connect-linkedin/src/utils/output.ts +119 -0
- package/connectors/connect-linkedin/tsconfig.json +16 -0
- package/connectors/connect-mailchimp/.env.example +11 -0
- package/connectors/connect-mailchimp/CLAUDE.md +127 -0
- package/connectors/connect-mailchimp/README.md +193 -0
- package/connectors/connect-mailchimp/package.json +52 -0
- package/connectors/connect-mailchimp/src/api/client.ts +162 -0
- package/connectors/connect-mailchimp/src/api/index.ts +580 -0
- package/connectors/connect-mailchimp/src/cli/index.ts +822 -0
- package/connectors/connect-mailchimp/src/index.ts +23 -0
- package/connectors/connect-mailchimp/src/types/index.ts +585 -0
- package/connectors/connect-mailchimp/src/utils/config.ts +208 -0
- package/connectors/connect-mailchimp/src/utils/output.ts +119 -0
- package/connectors/connect-mailchimp/tsconfig.json +16 -0
- package/connectors/connect-mongodb/.env.example +11 -0
- package/connectors/connect-mongodb/CLAUDE.md +272 -0
- package/connectors/connect-mongodb/README.md +193 -0
- package/connectors/connect-mongodb/package.json +51 -0
- package/connectors/connect-mongodb/scripts/release.ts +179 -0
- package/connectors/connect-mongodb/src/api/client.ts +213 -0
- package/connectors/connect-mongodb/src/api/example.ts +48 -0
- package/connectors/connect-mongodb/src/api/index.ts +51 -0
- package/connectors/connect-mongodb/src/cli/index.ts +254 -0
- package/connectors/connect-mongodb/src/index.ts +103 -0
- package/connectors/connect-mongodb/src/types/index.ts +237 -0
- package/connectors/connect-mongodb/src/utils/auth.ts +274 -0
- package/connectors/connect-mongodb/src/utils/bulk.ts +212 -0
- package/connectors/connect-mongodb/src/utils/config.ts +326 -0
- package/connectors/connect-mongodb/src/utils/output.ts +175 -0
- package/connectors/connect-mongodb/src/utils/settings.ts +114 -0
- package/connectors/connect-mongodb/src/utils/storage.ts +198 -0
- package/connectors/connect-mongodb/tsconfig.json +16 -0
- package/connectors/connect-netlify/.env.example +11 -0
- package/connectors/connect-netlify/CLAUDE.md +170 -0
- package/connectors/connect-netlify/README.md +193 -0
- package/connectors/connect-netlify/package.json +53 -0
- package/connectors/connect-netlify/src/api/client.ts +132 -0
- package/connectors/connect-netlify/src/api/index.ts +533 -0
- package/connectors/connect-netlify/src/cli/index.ts +985 -0
- package/connectors/connect-netlify/src/index.ts +22 -0
- package/connectors/connect-netlify/src/types/index.ts +423 -0
- package/connectors/connect-netlify/src/utils/config.ts +171 -0
- package/connectors/connect-netlify/src/utils/output.ts +119 -0
- package/connectors/connect-netlify/tsconfig.json +16 -0
- package/connectors/connect-paypal/.env.example +11 -0
- package/connectors/connect-paypal/CLAUDE.md +128 -0
- package/connectors/connect-paypal/README.md +193 -0
- package/connectors/connect-paypal/package.json +51 -0
- package/connectors/connect-paypal/src/api/client.ts +182 -0
- package/connectors/connect-paypal/src/api/index.ts +235 -0
- package/connectors/connect-paypal/src/cli/index.ts +559 -0
- package/connectors/connect-paypal/src/index.ts +23 -0
- package/connectors/connect-paypal/src/types/index.ts +377 -0
- package/connectors/connect-paypal/src/utils/config.ts +125 -0
- package/connectors/connect-paypal/src/utils/output.ts +119 -0
- package/connectors/connect-paypal/tsconfig.json +16 -0
- package/connectors/connect-pinterest/.env.example +11 -0
- package/connectors/connect-pinterest/CLAUDE.md +115 -0
- package/connectors/connect-pinterest/README.md +193 -0
- package/connectors/connect-pinterest/package.json +52 -0
- package/connectors/connect-pinterest/src/api/client.ts +125 -0
- package/connectors/connect-pinterest/src/api/index.ts +203 -0
- package/connectors/connect-pinterest/src/cli/index.ts +653 -0
- package/connectors/connect-pinterest/src/index.ts +21 -0
- package/connectors/connect-pinterest/src/types/index.ts +268 -0
- package/connectors/connect-pinterest/src/utils/config.ts +157 -0
- package/connectors/connect-pinterest/src/utils/output.ts +119 -0
- package/connectors/connect-pinterest/tsconfig.json +16 -0
- package/connectors/connect-posthog/.env.example +11 -0
- package/connectors/connect-posthog/CLAUDE.md +272 -0
- package/connectors/connect-posthog/README.md +193 -0
- package/connectors/connect-posthog/package.json +51 -0
- package/connectors/connect-posthog/scripts/release.ts +179 -0
- package/connectors/connect-posthog/src/api/client.ts +213 -0
- package/connectors/connect-posthog/src/api/example.ts +48 -0
- package/connectors/connect-posthog/src/api/index.ts +51 -0
- package/connectors/connect-posthog/src/cli/index.ts +254 -0
- package/connectors/connect-posthog/src/index.ts +103 -0
- package/connectors/connect-posthog/src/types/index.ts +237 -0
- package/connectors/connect-posthog/src/utils/auth.ts +274 -0
- package/connectors/connect-posthog/src/utils/bulk.ts +212 -0
- package/connectors/connect-posthog/src/utils/config.ts +326 -0
- package/connectors/connect-posthog/src/utils/output.ts +175 -0
- package/connectors/connect-posthog/src/utils/settings.ts +114 -0
- package/connectors/connect-posthog/src/utils/storage.ts +198 -0
- package/connectors/connect-posthog/tsconfig.json +16 -0
- package/connectors/connect-salesforce/.env.example +11 -0
- package/connectors/connect-salesforce/CLAUDE.md +128 -0
- package/connectors/connect-salesforce/README.md +193 -0
- package/connectors/connect-salesforce/package.json +53 -0
- package/connectors/connect-salesforce/src/api/client.ts +150 -0
- package/connectors/connect-salesforce/src/api/index.ts +367 -0
- package/connectors/connect-salesforce/src/cli/index.ts +594 -0
- package/connectors/connect-salesforce/src/index.ts +21 -0
- package/connectors/connect-salesforce/src/types/index.ts +292 -0
- package/connectors/connect-salesforce/src/utils/config.ts +208 -0
- package/connectors/connect-salesforce/src/utils/output.ts +119 -0
- package/connectors/connect-salesforce/tsconfig.json +16 -0
- package/connectors/connect-segment/.env.example +11 -0
- package/connectors/connect-segment/CLAUDE.md +272 -0
- package/connectors/connect-segment/README.md +193 -0
- package/connectors/connect-segment/package.json +51 -0
- package/connectors/connect-segment/scripts/release.ts +179 -0
- package/connectors/connect-segment/src/api/client.ts +213 -0
- package/connectors/connect-segment/src/api/example.ts +48 -0
- package/connectors/connect-segment/src/api/index.ts +51 -0
- package/connectors/connect-segment/src/cli/index.ts +254 -0
- package/connectors/connect-segment/src/index.ts +103 -0
- package/connectors/connect-segment/src/types/index.ts +237 -0
- package/connectors/connect-segment/src/utils/auth.ts +274 -0
- package/connectors/connect-segment/src/utils/bulk.ts +212 -0
- package/connectors/connect-segment/src/utils/config.ts +326 -0
- package/connectors/connect-segment/src/utils/output.ts +175 -0
- package/connectors/connect-segment/src/utils/settings.ts +114 -0
- package/connectors/connect-segment/src/utils/storage.ts +198 -0
- package/connectors/connect-segment/tsconfig.json +16 -0
- package/connectors/connect-sendgrid/.env.example +11 -0
- package/connectors/connect-sendgrid/CLAUDE.md +125 -0
- package/connectors/connect-sendgrid/README.md +193 -0
- package/connectors/connect-sendgrid/package.json +53 -0
- package/connectors/connect-sendgrid/src/api/client.ts +137 -0
- package/connectors/connect-sendgrid/src/api/index.ts +588 -0
- package/connectors/connect-sendgrid/src/cli/index.ts +764 -0
- package/connectors/connect-sendgrid/src/index.ts +21 -0
- package/connectors/connect-sendgrid/src/types/index.ts +403 -0
- package/connectors/connect-sendgrid/src/utils/config.ts +197 -0
- package/connectors/connect-sendgrid/src/utils/output.ts +119 -0
- package/connectors/connect-sendgrid/tsconfig.json +16 -0
- package/connectors/connect-supabase/.env.example +11 -0
- package/connectors/connect-supabase/CLAUDE.md +132 -0
- package/connectors/connect-supabase/README.md +193 -0
- package/connectors/connect-supabase/package.json +52 -0
- package/connectors/connect-supabase/src/api/client.ts +231 -0
- package/connectors/connect-supabase/src/api/index.ts +439 -0
- package/connectors/connect-supabase/src/cli/index.ts +691 -0
- package/connectors/connect-supabase/src/index.ts +24 -0
- package/connectors/connect-supabase/src/types/index.ts +215 -0
- package/connectors/connect-supabase/src/utils/config.ts +219 -0
- package/connectors/connect-supabase/tsconfig.json +16 -0
- package/connectors/connect-vercel/.env.example +11 -0
- package/connectors/connect-vercel/CLAUDE.md +142 -0
- package/connectors/connect-vercel/README.md +193 -0
- package/connectors/connect-vercel/package.json +52 -0
- package/connectors/connect-vercel/src/api/client.ts +139 -0
- package/connectors/connect-vercel/src/api/index.ts +384 -0
- package/connectors/connect-vercel/src/cli/index.ts +740 -0
- package/connectors/connect-vercel/src/index.ts +24 -0
- package/connectors/connect-vercel/src/types/index.ts +350 -0
- package/connectors/connect-vercel/src/utils/config.ts +182 -0
- package/connectors/connect-vercel/src/utils/output.ts +119 -0
- package/connectors/connect-vercel/tsconfig.json +16 -0
- package/connectors/connect-zendesk/.env.example +10 -0
- package/connectors/connect-zendesk/.github/workflows/deploy.yml +51 -0
- package/connectors/connect-zendesk/CLAUDE.md +78 -0
- package/connectors/connect-zendesk/Makefile +129 -0
- package/connectors/connect-zendesk/README.md +295 -0
- package/connectors/connect-zendesk/SCAFFOLD.md +178 -0
- package/connectors/connect-zendesk/nginx-connector.conf +218 -0
- package/connectors/connect-zendesk/nginx.conf +61 -0
- package/connectors/connect-zendesk/package.json +71 -0
- package/connectors/connect-zendesk/scripts/init.sh +62 -0
- package/connectors/connect-zendesk/scripts/publish.ts +210 -0
- package/connectors/connect-zendesk/server/index.js +142 -0
- package/connectors/connect-zendesk/src/api/automations.ts +95 -0
- package/connectors/connect-zendesk/src/api/brands.ts +80 -0
- package/connectors/connect-zendesk/src/api/bulk.ts +838 -0
- package/connectors/connect-zendesk/src/api/client.test.ts +315 -0
- package/connectors/connect-zendesk/src/api/client.ts +173 -0
- package/connectors/connect-zendesk/src/api/example.ts +59 -0
- package/connectors/connect-zendesk/src/api/groups.ts +60 -0
- package/connectors/connect-zendesk/src/api/index.test.ts +111 -0
- package/connectors/connect-zendesk/src/api/index.ts +131 -0
- package/connectors/connect-zendesk/src/api/macros.ts +124 -0
- package/connectors/connect-zendesk/src/api/organizations.ts +85 -0
- package/connectors/connect-zendesk/src/api/slas.ts +80 -0
- package/connectors/connect-zendesk/src/api/ticket-fields.ts +98 -0
- package/connectors/connect-zendesk/src/api/tickets.test.ts +215 -0
- package/connectors/connect-zendesk/src/api/tickets.ts +103 -0
- package/connectors/connect-zendesk/src/api/triggers.test.ts +204 -0
- package/connectors/connect-zendesk/src/api/triggers.ts +125 -0
- package/connectors/connect-zendesk/src/api/users.test.ts +180 -0
- package/connectors/connect-zendesk/src/api/users.ts +108 -0
- package/connectors/connect-zendesk/src/api/views.test.ts +223 -0
- package/connectors/connect-zendesk/src/api/views.ts +145 -0
- package/connectors/connect-zendesk/src/api/webhooks.test.ts +208 -0
- package/connectors/connect-zendesk/src/api/webhooks.ts +118 -0
- package/connectors/connect-zendesk/src/cli/index.ts +1478 -0
- package/connectors/connect-zendesk/src/index.ts +36 -0
- package/connectors/connect-zendesk/src/server/index.ts +204 -0
- package/connectors/connect-zendesk/src/types/index.ts +910 -0
- package/connectors/connect-zendesk/src/utils/config.test.ts +193 -0
- package/connectors/connect-zendesk/src/utils/config.ts +526 -0
- package/connectors/connect-zendesk/src/utils/export.ts +338 -0
- package/connectors/connect-zendesk/src/utils/logger.ts +105 -0
- package/connectors/connect-zendesk/src/utils/output.test.ts +137 -0
- package/connectors/connect-zendesk/src/utils/output.ts +119 -0
- package/connectors/connect-zendesk/tsconfig.json +31 -0
- package/dist/index.js +175 -0
- package/package.json +1 -1
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
import type { ConnectorConfig, OutputFormat } from '../types';
|
|
2
|
+
import { ConnectorApiError, parseApiError } from '../types';
|
|
3
|
+
|
|
4
|
+
// TODO: Replace with your API's base URL
|
|
5
|
+
const DEFAULT_BASE_URL = 'https://api.example.com';
|
|
6
|
+
|
|
7
|
+
export interface RequestOptions {
|
|
8
|
+
method?: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';
|
|
9
|
+
params?: Record<string, string | number | boolean | undefined>;
|
|
10
|
+
body?: Record<string, unknown> | unknown[] | string;
|
|
11
|
+
headers?: Record<string, string>;
|
|
12
|
+
format?: OutputFormat;
|
|
13
|
+
/** Number of retries for failed requests (default: 3) */
|
|
14
|
+
retries?: number;
|
|
15
|
+
/** Timeout in milliseconds (default: 30000) */
|
|
16
|
+
timeout?: number;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export class ConnectorClient {
|
|
20
|
+
private readonly apiKey: string;
|
|
21
|
+
private readonly apiSecret?: string;
|
|
22
|
+
private readonly baseUrl: string;
|
|
23
|
+
|
|
24
|
+
constructor(config: ConnectorConfig) {
|
|
25
|
+
// Support both 'apiKey' and 'token' for flexibility
|
|
26
|
+
// Also support 'accessToken' for OAuth2
|
|
27
|
+
const key = config.apiKey || config.token || config.accessToken;
|
|
28
|
+
if (!key) {
|
|
29
|
+
throw new Error('API key, token, or accessToken is required');
|
|
30
|
+
}
|
|
31
|
+
this.apiKey = key;
|
|
32
|
+
this.apiSecret = config.apiSecret;
|
|
33
|
+
this.baseUrl = config.baseUrl || DEFAULT_BASE_URL;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
private buildUrl(path: string, params?: Record<string, string | number | boolean | undefined>): string {
|
|
37
|
+
const url = new URL(`${this.baseUrl}${path}`);
|
|
38
|
+
|
|
39
|
+
if (params) {
|
|
40
|
+
Object.entries(params).forEach(([key, value]) => {
|
|
41
|
+
if (value !== undefined && value !== null && value !== '') {
|
|
42
|
+
url.searchParams.append(key, String(value));
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
return url.toString();
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Sleep for a given number of milliseconds
|
|
52
|
+
*/
|
|
53
|
+
private sleep(ms: number): Promise<void> {
|
|
54
|
+
return new Promise(resolve => setTimeout(resolve, ms));
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* Calculate delay for exponential backoff
|
|
59
|
+
*/
|
|
60
|
+
private getRetryDelay(attempt: number, baseDelay: number = 1000): number {
|
|
61
|
+
// Exponential backoff with jitter: base * 2^attempt + random(0-1000)ms
|
|
62
|
+
return baseDelay * Math.pow(2, attempt) + Math.random() * 1000;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* Check if error is retryable
|
|
67
|
+
*/
|
|
68
|
+
private isRetryableStatus(status: number): boolean {
|
|
69
|
+
// Retry on rate limit (429) and server errors (5xx)
|
|
70
|
+
return status === 429 || (status >= 500 && status < 600);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
/**
|
|
74
|
+
* Make an authenticated request to the API
|
|
75
|
+
* TODO: Adjust authentication method for your API:
|
|
76
|
+
* - Bearer token: Authorization: Bearer <token>
|
|
77
|
+
* - API Key header: X-API-Key: <key>
|
|
78
|
+
* - Basic auth: Authorization: Basic <base64(key:secret)>
|
|
79
|
+
*/
|
|
80
|
+
async request<T>(path: string, options: RequestOptions = {}): Promise<T> {
|
|
81
|
+
const { method = 'GET', params, body, headers = {}, retries = 3, timeout = 30000 } = options;
|
|
82
|
+
|
|
83
|
+
const url = this.buildUrl(path, params);
|
|
84
|
+
|
|
85
|
+
// TODO: Adjust authentication header for your API
|
|
86
|
+
const requestHeaders: Record<string, string> = {
|
|
87
|
+
'Authorization': `Bearer ${this.apiKey}`,
|
|
88
|
+
'Accept': 'application/json',
|
|
89
|
+
...headers,
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
if (body && ['POST', 'PUT', 'PATCH'].includes(method)) {
|
|
93
|
+
requestHeaders['Content-Type'] = 'application/json';
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
const fetchOptions: RequestInit = {
|
|
97
|
+
method,
|
|
98
|
+
headers: requestHeaders,
|
|
99
|
+
};
|
|
100
|
+
|
|
101
|
+
if (body && ['POST', 'PUT', 'PATCH'].includes(method)) {
|
|
102
|
+
fetchOptions.body = typeof body === 'string' ? body : JSON.stringify(body);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
let lastError: Error | null = null;
|
|
106
|
+
let lastStatus: number = 0;
|
|
107
|
+
|
|
108
|
+
for (let attempt = 0; attempt <= retries; attempt++) {
|
|
109
|
+
try {
|
|
110
|
+
// Create abort controller for timeout
|
|
111
|
+
const controller = new AbortController();
|
|
112
|
+
const timeoutId = setTimeout(() => controller.abort(), timeout);
|
|
113
|
+
|
|
114
|
+
const response = await fetch(url, {
|
|
115
|
+
...fetchOptions,
|
|
116
|
+
signal: controller.signal,
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
clearTimeout(timeoutId);
|
|
120
|
+
lastStatus = response.status;
|
|
121
|
+
|
|
122
|
+
// Handle 204 No Content
|
|
123
|
+
if (response.status === 204) {
|
|
124
|
+
return {} as T;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
// Parse response
|
|
128
|
+
let data: unknown;
|
|
129
|
+
const contentType = response.headers.get('content-type') || '';
|
|
130
|
+
|
|
131
|
+
if (contentType.includes('application/json')) {
|
|
132
|
+
const text = await response.text();
|
|
133
|
+
if (text) {
|
|
134
|
+
try {
|
|
135
|
+
data = JSON.parse(text);
|
|
136
|
+
} catch {
|
|
137
|
+
data = text;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
} else {
|
|
141
|
+
data = await response.text();
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
// Handle errors
|
|
145
|
+
if (!response.ok) {
|
|
146
|
+
// Check if we should retry
|
|
147
|
+
if (this.isRetryableStatus(response.status) && attempt < retries) {
|
|
148
|
+
// Check for Retry-After header
|
|
149
|
+
const retryAfter = response.headers.get('retry-after');
|
|
150
|
+
const delay = retryAfter
|
|
151
|
+
? parseInt(retryAfter, 10) * 1000
|
|
152
|
+
: this.getRetryDelay(attempt);
|
|
153
|
+
|
|
154
|
+
await this.sleep(delay);
|
|
155
|
+
continue;
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
throw parseApiError(data, response.status);
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
return data as T;
|
|
162
|
+
} catch (err) {
|
|
163
|
+
lastError = err instanceof Error ? err : new Error(String(err));
|
|
164
|
+
|
|
165
|
+
// Handle timeout errors
|
|
166
|
+
if (lastError.name === 'AbortError') {
|
|
167
|
+
lastError = new Error(`Request timeout after ${timeout}ms`);
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
// Retry on network errors
|
|
171
|
+
if (attempt < retries && !(err instanceof ConnectorApiError)) {
|
|
172
|
+
await this.sleep(this.getRetryDelay(attempt));
|
|
173
|
+
continue;
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
throw err;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
// Should not reach here, but just in case
|
|
181
|
+
throw lastError || new ConnectorApiError('Request failed', lastStatus);
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
async get<T>(path: string, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
|
|
185
|
+
return this.request<T>(path, { method: 'GET', params });
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
async post<T>(path: string, body?: Record<string, unknown> | unknown[] | string | object, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
|
|
189
|
+
return this.request<T>(path, { method: 'POST', body: body as Record<string, unknown>, params });
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
async put<T>(path: string, body?: Record<string, unknown> | object, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
|
|
193
|
+
return this.request<T>(path, { method: 'PUT', body: body as Record<string, unknown>, params });
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
async patch<T>(path: string, body?: Record<string, unknown> | object, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
|
|
197
|
+
return this.request<T>(path, { method: 'PATCH', body: body as Record<string, unknown>, params });
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
async delete<T>(path: string, params?: Record<string, string | number | boolean | undefined>): Promise<T> {
|
|
201
|
+
return this.request<T>(path, { method: 'DELETE', params });
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
/**
|
|
205
|
+
* Get a preview of the API key (for display/debugging)
|
|
206
|
+
*/
|
|
207
|
+
getApiKeyPreview(): string {
|
|
208
|
+
if (this.apiKey.length > 10) {
|
|
209
|
+
return `${this.apiKey.substring(0, 6)}...${this.apiKey.substring(this.apiKey.length - 4)}`;
|
|
210
|
+
}
|
|
211
|
+
return '***';
|
|
212
|
+
}
|
|
213
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import type { ConnectorClient } from './client';
|
|
2
|
+
import type { ExampleResource, ExampleListResponse, ExampleCreateParams } from '../types';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Example API module - demonstrates the pattern for API modules
|
|
6
|
+
* TODO: Replace with your actual API endpoints
|
|
7
|
+
*/
|
|
8
|
+
export class ExampleApi {
|
|
9
|
+
constructor(private readonly client: ConnectorClient) {}
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* List resources with optional pagination
|
|
13
|
+
*/
|
|
14
|
+
async list(options?: { maxResults?: number; pageToken?: string }): Promise<ExampleListResponse> {
|
|
15
|
+
return this.client.get<ExampleListResponse>('/resources', {
|
|
16
|
+
max_results: options?.maxResults,
|
|
17
|
+
page_token: options?.pageToken,
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Get a single resource by ID
|
|
23
|
+
*/
|
|
24
|
+
async get(id: string): Promise<ExampleResource> {
|
|
25
|
+
return this.client.get<ExampleResource>(`/resources/${id}`);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Create a new resource
|
|
30
|
+
*/
|
|
31
|
+
async create(params: ExampleCreateParams): Promise<ExampleResource> {
|
|
32
|
+
return this.client.post<ExampleResource>('/resources', params);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Update an existing resource
|
|
37
|
+
*/
|
|
38
|
+
async update(id: string, params: Partial<ExampleCreateParams>): Promise<ExampleResource> {
|
|
39
|
+
return this.client.patch<ExampleResource>(`/resources/${id}`, params);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Delete a resource
|
|
44
|
+
*/
|
|
45
|
+
async delete(id: string): Promise<void> {
|
|
46
|
+
await this.client.delete(`/resources/${id}`);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import type { ConnectorConfig } from '../types';
|
|
2
|
+
import { ConnectorClient } from './client';
|
|
3
|
+
import { ExampleApi } from './example';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Main Connector class
|
|
7
|
+
* TODO: Rename to your API name (e.g., Perplexity, Twitter, etc.)
|
|
8
|
+
*/
|
|
9
|
+
export class Connector {
|
|
10
|
+
private readonly client: ConnectorClient;
|
|
11
|
+
|
|
12
|
+
// API modules - add more as needed
|
|
13
|
+
public readonly example: ExampleApi;
|
|
14
|
+
|
|
15
|
+
constructor(config: ConnectorConfig) {
|
|
16
|
+
this.client = new ConnectorClient(config);
|
|
17
|
+
this.example = new ExampleApi(this.client);
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Create a client from environment variables
|
|
22
|
+
* TODO: Update env var names for your API
|
|
23
|
+
* Looks for CONNECTOR_API_KEY and optionally CONNECTOR_API_SECRET
|
|
24
|
+
*/
|
|
25
|
+
static fromEnv(): Connector {
|
|
26
|
+
const apiKey = process.env.CONNECTOR_API_KEY;
|
|
27
|
+
const apiSecret = process.env.CONNECTOR_API_SECRET;
|
|
28
|
+
|
|
29
|
+
if (!apiKey) {
|
|
30
|
+
throw new Error('CONNECTOR_API_KEY environment variable is required');
|
|
31
|
+
}
|
|
32
|
+
return new Connector({ apiKey, apiSecret });
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Get a preview of the API key (for debugging)
|
|
37
|
+
*/
|
|
38
|
+
getApiKeyPreview(): string {
|
|
39
|
+
return this.client.getApiKeyPreview();
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Get the underlying client for direct API access
|
|
44
|
+
*/
|
|
45
|
+
getClient(): ConnectorClient {
|
|
46
|
+
return this.client;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
export { ConnectorClient } from './client';
|
|
51
|
+
export { ExampleApi } from './example';
|
|
@@ -0,0 +1,254 @@
|
|
|
1
|
+
#!/usr/bin/env bun
|
|
2
|
+
import { Command } from 'commander';
|
|
3
|
+
import chalk from 'chalk';
|
|
4
|
+
import { Connector } from '../api';
|
|
5
|
+
import {
|
|
6
|
+
getApiKey,
|
|
7
|
+
setApiKey,
|
|
8
|
+
clearConfig,
|
|
9
|
+
getConfigDir,
|
|
10
|
+
setProfileOverride,
|
|
11
|
+
getCurrentProfile,
|
|
12
|
+
setCurrentProfile,
|
|
13
|
+
listProfiles,
|
|
14
|
+
createProfile,
|
|
15
|
+
deleteProfile,
|
|
16
|
+
profileExists,
|
|
17
|
+
loadProfile,
|
|
18
|
+
} from '../utils/config';
|
|
19
|
+
import type { OutputFormat } from '../utils/output';
|
|
20
|
+
import { success, error, info, print, warn, setVerboseMode, debug } from '../utils/output';
|
|
21
|
+
|
|
22
|
+
// TODO: Update connector name and version
|
|
23
|
+
const CONNECTOR_NAME = 'connector';
|
|
24
|
+
const VERSION = '0.1.0';
|
|
25
|
+
|
|
26
|
+
const program = new Command();
|
|
27
|
+
|
|
28
|
+
program
|
|
29
|
+
.name(CONNECTOR_NAME)
|
|
30
|
+
.description('API connector CLI - TODO: Add your description')
|
|
31
|
+
.version(VERSION)
|
|
32
|
+
.option('-k, --api-key <key>', 'API key (overrides config)')
|
|
33
|
+
.option('-f, --format <format>', 'Output format (json, pretty)', 'pretty')
|
|
34
|
+
.option('-p, --profile <profile>', 'Use a specific profile')
|
|
35
|
+
.option('-v, --verbose', 'Enable verbose output for debugging')
|
|
36
|
+
.hook('preAction', (thisCommand) => {
|
|
37
|
+
const opts = thisCommand.opts();
|
|
38
|
+
|
|
39
|
+
// Enable verbose mode if flag is set
|
|
40
|
+
if (opts.verbose) {
|
|
41
|
+
setVerboseMode(true);
|
|
42
|
+
debug('Verbose mode enabled');
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
// Set profile override before any command runs
|
|
46
|
+
if (opts.profile) {
|
|
47
|
+
if (!profileExists(opts.profile)) {
|
|
48
|
+
error(`Profile "${opts.profile}" does not exist. Create it with "${CONNECTOR_NAME} profile create ${opts.profile}"`);
|
|
49
|
+
process.exit(1);
|
|
50
|
+
}
|
|
51
|
+
setProfileOverride(opts.profile);
|
|
52
|
+
debug(`Using profile: ${opts.profile}`);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
// Set API key from flag if provided
|
|
56
|
+
if (opts.apiKey) {
|
|
57
|
+
process.env.CONNECTOR_API_KEY = opts.apiKey;
|
|
58
|
+
debug('API key set from command line flag');
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
// Helper to get output format
|
|
63
|
+
function getFormat(cmd: Command): OutputFormat {
|
|
64
|
+
const parent = cmd.parent;
|
|
65
|
+
return (parent?.opts().format || 'pretty') as OutputFormat;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
// Helper to get authenticated client
|
|
69
|
+
function getClient(): Connector {
|
|
70
|
+
const apiKey = getApiKey();
|
|
71
|
+
if (!apiKey) {
|
|
72
|
+
error(`No API key configured. Run "${CONNECTOR_NAME} config set-key <key>" or set CONNECTOR_API_KEY environment variable.`);
|
|
73
|
+
process.exit(1);
|
|
74
|
+
}
|
|
75
|
+
return new Connector({ apiKey });
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
// ============================================
|
|
79
|
+
// Profile Commands
|
|
80
|
+
// ============================================
|
|
81
|
+
const profileCmd = program
|
|
82
|
+
.command('profile')
|
|
83
|
+
.description('Manage configuration profiles');
|
|
84
|
+
|
|
85
|
+
profileCmd
|
|
86
|
+
.command('list')
|
|
87
|
+
.description('List all profiles')
|
|
88
|
+
.action(() => {
|
|
89
|
+
const profiles = listProfiles();
|
|
90
|
+
const current = getCurrentProfile();
|
|
91
|
+
|
|
92
|
+
if (profiles.length === 0) {
|
|
93
|
+
info('No profiles found. Use "profile create <name>" to create one.');
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
success(`Profiles:`);
|
|
98
|
+
profiles.forEach(p => {
|
|
99
|
+
const isActive = p === current ? chalk.green(' (active)') : '';
|
|
100
|
+
console.log(` ${p}${isActive}`);
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
profileCmd
|
|
105
|
+
.command('use <name>')
|
|
106
|
+
.description('Switch to a profile')
|
|
107
|
+
.action((name: string) => {
|
|
108
|
+
if (!profileExists(name)) {
|
|
109
|
+
error(`Profile "${name}" does not exist. Create it with "profile create ${name}"`);
|
|
110
|
+
process.exit(1);
|
|
111
|
+
}
|
|
112
|
+
setCurrentProfile(name);
|
|
113
|
+
success(`Switched to profile: ${name}`);
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
profileCmd
|
|
117
|
+
.command('create <name>')
|
|
118
|
+
.description('Create a new profile')
|
|
119
|
+
.option('--api-key <key>', 'API key')
|
|
120
|
+
.option('--use', 'Switch to this profile after creation')
|
|
121
|
+
.action((name: string, opts) => {
|
|
122
|
+
if (profileExists(name)) {
|
|
123
|
+
error(`Profile "${name}" already exists`);
|
|
124
|
+
process.exit(1);
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
createProfile(name, {
|
|
128
|
+
apiKey: opts.apiKey,
|
|
129
|
+
});
|
|
130
|
+
success(`Profile "${name}" created`);
|
|
131
|
+
|
|
132
|
+
if (opts.use) {
|
|
133
|
+
setCurrentProfile(name);
|
|
134
|
+
info(`Switched to profile: ${name}`);
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
|
|
138
|
+
profileCmd
|
|
139
|
+
.command('delete <name>')
|
|
140
|
+
.description('Delete a profile')
|
|
141
|
+
.action((name: string) => {
|
|
142
|
+
if (name === 'default') {
|
|
143
|
+
error('Cannot delete the default profile');
|
|
144
|
+
process.exit(1);
|
|
145
|
+
}
|
|
146
|
+
if (deleteProfile(name)) {
|
|
147
|
+
success(`Profile "${name}" deleted`);
|
|
148
|
+
} else {
|
|
149
|
+
error(`Profile "${name}" not found`);
|
|
150
|
+
process.exit(1);
|
|
151
|
+
}
|
|
152
|
+
});
|
|
153
|
+
|
|
154
|
+
profileCmd
|
|
155
|
+
.command('show [name]')
|
|
156
|
+
.description('Show profile configuration')
|
|
157
|
+
.action((name?: string) => {
|
|
158
|
+
const profileName = name || getCurrentProfile();
|
|
159
|
+
const config = loadProfile(profileName);
|
|
160
|
+
const active = getCurrentProfile();
|
|
161
|
+
|
|
162
|
+
console.log(chalk.bold(`Profile: ${profileName}${profileName === active ? chalk.green(' (active)') : ''}`));
|
|
163
|
+
info(`API Key: ${config.apiKey ? `${config.apiKey.substring(0, 8)}...` : chalk.gray('not set')}`);
|
|
164
|
+
});
|
|
165
|
+
|
|
166
|
+
// ============================================
|
|
167
|
+
// Config Commands
|
|
168
|
+
// ============================================
|
|
169
|
+
const configCmd = program
|
|
170
|
+
.command('config')
|
|
171
|
+
.description('Manage CLI configuration (for active profile)');
|
|
172
|
+
|
|
173
|
+
configCmd
|
|
174
|
+
.command('set-key <apiKey>')
|
|
175
|
+
.description('Set API key')
|
|
176
|
+
.action((apiKey: string) => {
|
|
177
|
+
setApiKey(apiKey);
|
|
178
|
+
success(`API key saved to profile: ${getCurrentProfile()}`);
|
|
179
|
+
});
|
|
180
|
+
|
|
181
|
+
configCmd
|
|
182
|
+
.command('show')
|
|
183
|
+
.description('Show current configuration')
|
|
184
|
+
.action(() => {
|
|
185
|
+
const profileName = getCurrentProfile();
|
|
186
|
+
const apiKey = getApiKey();
|
|
187
|
+
|
|
188
|
+
console.log(chalk.bold(`Active Profile: ${profileName}`));
|
|
189
|
+
info(`Config directory: ${getConfigDir()}`);
|
|
190
|
+
info(`API Key: ${apiKey ? `${apiKey.substring(0, 8)}...` : chalk.gray('not set')}`);
|
|
191
|
+
});
|
|
192
|
+
|
|
193
|
+
configCmd
|
|
194
|
+
.command('clear')
|
|
195
|
+
.description('Clear configuration for active profile')
|
|
196
|
+
.action(() => {
|
|
197
|
+
clearConfig();
|
|
198
|
+
success(`Configuration cleared for profile: ${getCurrentProfile()}`);
|
|
199
|
+
});
|
|
200
|
+
|
|
201
|
+
// ============================================
|
|
202
|
+
// Example API Commands - TODO: Replace with your API commands
|
|
203
|
+
// ============================================
|
|
204
|
+
const exampleCmd = program
|
|
205
|
+
.command('example')
|
|
206
|
+
.description('Example API commands (replace with your commands)');
|
|
207
|
+
|
|
208
|
+
exampleCmd
|
|
209
|
+
.command('list')
|
|
210
|
+
.description('List resources')
|
|
211
|
+
.option('-n, --max <number>', 'Maximum results', '10')
|
|
212
|
+
.action(async (opts) => {
|
|
213
|
+
try {
|
|
214
|
+
const client = getClient();
|
|
215
|
+
const result = await client.example.list({ maxResults: parseInt(opts.max) });
|
|
216
|
+
print(result, getFormat(exampleCmd));
|
|
217
|
+
} catch (err) {
|
|
218
|
+
error(String(err));
|
|
219
|
+
process.exit(1);
|
|
220
|
+
}
|
|
221
|
+
});
|
|
222
|
+
|
|
223
|
+
exampleCmd
|
|
224
|
+
.command('get <id>')
|
|
225
|
+
.description('Get a resource by ID')
|
|
226
|
+
.action(async (id: string) => {
|
|
227
|
+
try {
|
|
228
|
+
const client = getClient();
|
|
229
|
+
const result = await client.example.get(id);
|
|
230
|
+
print(result, getFormat(exampleCmd));
|
|
231
|
+
} catch (err) {
|
|
232
|
+
error(String(err));
|
|
233
|
+
process.exit(1);
|
|
234
|
+
}
|
|
235
|
+
});
|
|
236
|
+
|
|
237
|
+
exampleCmd
|
|
238
|
+
.command('create')
|
|
239
|
+
.description('Create a new resource')
|
|
240
|
+
.requiredOption('-n, --name <name>', 'Resource name')
|
|
241
|
+
.action(async (opts) => {
|
|
242
|
+
try {
|
|
243
|
+
const client = getClient();
|
|
244
|
+
const result = await client.example.create({ name: opts.name });
|
|
245
|
+
success('Resource created!');
|
|
246
|
+
print(result, getFormat(exampleCmd));
|
|
247
|
+
} catch (err) {
|
|
248
|
+
error(String(err));
|
|
249
|
+
process.exit(1);
|
|
250
|
+
}
|
|
251
|
+
});
|
|
252
|
+
|
|
253
|
+
// Parse and execute
|
|
254
|
+
program.parse();
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
// Connector API
|
|
2
|
+
// A TypeScript wrapper for your API - TODO: Update description
|
|
3
|
+
|
|
4
|
+
export { Connector } from './api';
|
|
5
|
+
export * from './types';
|
|
6
|
+
|
|
7
|
+
// Re-export individual API classes for advanced usage
|
|
8
|
+
export { ConnectorClient, ExampleApi } from './api';
|
|
9
|
+
|
|
10
|
+
// Export config utilities
|
|
11
|
+
export {
|
|
12
|
+
getApiKey,
|
|
13
|
+
setApiKey,
|
|
14
|
+
getApiSecret,
|
|
15
|
+
setApiSecret,
|
|
16
|
+
getToken,
|
|
17
|
+
setToken,
|
|
18
|
+
getCurrentProfile,
|
|
19
|
+
setCurrentProfile,
|
|
20
|
+
listProfiles,
|
|
21
|
+
createProfile,
|
|
22
|
+
deleteProfile,
|
|
23
|
+
loadProfile,
|
|
24
|
+
saveProfile,
|
|
25
|
+
clearConfig,
|
|
26
|
+
getOAuthConfig,
|
|
27
|
+
setOAuthConfig,
|
|
28
|
+
loadOAuthTokens,
|
|
29
|
+
saveOAuthTokens,
|
|
30
|
+
clearOAuthTokens,
|
|
31
|
+
getAccessToken,
|
|
32
|
+
} from './utils/config';
|
|
33
|
+
|
|
34
|
+
// Export OAuth2 utilities
|
|
35
|
+
export {
|
|
36
|
+
getAuthUrl,
|
|
37
|
+
exchangeCodeForTokens,
|
|
38
|
+
refreshAccessToken,
|
|
39
|
+
startCallbackServer,
|
|
40
|
+
getValidAccessToken,
|
|
41
|
+
isAuthenticated,
|
|
42
|
+
getRedirectUri,
|
|
43
|
+
getRedirectPort,
|
|
44
|
+
type AuthResult,
|
|
45
|
+
type AuthUrlOptions,
|
|
46
|
+
} from './utils/auth';
|
|
47
|
+
|
|
48
|
+
// Export settings utilities
|
|
49
|
+
export {
|
|
50
|
+
loadSettings,
|
|
51
|
+
saveSettings,
|
|
52
|
+
getSetting,
|
|
53
|
+
setSetting,
|
|
54
|
+
resetSettings,
|
|
55
|
+
getDefaultSettings,
|
|
56
|
+
isVerbose,
|
|
57
|
+
needsConfirmation,
|
|
58
|
+
type Settings,
|
|
59
|
+
} from './utils/settings';
|
|
60
|
+
|
|
61
|
+
// Export storage utilities
|
|
62
|
+
export {
|
|
63
|
+
saveEntity,
|
|
64
|
+
getEntity,
|
|
65
|
+
entityExists,
|
|
66
|
+
getAllEntities,
|
|
67
|
+
deleteEntity,
|
|
68
|
+
searchEntities,
|
|
69
|
+
searchEntitiesByText,
|
|
70
|
+
countEntities,
|
|
71
|
+
clearEntities,
|
|
72
|
+
createStorage,
|
|
73
|
+
type Storable,
|
|
74
|
+
} from './utils/storage';
|
|
75
|
+
|
|
76
|
+
// Export bulk operation utilities
|
|
77
|
+
export {
|
|
78
|
+
executeBulk,
|
|
79
|
+
executeSequential,
|
|
80
|
+
chunkArray,
|
|
81
|
+
sleep,
|
|
82
|
+
createProgressReporter,
|
|
83
|
+
formatBulkResult,
|
|
84
|
+
type BulkOperationOptions,
|
|
85
|
+
type BulkOperationResult,
|
|
86
|
+
} from './utils/bulk';
|
|
87
|
+
|
|
88
|
+
// Export output utilities
|
|
89
|
+
export {
|
|
90
|
+
formatOutput,
|
|
91
|
+
success,
|
|
92
|
+
error,
|
|
93
|
+
warn,
|
|
94
|
+
info,
|
|
95
|
+
heading,
|
|
96
|
+
print,
|
|
97
|
+
setVerboseMode,
|
|
98
|
+
isVerboseMode,
|
|
99
|
+
debug,
|
|
100
|
+
debugRequest,
|
|
101
|
+
debugResponse,
|
|
102
|
+
type OutputFormat,
|
|
103
|
+
} from './utils/output';
|