Skip to content

Latest commit

 

History

History
867 lines (611 loc) · 36.7 KB

File metadata and controls

867 lines (611 loc) · 36.7 KB

NPM Package — Programmatic API

TypeScript/JavaScript API reference for @microsoft/winappcli. Each CLI command is available as an async function that captures stdout/stderr and returns a typed result. Helper utilities for MSIX identity, Electron debug identity, and build tools are also exported.

Installation

npm install @microsoft/winappcli

Quick start

import { init, packageApp, certGenerate } from '@microsoft/winappcli';

// Initialize a new project with defaults
await init({ useDefaults: true });

// Generate a dev certificate
await certGenerate({ install: true });

// Package the built app
await packageApp({ inputFolder: './dist', cert: './devcert.pfx' });

Common types

Every CLI command wrapper accepts an options object extending CommonOptions and returns Promise<WinappResult>.

CommonOptions

Base options shared by most commands.

Property Type Required Description
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

WinappResult

Result returned by every command wrapper.

Property Type Required Description
exitCode number Yes Process exit code (always 0 on success – non-zero throws).
stdout string Yes Captured standard output.
stderr string Yes Captured standard error.

CLI command wrappers

These functions wrap native winapp CLI commands. All accept CommonOptions (quiet, verbose, cwd).

certGenerate()

Create a self-signed certificate for local testing only. Publisher must match AppxManifest.xml (auto-inferred if --manifest provided or appxmanifest.xml is in working directory). Output: devcert.pfx (default password: 'password'). For production, obtain a certificate from a trusted CA. Use 'cert install' to trust on this machine.

function certGenerate(options?: CertGenerateOptions): Promise<WinappResult>

Options:

Property Type Required Description
exportCer boolean | undefined No Export a .cer file (public key only) alongside the .pfx
ifExists IfExists | undefined No Behavior when output file exists: 'error' (fail, default), 'skip' (keep existing), or 'overwrite' (replace)
install boolean | undefined No Install the certificate to the local machine store after generation
json boolean | undefined No Format output as JSON
manifest string | undefined No Path to appxmanifest.xml file to extract publisher information from
output string | undefined No Output path for the generated PFX file
password string | undefined No Password for the generated PFX file
publisher string | undefined No Publisher name for the generated certificate. If not specified, will be inferred from manifest.
validDays number | undefined No Number of days the certificate is valid

Also accepts CommonOptions (quiet, verbose, cwd).


certInfo()

Display certificate details (subject, thumbprint, expiry). Useful for verifying a certificate matches your manifest before signing.

function certInfo(options: CertInfoOptions): Promise<WinappResult>

Options:

Property Type Required Description
certPath string Yes Path to the certificate file (PFX)
json boolean | undefined No Format output as JSON
password string | undefined No Password for the PFX file

Also accepts CommonOptions (quiet, verbose, cwd).


certInstall()

Trust a certificate on this machine (requires admin). Run before installing MSIX packages signed with dev certificates. Example: winapp cert install ./devcert.pfx. Only needed once per certificate.

function certInstall(options: CertInstallOptions): Promise<WinappResult>

Options:

Property Type Required Description
certPath string Yes Path to the certificate file (PFX or CER)
force boolean | undefined No Force installation even if the certificate already exists
password string | undefined No Password for the PFX file

Also accepts CommonOptions (quiet, verbose, cwd).


createDebugIdentity()

Enable package identity for debugging without creating full MSIX. Required for testing Windows APIs (push notifications, share target, etc.) during development. Example: winapp create-debug-identity ./myapp.exe. Requires appxmanifest.xml in current directory or passed via --manifest. Re-run after changing appxmanifest.xml or Assets/.

function createDebugIdentity(options?: CreateDebugIdentityOptions): Promise<WinappResult>

Options:

Property Type Required Description
entrypoint string | undefined No Path to the .exe that will need to run with identity, or entrypoint script.
keepIdentity boolean | undefined No Keep the package identity from the manifest as-is, without appending '.debug' to the package name and application ID.
manifest string | undefined No Path to the appxmanifest.xml
noInstall boolean | undefined No Do not install the package after creation.

Also accepts CommonOptions (quiet, verbose, cwd).


createExternalCatalog()

Generates a CodeIntegrityExternal.cat catalog file with hashes of executable files from specified directories. Used with the TrustedLaunch flag in MSIX sparse package manifests (AllowExternalContent) to allow execution of external files not included in the package.

function createExternalCatalog(options: CreateExternalCatalogOptions): Promise<WinappResult>

Options:

Property Type Required Description
inputFolder string Yes List of input folders with executable files to process (separated by semicolons)
computeFlatHashes boolean | undefined No Include flat hashes when generating the catalog
ifExists IfExists | undefined No Behavior when output file already exists
output string | undefined No Output catalog file path. If not specified, the default CodeIntegrityExternal.cat name is used.
recursive boolean | undefined No Include files from subdirectories
usePageHashes boolean | undefined No Include page hashes when generating the catalog

Also accepts CommonOptions (quiet, verbose, cwd).


getWinappPath()

Print the path to the .winapp directory. Use --global for the shared cache location, or omit for the project-local .winapp folder. Useful for build scripts that need to reference installed packages.

function getWinappPath(options?: GetWinappPathOptions): Promise<WinappResult>

Options:

Property Type Required Description
global boolean | undefined No Get the global .winapp directory instead of local

Also accepts CommonOptions (quiet, verbose, cwd).


init()

Start here for initializing a Windows app with required setup. Sets up everything needed for Windows app development: creates appxmanifest.xml with default assets, creates winapp.yaml for version management, and downloads Windows SDK and Windows App SDK packages and generates projections. Interactive by default (use --use-defaults to skip prompts). Use 'restore' instead if you cloned a repo that already has winapp.yaml. Use 'manifest generate' if you only need a manifest, or 'cert generate' if you need a development certificate for code signing.

function init(options?: InitOptions): Promise<WinappResult>

Options:

Property Type Required Description
baseDirectory string | undefined No Base/root directory for the winapp workspace, for consumption or installation.
configDir string | undefined No Directory to read/store configuration (default: current directory)
configOnly boolean | undefined No Only handle configuration file operations (create if missing, validate if exists). Skip package installation and other workspace setup steps.
ignoreConfig boolean | undefined No Don't use configuration file for version management
noGitignore boolean | undefined No Don't update .gitignore file
setupSdks SdkInstallMode | undefined No SDK installation mode: 'stable' (default), 'preview', 'experimental', or 'none' (skip SDK installation)
useDefaults boolean | undefined No Do not prompt, and use default of all prompts

Also accepts CommonOptions (quiet, verbose, cwd).


manifestGenerate()

Create appxmanifest.xml without full project setup. Use when you only need a manifest and image assets (no SDKs, no certificate). For full setup, use 'init' instead. Templates: 'packaged' (full MSIX), 'sparse' (desktop app needing Windows APIs).

function manifestGenerate(options?: ManifestGenerateOptions): Promise<WinappResult>

Options:

Property Type Required Description
directory string | undefined No Directory to generate manifest in
description string | undefined No Human-readable app description shown during installation and in Windows Settings
executable string | undefined No Path to the application's executable. Default: .exe
ifExists IfExists | undefined No Behavior when output file exists: 'error' (fail, default), 'skip' (keep existing), or 'overwrite' (replace)
logoPath string | undefined No Path to logo image file
packageName string | undefined No Package name (default: folder name)
publisherName string | undefined No Publisher CN (default: CN=)
template ManifestTemplates | undefined No Manifest template type: 'packaged' (full MSIX app, default) or 'sparse' (desktop app with package identity for Windows APIs)
version string | undefined No App version in Major.Minor.Build.Revision format (e.g., 1.0.0.0).

Also accepts CommonOptions (quiet, verbose, cwd).


manifestUpdateAssets()

Generate new assets for images referenced in an appxmanifest.xml from a single source image. Source image should be at least 400x400 pixels.

function manifestUpdateAssets(options: ManifestUpdateAssetsOptions): Promise<WinappResult>

Options:

Property Type Required Description
imagePath string Yes Path to source image file
manifest string | undefined No Path to AppxManifest.xml file (default: search current directory)

Also accepts CommonOptions (quiet, verbose, cwd).


packageApp()

Create MSIX installer from your built app. Run after building your app. appxmanifest.xml is required for packaging - it must be in current working directory, passed as --manifest or be in the input folder. Use --cert devcert.pfx to sign for testing. Example: winapp package ./dist --manifest appxmanifest.xml --cert ./devcert.pfx

function packageApp(options: PackageOptions): Promise<WinappResult>

Options:

Property Type Required Description
inputFolder string Yes Input folder with package layout
cert string | undefined No Path to signing certificate (will auto-sign if provided)
certPassword string | undefined No Certificate password (default: password)
executable string | undefined No Path to the executable relative to the input folder.
generateCert boolean | undefined No Generate a new development certificate
installCert boolean | undefined No Install certificate to machine
manifest string | undefined No Path to AppX manifest file (default: auto-detect from input folder or current directory)
name string | undefined No Package name (default: from manifest)
output string | undefined No Output msix file name for the generated package (defaults to .msix)
publisher string | undefined No Publisher name for certificate generation
selfContained boolean | undefined No Bundle Windows App SDK runtime for self-contained deployment
skipPri boolean | undefined No Skip PRI file generation

Also accepts CommonOptions (quiet, verbose, cwd).


restore()

Use after cloning a repo or when .winapp/ folder is missing. Reinstalls SDK packages from existing winapp.yaml without changing versions. Requires winapp.yaml (created by 'init'). To check for newer SDK versions, use 'update' instead.

function restore(options?: RestoreOptions): Promise<WinappResult>

Options:

Property Type Required Description
baseDirectory string | undefined No Base/root directory for the winapp workspace
configDir string | undefined No Directory to read configuration from (default: current directory)

Also accepts CommonOptions (quiet, verbose, cwd).


sign()

Code-sign an MSIX package or executable. Example: winapp sign ./app.msix ./devcert.pfx. Use --timestamp for production builds to remain valid after cert expires. The 'package' command can sign automatically with --cert.

function sign(options: SignOptions): Promise<WinappResult>

Options:

Property Type Required Description
filePath string Yes Path to the file/package to sign
certPath string Yes Path to the certificate file (PFX format)
password string | undefined No Certificate password
timestamp string | undefined No Timestamp server URL

Also accepts CommonOptions (quiet, verbose, cwd).


store()

Run a Microsoft Store Developer CLI command. This command will download the Microsoft Store Developer CLI if not already downloaded. Learn more about the Microsoft Store Developer CLI here: https://aka.ms/msstoredevcli

function store(options?: StoreOptions): Promise<WinappResult>

Options:

Property Type Required Description
storeArgs string[] | undefined No Arguments to pass through to the Microsoft Store Developer CLI.

Also accepts CommonOptions (quiet, verbose, cwd).


tool()

Run Windows SDK tools directly (makeappx, signtool, makepri, etc.). Auto-downloads Build Tools if needed. For most tasks, prefer higher-level commands like 'package' or 'sign'. Example: winapp tool makeappx pack /d ./folder /p ./out.msix

function tool(options?: ToolOptions): Promise<WinappResult>

Options:

Property Type Required Description
toolArgs string[] | undefined No Arguments to pass to the SDK tool, e.g. ['makeappx', 'pack', '/d', './folder', '/p', './out.msix'].

Also accepts CommonOptions (quiet, verbose, cwd).


update()

Check for and install newer SDK versions. Updates winapp.yaml with latest versions and reinstalls packages. Requires existing winapp.yaml (created by 'init'). Use --setup-sdks preview for preview SDKs. To reinstall current versions without updating, use 'restore' instead.

function update(options?: UpdateOptions): Promise<WinappResult>

Options:

Property Type Required Description
setupSdks SdkInstallMode | undefined No SDK installation mode: 'stable' (default), 'preview', 'experimental', or 'none' (skip SDK installation)

Also accepts CommonOptions (quiet, verbose, cwd).


Utility functions

execWithBuildTools()

Execute a command with BuildTools bin path added to PATH environment

function execWithBuildTools(command: string, options?: ExecSyncOptions): string | Buffer<ArrayBufferLike>

Parameters:

Parameter Type Required Description
command string Yes The command to execute
options ExecSyncOptions No Options to pass to execSync (optional)

Returns: The output from execSync


addMsixIdentityToExe()

Adds package identity information from an appxmanifest.xml file to an executable's embedded manifest

function addMsixIdentityToExe(exePath: string, appxManifestPath?: string | undefined, options?: MsixIdentityOptions): Promise<MsixIdentityResult>

Parameters:

Parameter Type Required Description
exePath string Yes Path to the executable file
appxManifestPath string | undefined No Path to the appxmanifest.xml file containing package identity data
options MsixIdentityOptions No Optional configuration

addElectronDebugIdentity()

Adds package identity to the Electron debug process

function addElectronDebugIdentity(options?: MsixIdentityOptions): Promise<ElectronDebugIdentityResult>

Parameters:

Parameter Type Required Description
options MsixIdentityOptions No Configuration options

clearElectronDebugIdentity()

Clears/removes package identity from the Electron debug process by restoring from backup

function clearElectronDebugIdentity(options?: MsixIdentityOptions): Promise<ClearElectronDebugIdentityResult>

Parameters:

Parameter Type Required Description
options MsixIdentityOptions No Configuration options

getGlobalWinappPath()

Get the path to the global .winapp directory

function getGlobalWinappPath(): string

Returns: The full path to the global .winapp directory


getLocalWinappPath()

Get the path to the local .winapp directory

function getLocalWinappPath(): string

Returns: The full path to the local .winapp directory


Node.js CLI commands

These commands are available exclusively via npx winapp node <subcommand> and are not exported as programmatic functions.

node create-addon

Generate native addon files for an Electron project. Supports C++ (node-gyp) and C# (node-api-dotnet) templates.

npx winapp node create-addon [options]

Options:

Flag Description
--name <name> Addon name (default depends on template)
--template <type> Addon template: cpp or cs (default: cpp)
--verbose Enable verbose output

Note: Must be run from the root of an Electron project (directory containing package.json).

Examples:

npx winapp node create-addon
npx winapp node create-addon --name myAddon
npx winapp node create-addon --template cs --name MyCsAddon

node add-electron-debug-identity

Add package identity to the Electron debug process using sparse packaging. Creates a backup of electron.exe, generates a sparse MSIX manifest, adds identity to the executable, and registers the sparse package. Requires an appxmanifest.xml (create one with winapp init or winapp manifest generate).

npx winapp node add-electron-debug-identity [options]

Options:

Flag Description
--manifest <path> Path to custom appxmanifest.xml (default: appxmanifest.xml in current directory)
--no-install Do not install the package after creation
--keep-identity Keep the manifest identity as-is, without appending .debug suffix
--verbose Enable verbose output

Note: Must be run from the root of an Electron project (directory containing node_modules/electron). To undo, use npx winapp node clear-electron-debug-identity.

Examples:

npx winapp node add-electron-debug-identity
npx winapp node add-electron-debug-identity --manifest ./custom/appxmanifest.xml

node clear-electron-debug-identity

Remove package identity from the Electron debug process. Restores electron.exe from the backup created by add-electron-debug-identity and removes the backup files.

npx winapp node clear-electron-debug-identity [options]

Options:

Flag Description
--verbose Enable verbose output

Note: Must be run from the root of an Electron project (directory containing node_modules/electron).

Examples:

npx winapp node clear-electron-debug-identity

Types reference

ExecSyncOptions

Re-exported from Node.js for convenience. See Node.js docs.

MsixIdentityOptions

Property Type Required Description
verbose boolean | undefined No
noInstall boolean | undefined No
keepIdentity boolean | undefined No
manifest string | undefined No

MsixIdentityResult

Property Type Required Description
success boolean Yes

ElectronDebugIdentityResult

Property Type Required Description
success boolean Yes
electronExePath string Yes
backupPath string Yes
manifestPath string Yes
assetsDir string Yes

ClearElectronDebugIdentityResult

Property Type Required Description
success boolean Yes
electronExePath string Yes
restoredFromBackup boolean Yes

CallWinappCliOptions

Property Type Required Description
exitOnError boolean | undefined No

CallWinappCliResult

Property Type Required Description
exitCode number Yes

CallWinappCliCaptureOptions

Property Type Required Description
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd())

CallWinappCliCaptureResult

Property Type Required Description
exitCode number Yes
stdout string Yes
stderr string Yes

GenerateCppAddonOptions

Property Type Required Description
name string | undefined No
projectRoot string | undefined No
verbose boolean | undefined No

GenerateCppAddonResult

Property Type Required Description
success boolean Yes
addonName string Yes
addonPath string Yes
needsTerminalRestart boolean Yes
files string[] Yes

GenerateCsAddonOptions

Property Type Required Description
name string | undefined No
projectRoot string | undefined No
verbose boolean | undefined No

GenerateCsAddonResult

Property Type Required Description
success boolean Yes
addonName string Yes
addonPath string Yes
needsTerminalRestart boolean Yes
files string[] Yes

IfExists

IfExists values.

type IfExists = "error" | "overwrite" | "skip"

SdkInstallMode

SdkInstallMode values.

type SdkInstallMode = "stable" | "preview" | "experimental" | "none"

ManifestTemplates

ManifestTemplates values.

type ManifestTemplates = "packaged" | "sparse"

CertGenerateOptions

Property Type Required Description
exportCer boolean | undefined No Export a .cer file (public key only) alongside the .pfx
ifExists IfExists | undefined No Behavior when output file exists: 'error' (fail, default), 'skip' (keep existing), or 'overwrite' (replace)
install boolean | undefined No Install the certificate to the local machine store after generation
json boolean | undefined No Format output as JSON
manifest string | undefined No Path to appxmanifest.xml file to extract publisher information from
output string | undefined No Output path for the generated PFX file
password string | undefined No Password for the generated PFX file
publisher string | undefined No Publisher name for the generated certificate. If not specified, will be inferred from manifest.
validDays number | undefined No Number of days the certificate is valid
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

CertInfoOptions

Property Type Required Description
certPath string Yes Path to the certificate file (PFX)
json boolean | undefined No Format output as JSON
password string | undefined No Password for the PFX file
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

CertInstallOptions

Property Type Required Description
certPath string Yes Path to the certificate file (PFX or CER)
force boolean | undefined No Force installation even if the certificate already exists
password string | undefined No Password for the PFX file
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

CreateDebugIdentityOptions

Property Type Required Description
entrypoint string | undefined No Path to the .exe that will need to run with identity, or entrypoint script.
keepIdentity boolean | undefined No Keep the package identity from the manifest as-is, without appending '.debug' to the package name and application ID.
manifest string | undefined No Path to the appxmanifest.xml
noInstall boolean | undefined No Do not install the package after creation.
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

CreateExternalCatalogOptions

Property Type Required Description
inputFolder string Yes List of input folders with executable files to process (separated by semicolons)
computeFlatHashes boolean | undefined No Include flat hashes when generating the catalog
ifExists IfExists | undefined No Behavior when output file already exists
output string | undefined No Output catalog file path. If not specified, the default CodeIntegrityExternal.cat name is used.
recursive boolean | undefined No Include files from subdirectories
usePageHashes boolean | undefined No Include page hashes when generating the catalog
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

GetWinappPathOptions

Property Type Required Description
global boolean | undefined No Get the global .winapp directory instead of local
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

InitOptions

Property Type Required Description
baseDirectory string | undefined No Base/root directory for the winapp workspace, for consumption or installation.
configDir string | undefined No Directory to read/store configuration (default: current directory)
configOnly boolean | undefined No Only handle configuration file operations (create if missing, validate if exists). Skip package installation and other workspace setup steps.
ignoreConfig boolean | undefined No Don't use configuration file for version management
noGitignore boolean | undefined No Don't update .gitignore file
setupSdks SdkInstallMode | undefined No SDK installation mode: 'stable' (default), 'preview', 'experimental', or 'none' (skip SDK installation)
useDefaults boolean | undefined No Do not prompt, and use default of all prompts
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

ManifestGenerateOptions

Property Type Required Description
directory string | undefined No Directory to generate manifest in
description string | undefined No Human-readable app description shown during installation and in Windows Settings
executable string | undefined No Path to the application's executable. Default: .exe
ifExists IfExists | undefined No Behavior when output file exists: 'error' (fail, default), 'skip' (keep existing), or 'overwrite' (replace)
logoPath string | undefined No Path to logo image file
packageName string | undefined No Package name (default: folder name)
publisherName string | undefined No Publisher CN (default: CN=)
template ManifestTemplates | undefined No Manifest template type: 'packaged' (full MSIX app, default) or 'sparse' (desktop app with package identity for Windows APIs)
version string | undefined No App version in Major.Minor.Build.Revision format (e.g., 1.0.0.0).
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

ManifestUpdateAssetsOptions

Property Type Required Description
imagePath string Yes Path to source image file
manifest string | undefined No Path to AppxManifest.xml file (default: search current directory)
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

PackageOptions

Property Type Required Description
inputFolder string Yes Input folder with package layout
cert string | undefined No Path to signing certificate (will auto-sign if provided)
certPassword string | undefined No Certificate password (default: password)
executable string | undefined No Path to the executable relative to the input folder.
generateCert boolean | undefined No Generate a new development certificate
installCert boolean | undefined No Install certificate to machine
manifest string | undefined No Path to AppX manifest file (default: auto-detect from input folder or current directory)
name string | undefined No Package name (default: from manifest)
output string | undefined No Output msix file name for the generated package (defaults to .msix)
publisher string | undefined No Publisher name for certificate generation
selfContained boolean | undefined No Bundle Windows App SDK runtime for self-contained deployment
skipPri boolean | undefined No Skip PRI file generation
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

RestoreOptions

Property Type Required Description
baseDirectory string | undefined No Base/root directory for the winapp workspace
configDir string | undefined No Directory to read configuration from (default: current directory)
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

SignOptions

Property Type Required Description
filePath string Yes Path to the file/package to sign
certPath string Yes Path to the certificate file (PFX format)
password string | undefined No Certificate password
timestamp string | undefined No Timestamp server URL
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

StoreOptions

Property Type Required Description
storeArgs string[] | undefined No Arguments to pass through to the Microsoft Store Developer CLI.
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

ToolOptions

Property Type Required Description
toolArgs string[] | undefined No Arguments to pass to the SDK tool, e.g. ['makeappx', 'pack', '/d', './folder', '/p', './out.msix'].
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).

UpdateOptions

Property Type Required Description
setupSdks SdkInstallMode | undefined No SDK installation mode: 'stable' (default), 'preview', 'experimental', or 'none' (skip SDK installation)
quiet boolean | undefined No Suppress progress messages.
verbose boolean | undefined No Enable verbose output.
cwd string | undefined No Working directory for the CLI process (defaults to process.cwd()).