Skip to content

Interact and view your private deployment from your commandline.

To use the Partisia CLI tool with a private deployment you must first configure it to target your chain. This can be done by running the following command

cargo pbc config net local "http://localhost:9432,http://localhost:8300" --default

Where

  • http://localhost:9432 is the url of the reader endpoint
  • http://localhost:8300 is the url of the browser

Any following command will now target the private deployment

Partisia CLI commands

You can get information about the usage or option for any command by using the option --help.

Below are some commonly used commands.

Create a key pair to create an account

You can create a key pair with the following command.

cargo pbc account create --file=./key.pk

The --file option lets you choose the file the private key is saved in.

Response from example command
Address: {Blockchain address of the account}

Deploy a contract

cargo pbc transaction deploy --pk=./key.pk token.pbc  Test Test 3 1050

Where

  • ./key.pk is the path to your private key file
  • token.pbc is the wasm byte code and abi byte code of your contract.
  • Test Test 3 1050 are the RPC arguments to the init function of your contract. In this case two strings and two numbers.
Response from example command
Deployed contract successfully.
Contract deployed at: 021c79a1b80a9f30ac49675a834f532fcb70276f8b
View it in browser here: http://localhost:8300/contracts/021c79a1b80a9f30ac49675a834f532fcb70276f8b

Send a transaction to a contract

cargo pbc transaction action --pk=./key.pk 021c79a1b80a9f30ac49675a834f532fcb70276f8b transfer 00db4eb445882bdb5c40c5959d1260d9383035b4e5 100

Where

  • ./key.pk is the path to your private key file
  • 021c79a1b80a9f30ac49675a834f532fcb70276f8b is the address of the contract
  • transfer is the name of the action you are trying to invoke
  • 00db4eb445882bdb5c40c5959d1260d9383035b4e5 100 are the RPC arguments of that action. In this case an address and an amount.
Response from example command
Transaction successfully sent: http://localhost:8300/transactions/220f27415e1781eda864decc53b3362345efaedb4e5ed79b2ea2d8d0297015ee

Show the state of a contract

cargo pbc contract show 021c79a1b80a9f30ac49675a834f532fcb70276f8b --state

Where

  • 021c79a1b80a9f30ac49675a834f532fcb70276f8b is the address of the contract
  • --state is the option for showing the state of the contract
Response from example command
{
  "contractState" : {
    "name" : "Test",
    "decimals" : 3,
    "symbol" : "Test",
    "owner" : "00e72e44eab933faaf1fd4ce94bb57e08bff98a1ed",
    "total_supply" : "1050",
    "balances" : [ {
      "key" : "00db4eb445882bdb5c40c5959d1260d9383035b4e5",
      "value" : "100"
    }, {
      "key" : "00e72e44eab933faaf1fd4ce94bb57e08bff98a1ed",
      "value" : "950"
    } ],
    "allowed" : [ ]
  }
}

Show list of owned secret variables

cargo pbc contract --pk=./key.pk secret list 03728784c957e46f7f428dc8b8348ce1e7d1d709bc

Where

  • ./key.pk is the path to your private key file
  • 021c79a1b80a9f30ac49675a834f532fcb70276f8b is the address of the contract
Response from example command
[ {
"id" : 1,
"owner" : "00e72e44eab933faaf1fd4ce94bb57e08bff98a1ed",
"sealed" : false,
"transaction" : "044b7860c2d118d708c7a2b5136941d66ebbf89709e69b7f773f6f721caa0ba5",
"information" : {
"data" : "AA=="
}
} ]

Get value of owned secret

cargo pbc contract --pk=./key.pk secret show 03728784c957e46f7f428dc8b8348ce1e7d1d709bc 1 i32

Where

  • ./key.pk is the path to your private key file
  • 021c79a1b80a9f30ac49675a834f532fcb70276f8b is the address of the contract
  • 1 is the id of the variable
  • i32 is the type of the variable. Can be a number type or a named type defined in the abi.
Response from example command
Secret: 400

ABI commands

The abi command contains subcommands useful for working with ABIs.

Show the structure of an ABI

cargo pbc abi show ./token.pbc

Where

  • ./token.abi is the path to the file containing your ABI.
Response from example command
// Version Binder: 10.2.0
// Version Client: 5.5.0

pub struct EventSubscriptionId {
raw_id: i32,
}
pub struct ExternalEventId {
raw_id: i32,
}
pub struct SecretVarId {
raw_id: u32,
}
pub struct Transfer {
to: Address,
amount: u128,
}
#[state]
pub struct TokenState {
name: String,
decimals: u8,
symbol: String,
owner: Address,
total_supply: u128,
balances: Map<Address, u128>,
allowed: Map<Address, Map<Address, u128>>,
}
#[init]
pub fn initialize (
name: String,
symbol: String,
decimals: u8,
total_supply: u128,
)
#[action(shortname = 0x01)]
pub fn transfer (
to: Address,
amount: u128,
)
#[action(shortname = 0x02)]
pub fn bulk_transfer (
transfers: Vec<Transfer>,
)
#[action(shortname = 0x03)]
pub fn transfer_from (
from: Address,
to: Address,
amount: u128,
)
#[action(shortname = 0x04)]
pub fn bulk_transfer_from (
from: Address,
transfers: Vec<Transfer>,
)
#[action(shortname = 0x05)]
pub fn approve (
spender: Address,
amount: u128,
)
#[action(shortname = 0x07)]
pub fn approve_relative (
spender: Address,
delta: i128,
)

Generate code for a contract interactions

cargo pbc abi codegen --ts ./token.pbc Token.ts

Where

  • --ts is the language to generate. Supported languages are --ts and --java.
  • ./token.pbc is the path to the file containing your abi file.
  • Token.ts is the name of the generated file.

This generates a file able to serialize RPC payloads or deserialize state.

Partisia All Rights Reserved © 2023