npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@capgo/cli

v7.62.1

Published

A CLI to upload to capgo servers

Readme

Capgo CLI

A CLI to upload and download files from the Capgo Cloud.

You can find the most up to date version of this doc in our web doc: https://capgo.app/docs/cli/overview/

Usage

Before using the CLI, you should register here: https://capgo.app/

Then go to your account in apikey section and click in the all key to copy it.

Follow the documentation here: https://capacitorjs.com/docs/getting-started/

📑 Capgo CLI Commands

📋 Table of Contents

🚀 Init

Alias: i

npx @capgo/cli@latest init

🚀 Initialize a new app in Capgo Cloud with step-by-step guidance. This includes adding code for updates, building, uploading your app, and verifying update functionality.

Example:

npx @capgo/cli@latest init YOUR_API_KEY com.example.app

Options

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -n, | string | App name for display in Capgo Cloud | | -i, | string | App icon path for display in Capgo Cloud | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

👨‍⚕️ Doctor

npx @capgo/cli@latest doctor

👨‍⚕️ Check if your Capgo app installation is up-to-date and gather information useful for bug reports. This command helps diagnose issues with your setup.

Example:

npx @capgo/cli@latest doctor

Options

| Param | Type | Description | | -------------- | ------------- | -------------------- | | --package-json | string | Paths to package.json files for monorepos (comma-separated) |

🔑 Login

Alias: l

npx @capgo/cli@latest login

🔑 Save your Capgo API key to your machine or local folder for easier access to Capgo Cloud services. Use --apikey=******** in any command to override it.

Example:

npx @capgo/cli@latest login YOUR_API_KEY

Options

| Param | Type | Description | | -------------- | ------------- | -------------------- | | --local | boolean | Only save in local folder, git ignored for security. | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

📦 Bundle

📦 Manage app bundles for deployment in Capgo Cloud, including upload, compatibility checks, and encryption.

⬆️ Upload

Alias: u

npx @capgo/cli@latest bundle upload

⬆️ Upload a new app bundle to Capgo Cloud for distribution. Version must be > 0.0.0 and unique. Deleted versions cannot be reused for security. External option: Store only a URL link (useful for apps >200MB or privacy requirements). Capgo never inspects external content. Add encryption for trustless security.

Example:

npx @capgo/cli@latest bundle upload com.example.app --path ./dist --channel production

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account | | -p, | string | Path of the folder to upload, if not provided it will use the webDir set in capacitor.config | | -c, | string | Channel to link to | | -e, | string | Link to external URL instead of upload to Capgo Cloud | | --iv-session-key | string | Set the IV and session key for bundle URL external | | --s3-region | string | Region for your S3 bucket | | --s3-apikey | string | API key for your S3 endpoint | | --s3-apisecret | string | API secret for your S3 endpoint | | --s3-endpoint | string | URL of S3 endpoint | | --s3-bucket-name | string | Name for your AWS S3 bucket | | --s3-port | string | Port for your S3 endpoint | | --no-s3-ssl | boolean | Disable SSL for S3 upload | | --key-v2 | string | Custom path for private signing key (v2 system) | | --key-data-v2 | string | Private signing key (v2 system) | | --bundle-url | boolean | Prints bundle URL into stdout | | --no-key | boolean | Ignore signing key and send clear update | | --no-code-check | boolean | Ignore checking if notifyAppReady() is called in source code and index present in root folder | | --display-iv-session | boolean | Show in the console the IV and session key used to encrypt the update | | -b, | string | Bundle version number of the bundle to upload | | --link | string | Link to external resource (e.g. GitHub release) | | --comment | string | Comment about this version, could be a release note, a commit hash, a commit message, etc. | | --min-update-version | string | Minimal version required to update to this version. Used only if the disable auto update is set to metadata in channel | | --auto-min-update-version | boolean | Set the min update version based on native packages | | --ignore-metadata-check | boolean | Ignores the metadata (node_modules) check when uploading | | --ignore-checksum-check | boolean | Ignores the checksum check when uploading | | --timeout | string | Timeout for the upload process in seconds | | --multipart | boolean | [DEPRECATED] Use --tus instead. Uses multipart protocol for S3 uploads | | --zip | boolean | Upload the bundle using zip to Capgo cloud (legacy) | | --tus | boolean | Upload the bundle using TUS to Capgo cloud | | --tus-chunk-size | string | Chunk size in bytes for TUS resumable uploads (default: auto) | | --partial | boolean | [DEPRECATED] Use --delta instead. Upload incremental updates | | --partial-only | boolean | [DEPRECATED] Use --delta-only instead. Upload only incremental updates, skip full bundle | | --delta | boolean | Upload incremental/differential updates to reduce bandwidth | | --delta-only | boolean | Upload only delta updates without full bundle (useful for large apps) | | --encrypted-checksum | string | An encrypted checksum (signature). Used only when uploading an external bundle. | | --auto-set-bundle | boolean | Set the bundle in capacitor.config.json | | --dry-upload | boolean | Dry upload the bundle process, mean it will not upload the files but add the row in database (Used by Capgo for internal testing) | | --package-json | string | Paths to package.json files for monorepos (comma-separated) | | --node-modules | string | Paths to node_modules directories for monorepos (comma-separated) | | --encrypt-partial | boolean | Encrypt delta update files (auto-enabled for updater > 6.14.4) | | --delete-linked-bundle-on-upload | boolean | Locates the currently linked bundle in the channel you are trying to upload to, and deletes it | | --no-brotli-patterns | string | Files to exclude from Brotli compression (comma-separated globs, e.g., ".jpg,.png") | | --disable-brotli | boolean | Completely disable brotli compression even if updater version supports it | | --version-exists-ok | boolean | Exit successfully if bundle version already exists, useful for CI/CD workflows with monorepos | | --self-assign | boolean | Allow devices to auto-join this channel (updates channel setting) | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) | | --verbose | boolean | Enable verbose output with detailed logging |

🧪 Compatibility

npx @capgo/cli@latest bundle compatibility

🧪 Check compatibility of a bundle with a specific channel in Capgo Cloud to ensure updates are safe.

Example:

npx @capgo/cli@latest bundle compatibility com.example.app --channel production

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account | | -c, | string | Channel to check the compatibility with | | --text | boolean | Output text instead of emojis | | --package-json | string | Paths to package.json files for monorepos (comma-separated) | | --node-modules | string | Paths to node_modules directories for monorepos (comma-separated) | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

🗑️ Delete

Alias: d

npx @capgo/cli@latest bundle delete

🗑️ Delete a specific bundle from Capgo Cloud, optionally targeting a single version.

Example:

npx @capgo/cli@latest bundle delete BUNDLE_ID com.example.app

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

📋 List

Alias: l

npx @capgo/cli@latest bundle list

📋 List all bundles uploaded for an app in Capgo Cloud.

Example:

npx @capgo/cli@latest bundle list com.example.app

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

🧹 Cleanup

Alias: c

npx @capgo/cli@latest bundle cleanup

🧹 Delete old bundles in Capgo Cloud, keeping specified number of recent versions. Bundles linked to channels are preserved unless --ignore-channel is used.

Example:

npx @capgo/cli@latest bundle cleanup com.example.app --bundle=1.0 --keep=3

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -b, | string | Bundle version number of the app to delete | | -a, | string | API key to link to your account | | -k, | string | Number of versions to keep | | -f, | string | Force removal | | --ignore-channel | boolean | Delete bundles even if linked to channels (WARNING: deletes channels too) | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

🔒 Encrypt

npx @capgo/cli@latest bundle encrypt

🔒 Encrypt a zip bundle for secure external storage. Returns ivSessionKey for upload/decryption. Get checksum using 'bundle zip --json'.

Example:

npx @capgo/cli@latest bundle encrypt ./myapp.zip CHECKSUM

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | --key | string | Custom path for private signing key | | --key-data | string | Private signing key | | -j, | string | Output in JSON |

🔓 Decrypt

npx @capgo/cli@latest bundle decrypt

🔓 Decrypt an encrypted bundle (mainly for testing). Prints base64 session key for verification.

Example:

npx @capgo/cli@latest bundle decrypt ./myapp_encrypted.zip CHECKSUM

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | --key | string | Custom path for private signing key | | --key-data | string | Private signing key | | --checksum | string | Checksum of the bundle, to verify the integrity of the bundle |

🔹 Zip

npx @capgo/cli@latest bundle zip

🗜️ Create a zip file of your app bundle. Returns checksum for use with encryption. Use --json for machine-readable output.

Example:

npx @capgo/cli@latest bundle zip com.example.app --path ./dist

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -p, | string | Path of the folder to upload, if not provided it will use the webDir set in capacitor.config | | -b, | string | Bundle version number to name the zip file | | -n, | string | Name of the zip file | | -j, | string | Output in JSON | | --no-code-check | boolean | Ignore checking if notifyAppReady() is called in source code and index present in root folder | | --key-v2 | boolean | Use encryption v2 | | --package-json | string | Paths to package.json files for monorepos (comma-separated) |

📱 App

📱 Manage your Capgo app settings and configurations in Capgo Cloud.

Add

Alias: a

npx @capgo/cli@latest app add

➕ Add a new app to Capgo Cloud with a unique app ID in the format com.test.app. All options can be guessed from config if not provided.

Example:

npx @capgo/cli@latest app add com.example.app --name "My App" --icon ./icon.png

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -n, | string | App name for display in Capgo Cloud | | -i, | string | App icon path for display in Capgo Cloud | | -a, | string | API key to link to your account | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

🗑️ Delete

npx @capgo/cli@latest app delete

🗑️ Delete an app from Capgo Cloud, optionally specifying a version to delete only that bundle.

Example:

npx @capgo/cli@latest app delete com.example.app

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

📋 List

Alias: l

npx @capgo/cli@latest app list

📋 List all apps registered under your account in Capgo Cloud.

Example:

npx @capgo/cli@latest app list

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

🐞 Debug

npx @capgo/cli@latest app debug

🐞 Listen for live update events in Capgo Cloud to debug your app. Optionally target a specific device for detailed diagnostics.

Example:

npx @capgo/cli@latest app debug com.example.app --device DEVICE_ID

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account | | -d, | string | The specific device ID to debug | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

⚙️ Setting

npx @capgo/cli@latest app setting

⚙️ Modify Capacitor configuration programmatically. Specify setting path (e.g., plugins.CapacitorUpdater.defaultChannel) with --string or --bool.

Example:

npx @capgo/cli@latest app setting plugins.CapacitorUpdater.defaultChannel --string "Production"

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | --bool | string | A value for the setting to modify as a boolean, ex: --bool true | | --string | string | A value for the setting to modify as a string, ex: --string "Production" |

⚙️ Set

Alias: s

npx @capgo/cli@latest app set

⚙️ Update settings for an existing app in Capgo Cloud, such as name, icon, or retention period for bundles. Retention of 0 means infinite storage.

Example:

npx @capgo/cli@latest app set com.example.app --name "Updated App" --retention 30

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -n, | string | App name for display in Capgo Cloud | | -i, | string | App icon path for display in Capgo Cloud | | -a, | string | API key to link to your account | | -r, | string | Days to keep old bundles (0 = infinite, default: 0) | | --expose-metadata | string | Expose bundle metadata (link and comment) to the plugin (true/false, default: false) | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

📢 Channel

📢 Manage distribution channels for app updates in Capgo Cloud, controlling how updates are delivered to devices.

Add

Alias: a

npx @capgo/cli@latest channel add

➕ Create a new channel for app distribution in Capgo Cloud to manage update delivery.

Example:

npx @capgo/cli@latest channel add production com.example.app --default

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -d, | string | Set the channel as default | | --self-assign | boolean | Allow device to self-assign to this channel | | -a, | string | API key to link to your account | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

🗑️ Delete

Alias: d

npx @capgo/cli@latest channel delete

🗑️ Delete a channel from Capgo Cloud, optionally removing associated bundles to free up resources.

Example:

npx @capgo/cli@latest channel delete production com.example.app

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account | | --delete-bundle | boolean | Delete the bundle associated with the channel | | --success-if-not-found | boolean | Success if the channel is not found | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

📋 List

Alias: l

npx @capgo/cli@latest channel list

📋 List all channels configured for an app in Capgo Cloud to review distribution settings.

Example:

npx @capgo/cli@latest channel list com.example.app

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

📦 CurrentBundle

npx @capgo/cli@latest channel currentBundle

📦 Get the current bundle linked to a specific channel in Capgo Cloud for update tracking.

Example:

npx @capgo/cli@latest channel currentBundle production com.example.app

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -c, | string | Channel to get the current bundle from | | -a, | string | API key to link to your account | | --quiet | boolean | Only print the bundle version | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

⚙️ Set

Alias: s

npx @capgo/cli@latest channel set

⚙️ Configure settings for a channel, such as linking a bundle, setting update strategies (major, minor, metadata, patch, none), or device targeting (iOS, Android, dev, prod, emulator, device). One channel must be default.

Example:

npx @capgo/cli@latest channel set production com.example.app --bundle 1.0.0 --state default

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account | | -b, | string | Bundle version number of the file to set | | -s, | string | Set the state of the channel, default or normal | | --latest-remote | boolean | Get the latest bundle uploaded in capgo cloud and set it to the channel | | --latest | boolean | Get the latest version key in the package.json to set it to the channel | | --downgrade | boolean | Allow to downgrade to version under native one | | --no-downgrade | boolean | Disable downgrade to version under native one | | --ios | boolean | Allow sending update to iOS devices | | --no-ios | boolean | Disable sending update to iOS devices | | --android | boolean | Allow sending update to Android devices | | --no-android | boolean | Disable sending update to Android devices | | --self-assign | boolean | Allow device to self-assign to this channel | | --no-self-assign | boolean | Disable devices to self-assign to this channel | | --disable-auto-update | string | Block updates by type: major, minor, metadata, patch, or none (allows all) | | --dev | boolean | Allow sending update to development devices | | --no-dev | boolean | Disable sending update to development devices | | --prod | boolean | Allow sending update to production devices | | --no-prod | boolean | Disable sending update to production devices | | --emulator | boolean | Allow sending update to emulator devices | | --no-emulator | boolean | Disable sending update to emulator devices | | --device | boolean | Allow sending update to physical devices | | --no-device | boolean | Disable sending update to physical devices | | --package-json | string | Paths to package.json files for monorepos (comma-separated) | | --ignore-metadata-check | boolean | Ignore checking node_modules compatibility if present in the bundle | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

🔐 Key

🔐 Manage encryption keys for secure bundle distribution in Capgo Cloud, supporting end-to-end encryption with RSA and AES combination.

🔹 Save

npx @capgo/cli@latest key save

💾 Save the public key in the Capacitor config, useful for CI environments. Recommended not to commit the key for security.

Example:

npx @capgo/cli@latest key save --key ./path/to/key.pub

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -f, | string | Force generate a new one | | --key | string | Key path to save in Capacitor config | | --key-data | string | Key data to save in Capacitor config |

🔨 Create

npx @capgo/cli@latest key create

🔨 Create RSA key pair for end-to-end encryption. Creates .capgo_key_v2 (private) and .capgo_key_v2.pub (public) in project root. Public key is saved to capacitor.config for mobile app decryption. NEVER commit the private key - store it securely!

Example:

npx @capgo/cli@latest key create

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -f, | string | Force generate a new one |

🗑️ Delete_old

npx @capgo/cli@latest key delete_old

🧹 Delete the old encryption key from the Capacitor config to ensure only the current key is used.

Example:

npx @capgo/cli@latest key delete_old

👤 Account

👤 Manage your Capgo account details and retrieve information for support or collaboration.

🔹 Id

npx @capgo/cli@latest account id

🪪 Retrieve your account ID, safe to share for collaboration or support purposes in Discord or other platforms.

Example:

npx @capgo/cli@latest account id

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account |

🔹 Organisation

🏢 Manage your organizations in Capgo Cloud for team collaboration and app management.

📋 List

Alias: l

npx @capgo/cli@latest organisation list

📋 List all organizations you have access to in Capgo Cloud.

Example:

npx @capgo/cli@latest organisation list

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

Add

Alias: a

npx @capgo/cli@latest organisation add

➕ Create a new organization in Capgo Cloud for team collaboration.

Example:

npx @capgo/cli@latest organisation add --name "My Company" --email [email protected]

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -n, | string | Organization name | | -e, | string | Management email for the organization | | -a, | string | API key to link to your account | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

⚙️ Set

Alias: s

npx @capgo/cli@latest organisation set

⚙️ Update organization settings such as name and management email.

Example:

npx @capgo/cli@latest organisation set ORG_ID --name "Updated Company Name"

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -n, | string | Organization name | | -e, | string | Management email for the organization | | -a, | string | API key to link to your account | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

🗑️ Delete

Alias: d

npx @capgo/cli@latest organisation delete

🗑️ Delete an organization from Capgo Cloud. This action cannot be undone. Only organization owners can delete organizations.

Example:

npx @capgo/cli@latest organisation delete ORG_ID

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | -a, | string | API key to link to your account | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) |

🔹 Build

🏗️ Manage native iOS/Android builds through Capgo Cloud. ⚠️ This feature is currently in PUBLIC BETA and cannot be used by anyone at this time. 🔒 SECURITY GUARANTEE: Build credentials are NEVER stored on Capgo servers. They are used only during the build and auto-deleted after. Builds sent directly to app stores - Capgo keeps nothing. 📋 BEFORE BUILDING: Save your credentials first: npx @capgo/cli build credentials save --appId --platform ios npx @capgo/cli build credentials save --appId --platform android

🔹 Request

npx @capgo/cli@latest build request

Request a native build from Capgo Cloud. This command will zip your project directory and upload it to Capgo for building. The build will be processed and sent directly to app stores. 🔒 SECURITY: Credentials are never stored on Capgo servers. They are auto-deleted after build completion. Builds sent directly to stores - Capgo keeps nothing. 📋 PREREQUISITE: Save credentials first with: npx @capgo/cli build credentials save --appId --platform <ios|android>

Example:

npx @capgo/cli@latest build request com.example.app --platform ios --path .

Options:

| Param | Type | Description | | -------------- | ------------- | -------------------- | | --path | string | Path to the project directory to build (default: current directory) | | --platform | string | Target platform: ios or android (required) | | --build-mode | string | Build mode: debug or release (default: release) | | --build-config | string | Additional build configuration as JSON string | | --build-certificate-base64 | string | iOS: Base64-encoded .p12 certificate | | --build-provision-profile-base64 | string | iOS: Base64-encoded provisioning profile | | --build-provision-profile-base64-prod | string | iOS: Base64-encoded production provisioning profile | | --p12-password | string | iOS: Certificate password (optional if cert has no password) | | --apple-id | string | iOS: Apple ID email | | --apple-app-specific-password | string | iOS: App-specific password | | --apple-key-id | string | iOS: App Store Connect API Key ID | | --apple-issuer-id | string | iOS: App Store Connect Issuer ID | | --apple-key-content | string | iOS: Base64-encoded App Store Connect API key (.p8) | | --apple-profile-name | string | iOS: Provisioning profile name | | --app-store-connect-team-id | string | iOS: App Store Connect Team ID | | --android-keystore-file | string | Android: Base64-encoded keystore file | | --keystore-key-alias | string | Android: Keystore key alias | | --keystore-key-password | string | Android: Keystore key password | | --keystore-store-password | string | Android: Keystore store password | | --play-config-json | string | Android: Base64-encoded Google Play service account JSON | | -a, | string | API key to link to your account | | --supa-host | string | Custom Supabase host URL (for self-hosting or Capgo development) | | --supa-anon | string | Custom Supabase anon key (for self-hosting) | | --verbose | boolean | Enable verbose output with detailed logging |

🔹 Credentials

npx @capgo/cli@latest build credentials

Manage build credentials stored locally on your machine. 🔒 SECURITY:

  • Credentials saved to ~/.capgo-credentials/credentials.json (global) or .capgo-credentials.json (local)
  • When building, sent to Capgo but NEVER stored permanently
  • Deleted from Capgo immediately after build
  • Builds sent directly to app stores - Capgo keeps nothing 📚 DOCUMENTATION: iOS setup: https://capgo.app/docs/cli/cloud-build/ios/ Android setup: https://capgo.app/docs/cli/cloud-build/android/

🔹 Mcp

npx @capgo/cli@latest mcp

🤖 Start the Capgo MCP (Model Context Protocol) server for AI agent integration. This command starts an MCP server that exposes Capgo functionality as tools for AI agents. The server communicates via stdio and is designed for non-interactive, programmatic use. Available tools exposed via MCP:

  • capgo_list_apps, capgo_add_app, capgo_update_app, capgo_delete_app
  • capgo_upload_bundle, capgo_list_bundles, capgo_delete_bundle, capgo_cleanup_bundles
  • capgo_list_channels, capgo_add_channel, capgo_update_channel, capgo_delete_channel
  • capgo_get_current_bundle, capgo_check_compatibility
  • capgo_list_organizations, capgo_add_organization
  • capgo_get_account_id, capgo_doctor, capgo_get_stats
  • capgo_request_build, capgo_generate_encryption_keys Example usage with Claude Desktop: Add to claude_desktop_config.json: { "mcpServers": { "capgo": { "command": "npx", "args": ["@capgo/cli", "mcp"] } } }

Example:

npx @capgo/cli mcp

Programmatic Usage (SDK)

You can use the Capgo CLI programmatically in your Node.js/TypeScript projects for automation and CI/CD pipelines.

Installation

npm install @capgo/cli

Example: Upload a Bundle

import { CapgoSDK } from '@capgo/cli/sdk'

const sdk = new CapgoSDK({
  apikey: 'your-api-key'
})

await sdk.uploadBundle({
  appId: 'com.example.app',
  bundle: '1.0.0',
  path: './dist',
  channel: 'production'
})

Example: CI/CD Automation

import { CapgoSDK } from '@capgo/cli/sdk'

const sdk = new CapgoSDK({
  apikey: process.env.CAPGO_API_KEY
})

// Upload new version
await sdk.uploadBundle({
  appId: 'com.example.app',
  bundle: process.env.VERSION,
  path: './dist',
  channel: 'production'
})

// Cleanup old bundles
await sdk.cleanupBundles({
  appId: 'com.example.app',
  keep: 10
})

All CLI features are available as SDK methods. See the TypeScript types for the complete API reference.