# Commands A CLI is provided to support building and managing an Anchor workspace. For a comprehensive list of commands and options, run `anchor -h` on any of the following subcommands. ``` anchor-cli USAGE: anchor FLAGS: -h, --help Prints help information -V, --version Prints version information SUBCOMMANDS: build Builds the workspace cluster Cluster commands deploy Deploys each program in the workspace help Prints this message or the help of the given subcommand(s) idl Commands for interacting with interface definitions init Initializes a workspace launch Deploys, initializes an IDL, and migrates all in one command migrate Runs the deploy migration script new Creates a new program test Runs integration tests against a localnetwork upgrade Upgrades a single program. The configured wallet must be the upgrade authority verify Verifies the on-chain bytecode matches the locally compiled artifact. Run this command inside a program subdirectory, i.e., in the dir containing the program's Cargo.toml ``` ## Init ``` anchor init ``` Initializes a project workspace wit the following structure. * `Anchor.toml`: Anchor configuration file. * `Cargo.toml`: Rust workspace configuration file. * `programs/`: Directory for Solana program crates. * `app/`: Directory for your application frontend. * `tests/`: Directory for JavaScript integration tests. * `migrations/deploy.js`: Deploy script. ## Build ``` anchor build ``` Builds programs in the workspace targeting Solana's BPF runtime and emitting IDLs in the `target/idl` directory. ## Deploy ``` anchor deploy ``` Deploys all programs in the workspace to the configured cluster. ::: tip Note This is different from the `solana program deploy` command, because everytime it's run it will generate a *new* program address. ::: ## Upgrade ``` anchor upgrade --program-id ``` Uses Solana's upgradeable BPF loader to upgrade the on chain program code. ## Test ``` anchor test ``` Run an integration test suit against the configured cluster, deploying new versions of all workspace programs before running them. If the configured network is a localnet, then automatically starts the localnetwork and runs the test. ::: tip Note The Anchor workflow [recommends](https://www.parity.io/paritys-checklist-for-secure-smart-contract-development/) to test your program using integration tests in a language other than Rust to make sure that bugs related to syntax misunderstandings are coverable with tests and not just replicated in tests. ::: ## Migrate ``` anchor migrate ``` Runs the deploy script located at `migrations/deploy.js`, injecting a provider configured form the workspace's `Anchor.toml`. For example, ```javascript // File: migrations/deploys.js const anchor = require("@project-serum/anchor"); module.exports = async function (provider) { anchor.setProvider(provider); // Add your deploy script here. } ``` Migrations are a new feature and only support this simple deploy script at the moment. ## Idl The `idl` subcommand provides commands for interacting with interface definition files. It's recommended to use these commands to store an IDL on chain, at a deterministic address, as a function of nothing but the the program's ID. This allow us to generate clients for a program using nothing but the program ID. ### Idl Init ``` anchor idl init -f ``` Creates an idl account, writing the given `` file into a program owned account. By default, the size of the account is double the size of the IDL, allowing room for growth in case the idl needs to be upgraded in the future. ### Idl Fetch ``` anchor idl fetch -o ``` Fetches an IDL from the configured blockchain. For example, make sure your `Anchor.toml` is pointing to the `mainnet` cluster and run ``` anchor idl fetch GrAkKfEpTKQuVHG2Y97Y2FF4i7y7Q5AHLK94JBy7Y5yv ``` ### Idl Authority ``` anchor idl authority ``` Outputs the IDL account's authority. This is the wallet that has the ability to update the IDL. ### Idl Erase Authority ``` anchor idl erase-authority -p ``` Erases the IDL account's authority so that upgrades can no longer occur. The configured wallet must be the current authority. ### Idl Upgrade ``` anchor idl upgrade -f ``` Upgrades the IDL file on chain to the new `target/idl/program.json` idl. The configured wallet must be the current authority. ``` anchor idl set-authority -n -p ``` Sets a new authority on the IDL account. Both the `new-authority` and `program-id` must be encoded in base 58. ## Launch ``` anchor launch ``` Builds, deploys and migrates, all in one command. This is particularly useful when simultaneously developing an app against a Localnet or Devnet. For mainnet, it's recommended to run each command separately, since transactions can sometimes be unreliable depending on the Solana RPC node being used. ## New ``` anchor new ``` Creates a new program in the workspace's `programs/` directory initialized with boilerplate. ## Cluster ### Cluster list ``` anchor cluster list ``` This lists cluster endpoints: ``` Cluster Endpoints: * Mainnet - https://solana-api.projectserum.com * Mainnet - https://api.mainnet-beta.solana.com * Devnet - https://api.devnet.solana.com * Testnet - https://api.testnet.solana.com ``` ## Verify Verifies the on-chain bytecode matches the locally compiled artifact.