Native token

Now that you have your wallet set up, you will need some native DRK tokens in order to be able to perform transactions, since that token is used to pay the transaction fees. You can obtain DRK either by successfully mining a block that gets confirmed or by asking for some by the community on darkirc and/or your comrades. Don't forget to tell them to add the --half-split flag when they create the transfer transaction, so you get more than one coins to play with.

After you request some DRK and the other party submitted a transaction to the network, it should be in the consensus' mempool, waiting for inclusion in the next block(s). Depending on your network configuration, confirmation of the blocks could take some time. You'll have to wait for this to happen. If your drk subscription is running, then after some time your new balance should be in your wallet.

pablo-waiting0

You can check your wallet balance using drk:

drk> wallet balance

 Token ID                                     | Aliases | Balance
----------------------------------------------+---------+---------
 241vANigf1Cy3ytjM1KHXiVECxgxdK4yApddL8KcLssb | DRK     | 20

Creating tokens

On the DarkFi network, we're able to mint custom tokens with some supply. To do this, we need to generate a mint authority keypair, and derive a token ID from it. The tokens shown in the outputs are placeholders for the ones that will be generated from you. In rest of the guide, use the ones you generated by replacing the corresponding placeholder. We can simply create our own tokens by executing the following command:

drk> token generate-mint

Successfully imported mint authority for token ID: {TOKEN1}

This will generate a new token mint authority and will tell you what your new token ID is.

You can list your mint authorities with:

drk> token list

 Token ID | Aliases | Mint Authority          | Token Blind    | Frozen | Freeze Height
----------+---------+-------------------------+----------------+--------+---------------
 {TOKEN1} | -       | {TOKEN1_MINT_AUTHORITY} | {TOKEN1_BLIND} | false  | -

For this tutorial we will need two tokens so execute the command again to generate another one.

drk> token generate-mint

Successfully imported mint authority for token ID: {TOKEN2}

Verify you have two tokens by running:

drk> token list

 Token ID | Aliases | Mint Authority          | Token Blind    | Frozen | Freeze Height
----------+---------+-------------------------+----------------+--------+---------------
 {TOKEN1} | -       | {TOKEN1_MINT_AUTHORITY} | {TOKEN1_BLIND} | false  | -
 {TOKEN2} | -       | {TOKEN2_MINT_AUTHORITY} | {TOKEN2_BLIND} | false  | -

Aliases

To make our life easier, we can create token ID aliases, so when we are performing transactions with them, we can use that instead of the full token ID. Multiple aliases per token ID are supported.

The native token alias DRK should already exist, and we can use that to refer to the native token when executing transactions using it.

We can also list all our aliases using:

drk> alias show

 Alias | Token ID
-------+----------------------------------------------
 DRK   | 241vANigf1Cy3ytjM1KHXiVECxgxdK4yApddL8KcLssb

Note: these aliases are only local to your machine. When exchanging with other users, always verify that your aliases' token IDs match.

Now let's add the two token IDs generated earlier to our aliases:

drk> alias add ANON {TOKEN1}

Generating alias ANON for Token: {TOKEN1}
drk> alias add DAWN {TOKEN2}

Generating alias DAWN for Token: {TOKEN2}
drk> alias show

 Alias | Token ID
-------+---------------------------------------------
 ANON  | {TOKEN1}
 DAWN  | {TOKEN2}
 DRK   | 241vANigf1Cy3ytjM1KHXiVECxgxdK4yApddL8KcLss

Mint transaction

Now let's mint some tokens for ourselves. First grab your wallet address, and then create the token mint transaction, and finally - broadcast it:

drk> wallet address

{YOUR_ADDRESS}

By default the transaction will be printed in the terminal. Interactive mode supports UNIX style pipes and exporting/importing to/from files. We can either export a transaction to a file by appending > {tx_file_name}.tx, or broadcast it right away by appending | broadcast. We will broadcast all transactions in the guide, for simplicity.

drk> token mint ANON 42.69 {YOUR_ADDRESS} | broadcast

[mark_tx_spend] Processing transaction: e9ded45928f2e2dbcb4f8365653220a8e2346987dd8b75fe1ffdc401ce0362c2
[mark_tx_spend] Found Money contract in call 0
[mark_tx_spend] Found Money contract in call 1
[mark_tx_spend] Found Money contract in call 2
Broadcasting transaction...
Transaction ID: e9ded45928f2e2dbcb4f8365653220a8e2346987dd8b75fe1ffdc401ce0362c2
drk> token mint DAWN 20.0 {YOUR_ADDRESS} | broadcast

[mark_tx_spend] Processing transaction: e404241902ba0a8825cf199b3083bff81cd518ca30928ca1267d5e0008f32277
[mark_tx_spend] Found Money contract in call 0
[mark_tx_spend] Found Money contract in call 1
[mark_tx_spend] Found Money contract in call 2
Broadcasting transaction...
Transaction ID: e404241902ba0a8825cf199b3083bff81cd518ca30928ca1267d5e0008f32277

Now the transaction should be published to the network. When the transaction is confirmed, your wallet should have your new tokens listed when you run:

drk> wallet balance

 Token ID                                     | Aliases | Balance
----------------------------------------------+---------+-------------
 241vANigf1Cy3ytjM1KHXiVECxgxdK4yApddL8KcLssb | DRK     | 19.98451279
 {TOKEN1}                                     | ANON    | 42.69
 {TOKEN2}                                     | DAWN    | 20

Freeze transaction

We can lock a tokens supply dissallowing further mints by executing:

drk> token freeze DAWN | broadcast

[mark_tx_spend] Processing transaction: 138274448ac3af26f253e0a40d0964dc125b99b3c826ba321bcb989cabfb6df6
[mark_tx_spend] Found Money contract in call 0
[mark_tx_spend] Found Money contract in call 1
Broadcasting transaction...
Transaction ID: 138274448ac3af26f253e0a40d0964dc125b99b3c826ba321bcb989cabfb6df6

After the transaction has been confirmed, we will see the token freeze flag set to true, along with the block height it was frozen on:

drk> token list

 Token ID | Aliases | Mint Authority          | Token Blind    | Frozen | Freeze Height
----------+---------+-------------------------+----------------+--------+---------------
 {TOKEN1} | ANON    | {TOKEN1_MINT_AUTHORITY} | {TOKEN1_BLIND} | false  | -
 {TOKEN2} | DAWN    | {TOKEN2_MINT_AUTHORITY} | {TOKEN2_BLIND} | true   | 4