Setup Supra CLI

Installation of the Supra CLI using Docker.

Prerequisites

The installation process of Docker is straight forward and requires no additional configuration. The only requirement to proceed is to ensure the Docker Daemon is running. If you installed Docker Engine, opening the program will start the daemon.

Install and Setup the CLI

1

Start the container with Docker Compose

Open your terminal and cd to the directory on your machine where you wish to setup the CLI. For convenience, we recommend placing it within the Documents directory. However, this is entirely arbitrary and there will be no repercussions for choosing differently.

execute me!
cd Documents

The following command will use the latest compose file (which you can view here) and pipe it into the Docker Compose command. This will pull the latest image, create, and start the container. Please note that the following command will create a supra directory within your current working directory if one does not already exist.

execute me!
curl https://raw.githubusercontent.com/supra-labs/supra-dev-hub/refs/heads/main/Scripts/cli/compose.yaml | docker compose -f - up -d

You can confirm that the container is running by executing docker ps --all. This command will output all docker containers that exist on your machine, whether they are running or stopped.

2

Enter the shell of the container

To interact with the Supra CLI, we must enter the shell of the container. This will allow us to execute commands within the container from our host machine.

execute me!
docker exec -it supra_cli /bin/bash 

Once inside, execute the ls command to gain a simple understanding of the file system. The displayed configs directory is bind mounted to the /supra/configs directory on your host machine. These directories are shared/linked between your host machine and the container.

Note: "supra" is the CLI binary within the container. The compose file automatically setup the alias to interact with the binary using the "supra" command.
3

Execute the supra command

Example output of the "supra" command

Within the shell of the container, CLI commands operate in the same manner as you would expect on your host machine. For example, executing commands such as supra move tool init will initialize the new module within your current working directory. You may view all available arguments of any command by passing the --help argument.

Example: supra move tool init --help

Last updated