Kagome
Polkadot Runtime Engine in C++17
docs/source/tutorials/first_kagome_chain.md
Go to the documentation of this file.
1 ## Your first Kagome chain
2 
3 In this tutorial you will learn how to execute Kagome-based Polkadot-host chain which can be used as a cryptocurrency, and interact with it by sending extrinsics and executing queries.
4 
5 ### Prerequisites
6 
7 1. Kagome validating node binary built as described [here](https://kagome.readthedocs.io/en/latest/overview/getting_started.html#build-application).
8 2. For your convenience make sure you have this binary included into your path:
9 
10  ```bash
11  # from Kagome's root repo:
12  PATH=$PATH:$(pwd)/build/node/
13  ```
14 
15 3. Python 3 installed in the system with `substrate-interface` package installed
16 
17  > If you are not sure if you have requests package installed in your python run `pip3 install substrate-interface`
18 
19 ### Tutorial
20 
21 During this tutorial we will:
22 1. Launch Kagome network using prepared genesis file
23 2. Query the balance of Alice account
24 3. Send extrinsic that transfers some amount of currency from Alice to Bob
25 4. Query again the balance of Alice to make sure balance was updated
26 
27 #### Launch Kagome network
28 
29 For this tutorial we will spin up a simple network of a single peer with predefined genesis.
30 
31 To start with let's navigate into the node's folder:
32 
33 ```shell script
34 cd examples/first_kagome_chain
35 ```
36 
37 `first_kagome_chain` folder contains necessary configuration files for our tutorial:
38 
39 * `localchain.json` – genesis file for our network. It contains necessary key-value pairs that should be inserted before the genesis block
40 * `base_path` – Directory, containing kagome base path. It contains several dirs, each one named with the chain id, which data it stores (`dev` in this case). Data for each chain consists of `db/` (will be initialized on node startup) and `keystore/` (keys to sign the messages sent by our authority). The latter has to exist prior to the node start. This behaviour will be improved in the future.
41 
42 `localchain.json` contains Alice and Bob accounts. Both have 999998900.0 amount of crypto.
43 Their keys can be generated using [subkey](https://substrate.dev/docs/en/knowledgebase/integrate/subkey) tool:
44 ```shell script
45 subkey inspect //Alice
46 # Secret Key URI `//Alice` is account:
47 # Secret seed: 0xe5be9a5092b81bca64be81d212e7f2f9eba183bb7a90954f7b76361f6edb5c0a
48 # Public key (hex): 0xd43593c715fdd31c61141abd04a99fd6822c8558854ccde39a5684e7a56da27d
49 # Account ID: 0xd43593c715fdd31c61141abd04a99fd6822c8558854ccde39a5684e7a56da27d
50 # SS58 Address: 5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY
51 
52 subkey inspect //Bob
53 # Secret Key URI `//Bob` is account:
54 # Secret seed: 0x398f0c28f98885e046333d4a41c19cee4c37368a9832c6502f6cfd182e2aef89
55 # Public key (hex): 0x8eaf04151687736326c9fea17e25fc5287613693c912909cb226aa4794f26a48
56 # Account ID: 0x8eaf04151687736326c9fea17e25fc5287613693c912909cb226aa4794f26a48
57 # SS58 Address: 5FHneW46xGXgs5mUiveU4sbTyGBzmstUspZC92UhjJM694ty
58 ```
59 
60 
61 > If you are running this tutorial not for the first time, then make sure you cleaned up your storage as follows (assuming storage files are generated in ldb/ folder):
62 > ```
63 > rm -rf ldb
64 > ```
65 > ---
66 
67 For this tutorial you can start a single node network as follows:
68 
69 ```shell script
70 kagome \
71  --validator \
72  --chain localchain.json \
73  --base-path base_path \
74  --port 30363 \
75  --rpc-port 9933 \
76  --ws-port 9944
77 ```
78 
79 Let's look at this flags in detail:
80 
81 | Flag | Description |
82 |-------------------|---------------------------------------------------|
83 | `--validator` | optional, enables validator mode |
84 | `--chain` | mandatory, chainspec file path |
85 | `--base-path` | mandatory, base kagome directory path |
86 | `--port` | port for p2p interactions |
87 | `--rpc-port` | port for RPC over HTTP |
88 | `--ws-port` | port for RPC over Websocket protocol |
89 
90 More flags info available by running `kagome --help`.
91 
92 You should see the log messages notifying about produced and finalized the blocks.
93 
94 Now chain is running on a single node. To query it we can use localhost's ports 9933 for http- and 9944 for websockets-based RPCs.
95 
96 > Kagome blockchain is constantly producing new blocks, even if there were no transactions in the network.
97 
98 #### Query the balance
99 
100 Now open second terminal and go to the transfer folder, available from the projects root directory.
101 
102 `cd examples/transfer`
103 
104 This folder contains two python scripts:
105 
106 1. `balance.py <address> <account_id>` – executes query to kagome, which returns balance of provided account
107  * `<address>` address node's http service
108  * `<account_id>` id of account being queried
109 2. `transfer.py <address> <seed> <dest> <amount>` – sends provided extrinsic
110  * `<address>` address node's http service
111  * `<seed>` secret seed of source account
112  * `<dest>` destination account
113  * `<amount>` amount of crypto to be transferred
114 
115 
116 
117 Let's query current balance of Alice's account.
118 
119 ```shell script
120 python3 balance.py localhost:9933 5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY
121 # Current free balance: 10000.0
122 ```
123 
124 Let's do the same for the Bob's account.
125 ```shell script
126 python3 balance.py localhost:9933 5FHneW46xGXgs5mUiveU4sbTyGBzmstUspZC92UhjJM694ty
127 # Current free balance: 10000.0
128 ```
129 
130 #### Send extrinsic
131 
132 We can generate extrinsic using the following command:
133 
134 This command will create extrinsic that transfers 1 from Alice to Bob's account (Alice's account is defined by secret seed and Bob's account by account id).
135 
136 To send extrinsic use `transfer.py` script as follows:
137 ```shell script
138 python3 transfer.py localhost:9933 0xe5be9a5092b81bca64be81d212e7f2f9eba183bb7a90954f7b76361f6edb5c0a 5FHneW46xGXgs5mUiveU4sbTyGBzmstUspZC92UhjJM694ty 1
139 Extrinsic '0x315060176633a3e20656bd15c6eceff63b9f8bdc45595dc8ad52a02ae38d1708' sent
140 ```
141 
142 #### Query again the balances
143 
144 Now let's check that extrinsic was actually applied:
145 
146 Get the balance of Bob's account:
147 
148 ```shell script
149 python3 balance.py localhost:9933 5FHneW46xGXgs5mUiveU4sbTyGBzmstUspZC92UhjJM694ty
150 # Current free balance: 10001.0
151 ```
152 We can see that Bob's balance was increased by 1 as it was set on the subkey command
153 
154 Now let's check Alice's account:
155 ```shell script
156 python3 balance.py localhost:9933 5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY
157 Current free balance: 9998.999829217584
158 ```
159 
160 We can see that Alice's account was decreased by more than 1. This is caused by the commission paid for transfer
161 
162 ### Conclusion
163 
164 Now you know how to set up single peer kagome network and execute transactions on it