Bittensor CLI: Permissions Guide
The Bittensor CLI, btcli
provides a wide range of functionality, and has a range of different requirements for various commands: some require a coldkey private key to authenticate, some require a hotkey private key, and some require neither. Additionally, different functions require different levels of permissions. Some require the user to have special status like being registered with a node, have a validator permit, or be an active member of the senate.
This page details the requirements for all of the btcli
commands.
See also the btcli
permissions guides for specific Bittensor personas:
- Staker's Guide to
BTCLI
- Miner's Guide to
BTCLI
- Validator's Guide to
BTCLI
- Subnet Creator's Guide to
BTCLI
- Senator's Guide to
BTCLI
Other resources:
Bittensor work environments and security requirements
Interacting with Bittensor generally falls into one of three levels of security, depending on whether you need to use your coldkey private key, hotkey private key, or neither.
The workstations you use to do this work can be referred to as a permissionless workstation (requiring neither private key), a coldkey workstation or a hotkey workstation, depending on which private key is provisioned.
-
A permissionless workstation has only coldkey public keys on it. Public keys are sufficient for viewing all information about a wallet, such as TAO and alpha stake balances. Information about wallets, subnets, miners, and validators can and should be viewed without initializing your private keys on a device, to avoid the security risk of compromising your keys.
coldkey workstation security -
A coldkey workstation contains one or more coldkey private key in the
wallet_path
. For any coldkey associated with mainnet TAO, the coldkey workstation should be held to the highest possible security standards.coldkey workstation securitySee [Coldkey workstation](./ getting-started/coldkey-hotkey-security#coldkey-workstation)
-
A hotkey workstation—which is generally a server used for mining or validation—contains a hotkey private key in the
wallet_path
located in thebtcli config
, as well as a coldkey public key for the corresponding coldkey. Compromised hotkeys can damage your reputation if they are used to maliciously to submit inaccurate weights as a validator, or bad work as a miner. However, ownership of TAO or alpha stake can only be transferred with a coldkey, and a leaked hotkey can be swapped using the coldkey; therefore hotkey leaks are far less dangerous than coldkey leaks.hotkey workstation
Requirements for btcli
functions
Coldkey
Your coldkey is your primary, fully privileged key; important for all users. This key should be handled on a maximum security coldkey workstation only, to avoid catastrophic loss or malicious actions if compromised.
See Coldkey and Hotkey Workstation Security.
Required for:
- Moving and transferring TAO
- Managing stake (add/remove/move)
- Creating hotkeys
- Registering hotkeys in subnets
- Creating and modifying subnets
- Participating in governance of Bittensor as a senator
Hotkey
Hotkeys are used by miners and validators to sign transactions, and are required for governance.
Required for:
- Running miners:
- Serving requests from validators
- Making on-chain data commitments (if applicable)
- Running validators:
- making signed requests to miners
- setting weights
- being discoverable by stakers and miners
Available liquidity
Some operations require a TAO balance or alpha stake balance to execute.
- Transfers of TAO fail if you lack the specified amount
- Staking and unstaking operations fail if they specify more than the owner has
- Registering a hotkey on a subnet to mine or validate has a fee that can be paid with TAO or proof-of-work.
- Creating a subnet requires a fee, which is computed dynamically. The price to create a subnet doubles when someone creates a subnet, and then gradually decreases. This system is designed as a kind of distributed auction, where price is determined by what people are willing to pay given the uncertain estimation of what others are willing to pay.
Validator Permit
To set weights, a validator must meet several requirements. See Requirements for validation.
Senate requirements
btcli
commands
config
The btcli config ...
commands are used to configure btcli
, including:
- selecting the targeted network (
finney
a.k.a. mainnet ortest
for test network) - setting the directory where your Bittensor wallet coldkeys and/or hotkeys are stored
These commands don't require any permissions to run. Rather, you run these commands on all btcli
workstations to initialize them.
See: Coldkey and Hotkey Workstation Security
btcli config
-
btcli config set
-
btcli config get
-
btcli config clear
-
btcli config metagraph
-
btcli conf set
-
btcli conf get
-
btcli conf clear
-
btcli conf metagraph
-
btcli c set
-
btcli c get
-
btcli c clear
-
btcli c metagraph
wallet
wallet
subcommands have a variety of uses and must be run on all different kinds of workstation.
The wallet
command is required to provision keys to btcli
, so it can access your wallet. This is essentially the equivalent of logging in/authentication. This is true for both coldkeys, which all users require, and hotkeys, which are required only by miners and validators as well as for advanced functions.
Provisioning keys
-
btcli wallet regen-coldkeypub
: This initializes a wallet for a permissionless workstation with a public key only. It allows you to read all information about your wallet, which is public information. However, it doesn't allow you to sign any transactions and therefore doesn't allow you to make any changes to the state of the blockchain, including any of your balances or stakes. -
new coldkey
is used to initialize a coldkey workstation using a newly created seed phrase. This is a high security risk operation due to the inherent risk of handling the seed phrase. -
regen coldkey
is used to initialize a coldkey workstation using a pre-existing wallet's seed phrase. This is a high security risk operation due to the inherent risk of handling the seed phrase. -
new hotkey
is used to initialize a hotkey workstation using a newly created seed phrase. This is a high security risk operation due to the inherent risk of handling the seed phrase. Hotkeys should be created on secure coldkey workstation and then carefully provisioned to working nodes for mining and validation. -
regen hotkey
is used to initialize a hotkey workstation using a pre-existing wallet's seed phrase. This is a high security risk operation due to the inherent risk of handling the seed phrase.
Permissionless operations
btcli wallet balance
: Displays a wallet balance.btcli wallet overview
: Displays a wallet overview.
Operations requiring coldkey private key:
swap-hotkey
rotates a hotkey coldkey owned by the coldkey.new-hotkey
creates a new hotkey owned by the coldkey.transfer
transfers TAO to another coldkey.set-identity
sets the coldkey's public identity information.sign
(with coldkey) signs a message with the coldkey.
Operations requiring hotkey private key:
sign
(with hotkey): sign a message with the hotkey
btcli wallet
btcli wallet list
btcli wallet swap-hotkey
btcli wallet regen-coldkey
btcli wallet regen-coldkeypub
btcli wallet regen-hotkey
btcli wallet new-hotkey
btcli wallet new-coldkey
btcli wallet create
btcli wallet balance
btcli wallet overview
btcli wallet transfer
btcli wallet inspect
btcli wallet faucet
btcli wallet set-identity
btcli wallet get-identity
btcli wallet sign
btcli wallet swap_hotkey
btcli wallet regen_coldkey
btcli wallet regen_coldkeypub
btcli wallet regen_hotkey
btcli wallet new_hotkey
btcli wallet new_coldkey
btcli wallet set_identity
btcli wallet get_identity
btcli w list
btcli w swap-hotkey
btcli w regen-coldkey
btcli w regen-coldkeypub
btcli w regen-hotkey
btcli w new-hotkey
btcli w new-coldkey
btcli w create
btcli w balance
btcli w overview
btcli w transfer
btcli w inspect
btcli w faucet
btcli w set-identity
btcli w get-identity
btcli w sign
btcli w swap_hotkey
btcli w regen_coldkey
btcli w regen_coldkeypub
btcli w regen_hotkey
btcli w new_hotkey
btcli w new_coldkey
btcli w set_identity
btcli w get_identity
btcli wallets list
btcli wallets swap-hotkey
btcli wallets regen-coldkey
btcli wallets regen-coldkeypub
btcli wallets regen-hotkey
btcli wallets new-hotkey
btcli wallets new-coldkey
btcli wallets create
btcli wallets balance
btcli wallets history
btcli wallets overview
btcli wallets transfer
btcli wallets inspect
btcli wallets faucet
btcli wallets set-identity
btcli wallets get-identity
btcli wallets sign
btcli wallets swap_hotkey
btcli wallets regen_coldkey
btcli wallets regen_coldkeypub
btcli wallets regen_hotkey
btcli wallets new_hotkey
btcli wallets new_coldkey
btcli wallets set_identity
btcli wallets get_identity
stake
Read operations require public keys. Write operations (stake add, move, remove...) require a coldkey private key.