Local Development
The Flow Command Line Interface (CLI) is a set of tools that developers can use to interact with the Flow blockchain by managing accounts, sending transactions, deploying smart contracts, running the emulator, and more. This quickstart will get you familiar with its main concepts and functionality.
Objectives
After completing this guide, you'll be able to:
- Create a Flow project using the Flow Command Line Interface
- Add an already-deployed contract to your project with the Dependency Manager
- Deploy a smart contract locally to the Flow Emulator
- Write and execute scripts to interact with a deployed smart contract
Installation
The first thing you'll need to do is install the Flow CLI. If you have homebrew installed you can run:
_10brew install flow-cli
For other ways of installing, please refer to the installation guide.
Configuration
Lets first create a project directory and navigate to it:
_10mkdir cli-quickstart_10cd cli-quickstart
Next, we'll initialize a new Flow project with the CLI:
_10flow init --config-only
This will create a flow.json file in your project directory. This file is used to configure your project and describe the setup of your contracts, networks, and accounts.
It will also have a default emulator-account created for you. We'll use this account to interact with the emulator later on.
For additional details on how flow.json is configured, review the configuration docs.
Grabbing the HelloWorld Contract
For this demo, we are going to be interacting with a simple HelloWorld contract, written in Cadence, that is already deployed on Flow's testnet network on account 0xa1296b1e2e90ca5b. In order to grab this project dependency, we'll use Flow's Dependency Manager to install it into our project using a source string that defines the network, address, and contract name of the contract we want to import.
_10flow dependencies add testnet://0xa1296b1e2e90ca5b.HelloWorld
This will add the HelloWorld contract and any of its dependencies to an imports directory in your project. We recommend adding this directory to your .gitignore file, which is done by the script by default. It will also add any dependencies to your flow.json file.
During the install you'll be prompted to specify which account to deploy the contracts to. For this tutorial, you can select the default emulator-account. Leave the alias address for HelloWorld on mainnet blank.
Review the 📝 Dependency Manager Actions Summary for a list of actions completed by the script.
Open imports/a1296b1e2e90ca5b/HelloWorld.cdc in your editor. You will see the following:
_14access(all) contract HelloWorld {_14_14  access(all)_14  var greeting: String_14_14  access(all)_14  fun changeGreeting(newGreeting: String) {_14    self.greeting = newGreeting_14  }_14_14  init() {_14    self.greeting = "Hello, World!"_14  }_14}
This contract has a greeting variable that can be read and changed. It also has a changeGreeting function that allows you to change the greeting.
Deploying the Contract to Emulator
The emulator is a local version of the Flow blockchain that you can use to test your contracts and scripts. It's a great way to develop and test your contracts locally - before you try them on the testnet or mainnet.
Before we deploy, let's open a new terminal window and run the emulator.  From the root of your project directory, where your emulator-account.pkey and flow.json files are located, run:
_10flow emulator start
If you see a message that configuration is missing, you are in the wrong directory.  Do not run flow init!.
🙏 Configuration is missing, initialize it with: 'flow init' and then rerun this command.
To deploy the HelloWorld contract to the emulator, return to your first terminal and run the following command:
_10flow project deploy
You should see:
_10🎉 All contracts deployed successfully
The contract will now have been deployed to the default emulator-account. You can now interact with it using a script.
Running Scripts
Scripts are used to read data from the Flow blockchain. There is no state modification. In our case, we are going to read a greeting from the HelloWorld contract.
Let's create a script file. We can generate a boilerplate script file with the following command:
_10flow generate script ReadGreeting
This will create a file called ReadGreeting.cdc in the cadence/scripts directory.  Let's update the script to read the greeting from the HelloWorld contract.  Replace the existing coded with:
_10import "HelloWorld"_10_10access(all) fun main(): String {_10  return HelloWorld.greeting_10}
The import syntax will automatically resolve the address of the contract on the network you are running the script on. This is determined by your flow.json configuration.
If you'll like to learn more about writing scripts, please check out the docs for basic scripts.
To run the script, we'll run this from the CLI:
_10flow scripts execute cadence/scripts/ReadGreeting.cdc
You should see the result of the greeting. Result: "Hello, world!"
Creating an Account and Running a Transaction
To change state on the Flow Blockchain, you need to run a transaction. Let's create a simple transaction file. We can use to modify the greeting on the HelloWorld contract.
First, create a file called cadence/transactions/ChangeGreeting.cdc with the following command:
_10flow generate transaction ChangeGreeting
Open the new file - cadence/transactions/ChangeGreeting.cdc.  Update the boilerplate transaction to look like this:
_12import "HelloWorld"_12_12transaction(greeting: String) {_12_12  prepare(acct: &Account) {_12    log(acct.address)_12  }_12_12  execute {_12    HelloWorld.changeGreeting(newGreeting: greeting)_12  }_12}
This will log the account signing the transaction, call the changeGreeting method of the HelloWorld contract, and pass in the new greeting.
If you want to learn more about writing transactions, please read the docs for basic transactions.
In order to run a transaction, the signing account needs to pay for it. You could run the transaction on emulator using the default emulator-account account, but a better test is to run it with a new test account.
Let's learn the command for creating accounts.
The easiest way to create an account using CLI is with:
_10flow accounts create
Remember, your emulator should still be running at this point in another terminal.
Give your account the name emulator-tester, then select Emulator as the network.  You'll now see this account in your flow.json.
To run a transaction with this new account, you can run the following:
_10flow transactions send cadence/transactions/ChangeGreeting.cdc "Hello, me" --signer emulator-tester --network emulator
You've just modified the state of the Flow Blockchain! At least on the emulator. You'll know it worked if you see the receipt. Yours will be similar to:
_10Transaction ID: 2ff6cbb8125103595fca0abaead94cd00510d29902ceae9f5dc480e927ab7334_10_10Block ID	36bbf6fc573129fa9a3c78a43e257d3b627a3af78fd9e64eeb133d981819cc69_10Block Height	3_10Status		✅ SEALED_10ID		2ff6cbb8125103595fca0abaead94cd00510d29902ceae9f5dc480e927ab7334_10Payer		179b6b1cb6755e31_10Authorizers	[179b6b1cb6755e31]
You can also re-run the ReadGreeting script with:
_10flow scripts execute cadence/scripts/ReadGreeting.cdc
You'll now see:
_10Result: "Hello, me"
More
If you want to continue on generating your own contracts, you can also use the the generate subcommand to create a new contract file. See more in the generate documentation.
After that, it's easy to add your contract to your project configuration using the Flow CLI config commands.