name: hot-updater description: Use when working with Hot Updater CLI setup, deployment, patch artifacts, bundle inventory/state, rollback, channels, code signing keys, database migration, diagnostics, or AI-assisted React Native OTA operations. metadata: author: hot-updater version: "1.0.0"
Hot Updater CLI
Use this skill when a task involves Hot Updater's CLI, hot-updater.config.ts,
React Native OTA deployment, patch artifacts, bundle operations, rollback,
release-channel management, code signing keys, database migration, fingerprints,
or diagnostics.
Operating Rules
- Start from the project root unless the user specifies another app directory.
- Read local
hot-updater.config.tsbefore assuming provider behavior. - Use
npx hot-updater ...for CLI examples and user-facing instructions. - Do not run
npx hot-updater initon behalf of the user. It is interactive and asks for provider, build, and project-specific choices. Guide the user to run it directly and follow the setup documentation. - Before running
npx hot-updater doctorfor a server/infrastructure check, make sure the server base URL is available. If the user did not provide it and it is not obvious from local config, ask for the update server URL first. - For doctor repair loops, run
npx hot-updater doctor --jsonfirst. Fix issues markedfixability: "auto"by editing local project files, run the listedcommandsfor issues markedfixability: "command", and rerun doctor after each focused change. Stop when doctor passes or the remaining issues are markedfixability: "blocked". - Treat
fixability: "blocked"as outside the autonomous local loop. Server infrastructure remediation commonly needs provider credentials, environment variables, and redeploy access; summarize the blocker instead of running migrations or mutating provider setup. - Treat
deploy,patch,bundle enable,bundle disable,bundle update,bundle delete,bundle promote,rollback,channel set,keys export-public,keys remove, anddb migrateas state-changing operations. - Treat
keys generateanddb generateas local file/artifact writing operations. - Use
--jsononly with commands documented here as supporting it. For mutating commands,--jsononly changes the output format after the requested mutation has already been authorized. If a target project uses an older CLI without that option, fall back to the human-readable output. - For non-interactive shells, use
-yonly when the user already requested the exact mutation and the target is unambiguous. - After mutating bundle state, verify with
bundle listor the relevant provider state. - If
deployfails, stop the deploy workflow. Do not keep retrying fixes, edit setup, change credentials, install dependencies, or run migrations unless the user explicitly asks for that follow-up. Analyze only the failed command, relevant output, likely cause, and suggested next checks. - Do not edit provider credentials unless the user explicitly asks. Credentials
are commonly stored in
.env.hotupdater, but projects may use a different environment-loading setup.
Natural Language Requests
Users may invoke this skill with prompts such as:
$hot-updater deploy using the current app version
$hot-updater deploy the current iOS app version to production
$hot-updater roll back the most recently deployed bundle
$hot-updater list iOS bundles on the production channel
$hot-updater update rollout cohort count for bundle <bundle-id> to 500
$hot-updater promote bundle <bundle-id> to staging
$hot-updater create a patch from bundle <old-id> to <new-id>
$hot-updater export the code signing public key
$hot-updater run doctor with server URL https://updates.example.com/api/check-update
$hot-updater fix local doctor issues that do not require server credentials
Translate the request into the safest CLI flow. If a state-changing request is
missing a required channel, platform, bundle target, patch base, destination
channel, or server URL that cannot be inferred from local context, ask one
concise question before mutating anything. For deploy and patch channel, use the
CLI default production unless the user names another channel or local context
clearly indicates one.
Current App Version Deploy
When the user asks to deploy for the current app version:
- Run
npx hot-updater app-version --jsonwhen supported; otherwise runnpx hot-updater app-version. - Extract
iosand/orandroidfrom JSON when available, or from the human-readable output as a fallback. - If the platform is missing, ask whether to deploy iOS, Android, or both.
- Deploy with
-t <version>:
npx hot-updater deploy -p ios -t <ios-app-version>
npx hot-updater deploy -p android -t <android-app-version>
If deploying both platforms, run one platform at a time and verify each result
with npx hot-updater bundle list -p <platform> --limit 5 --json when
supported, or without --json as a fallback.
If a deploy command fails, do not continue to the next platform or attempt an automatic repair. Report the failure analysis and wait for a new user request.
Recent Bundle Rollback
When the user asks to roll back the most recent deployment without naming a bundle:
- Run
npx hot-updater bundle list --json --limit 10. - Choose the most recent enabled bundle from the JSON result.
- Use that bundle's
channel,platform, andidfor a scoped rollback:
npx hot-updater rollback <channel> -p <platform> --target <bundle-id> -y
If the most recent bundle is already disabled, tell the user and ask whether to roll back the next enabled bundle. After rollback, verify with:
npx hot-updater bundle list -c <channel> -p <platform> --limit 5 --json
If --json is unavailable, rerun the same command without --json.
Core Commands
Setup and Diagnostics
npx hot-updater init
npx hot-updater doctor --server-base-url <update-server-url>
npx hot-updater doctor --json
npx hot-updater doctor --server-base-url <update-server-url> --json
npx hot-updater fingerprint
npx hot-updater fingerprint create
npx hot-updater app-version
npx hot-updater app-version --json
npx hot-updater console
initcreates or updates project configuration. Because it is interactive, tell the user to run it directly instead of choosing answers for them.doctorchecks local setup and server health. Provide--server-base-url; the command appends/versionfor the server check. If the user has not provided one, ask for it before running the command.doctor --jsonis the preferred agent surface. It returns stable issue codes, related paths,fixability, and command hints for local iterative repair. Do not parse the human-readable doctor output when JSON is available.fingerprintandfingerprint creategenerate the app fingerprint.app-versionreads native iOS and Android app versions.--jsonreturns{ "android": string | null, "ios": string | null }on CLIs that support it.consoleopens the local management console.
Deploy
npx hot-updater deploy -p <ios|android>
npx hot-updater deploy -p ios -c production -r 25
npx hot-updater deploy -p android -f
npx hot-updater deploy -p ios -d
npx hot-updater deploy -p ios -o ./hot-updater-output
Important options:
| Option | Meaning |
|---|---|
-p, --platform <platform> |
Target ios or android. |
-c, --channel <channel> |
Release channel, default production. |
-t, --target-app-version <range> |
App version range such as 1.2.3 or 1.x.x. |
-r, --rollout <percentage> |
Initial rollout percentage from 0 to 100. |
-f, --force-update |
Apply immediately on client update. |
-d, --disabled |
Upload disabled for later enablement. |
-o, --bundle-output-path <path> |
Directory where bundle archives are generated. |
-m, --message <message> |
Custom deployment message. |
-i, --interactive |
Guided deployment flow. |
Patch Artifacts
npx hot-updater patch -b <bundle-id> --base-bundle-id <base-bundle-id> -p ios
npx hot-updater patch -b <bundle-id> --base-bundle-id <base-bundle-id> -p android -c production
npx hot-updater patch -i
Important options:
| Option | Meaning |
|---|---|
-b, --bundle-id <bundleId> |
Target bundle id that should receive the patch artifact. |
--base-bundle-id <baseBundleId> |
Older bundle id to use as the patch base. |
-p, --platform <platform> |
Target ios or android. |
-c, --channel <channel> |
Channel used to load config, default production. |
-i, --interactive |
Guided patch flow. |
Bundle Inventory and State
npx hot-updater bundle list
npx hot-updater bundle list -c production -p ios --limit 10
npx hot-updater bundle list -c production -p ios --limit 10 --json
npx hot-updater bundle list --json
npx hot-updater bundle show <bundle-id>
npx hot-updater bundle show <bundle-id> --json
npx hot-updater bundle disable <bundle-id>
npx hot-updater bundle enable <bundle-id>
npx hot-updater bundle update <bundle-id> --rollout-cohort-count 500
npx hot-updater bundle update <bundle-id> --force-update true --json
npx hot-updater bundle update <bundle-id> --target-cohorts 1,2,3
npx hot-updater bundle update <bundle-id> --clear-target-cohorts
npx hot-updater bundle delete <bundle-id>
npx hot-updater bundle promote <bundle-id> -t staging
npx hot-updater bundle promote <bundle-id> -t staging -a move
bundle listshows the most recent bundles first.bundle list --limit <n>defaults to20.--jsonis available forbundle list,bundle show, andbundle updateon CLIs that support it.bundle disableandbundle enableread the bundle, mutate enabled state, commit the change, then re-read to verify.bundle updatecan set rollout cohort count from0to1000, force update metadata, and target cohorts.bundle deleteremoves the bundle record by id.bundle promotecopies to a target channel by default. Use-a moveonly when the user explicitly wants to keep the same bundle id and move channels.- In CI or other non-interactive shells, pass
-ytoenableordisable. Also pass-ytoupdate,delete, orpromoteonly when the requested mutation target is unambiguous.
Rollback
npx hot-updater rollback <channel>
npx hot-updater rollback production -p ios
npx hot-updater rollback production -p ios --target <bundle-id> -y
- Rollback disables the latest enabled bundle on the channel.
- Without
-p, rollback applies to both iOS and Android. - The next most recent enabled bundle on the same channel and platform becomes the fallback.
- If no previous enabled bundle exists, the app falls back to the JavaScript bundle shipped in the native binary.
- Use
--target <bundle-id>to retry a partial rollback for exactly one bundle.
Channels
npx hot-updater channel set <channel>
This writes the default channel into native iOS and Android project files. Changing this embedded channel requires a native rebuild.
Code Signing Keys
npx hot-updater keys generate
npx hot-updater keys generate -o ./keys -k 4096
npx hot-updater keys export-public
npx hot-updater keys export-public -i ./keys/private.pem --print-only
npx hot-updater keys remove
keys generatewrites an RSA key pair. The default output directory is./keys, and supported key sizes are2048and4096with default4096.keys export-publicreads the private key from-ior fromsigning.privateKeyPathinhot-updater.config.ts, then writes native public key configuration unless--print-onlyis used.keys removeremoves public keys from native configuration files.- Use
-yfor native file writes only when the user explicitly requested the exact operation.
Database
npx hot-updater db generate [configPath] [outputDir]
npx hot-updater db generate --sql
npx hot-updater db generate --sql postgresql
npx hot-updater db migrate [configPath]
db generatecreates migration output without applying it. The default output directory ishot-updater_migrations.db generate --sql [provider]creates a standalone SQL file without reading config. Supported providers arepostgresql,mysql, andsqlite; omitting the provider starts interactive selection.db migrateapplies the latest migration through the configured database plugin.- Pass
-yonly when the user explicitly requested the write or migration.