/factom-daml-integration

FAT Token DAML smart contract integration

Primary LanguageJavaApache License 2.0Apache-2.0

Mithra: DAML Library + Java App for DAML Integration

Mithra makes use of the DAML Ledger Java bindings in order to integrate the sending and receiving of FAT tokens within DAML contracts. This repo includes a set of automation bots that connect to the DAML Ledger, and a set of DAML contracts that provide templates for sending and receiving FAT Tokens. These templates can be used within, or as consequences of actions in any DAML contract.

Installation and Usage

Dependencies

  1. DAML SDK: to run Mithra, the DAML SDK must be installed on your system. Click here for the official installation instructions. This project uses DAML SDK 0.13.16. If you download the latest version, you can manually install 0.13.16 using the daml install command. Otherwise it should automatically download upon running daml build ....

  2. Maven: The Java app is a Maven project. You will also need to have that installed in order to download all dependencies and execute the various targets.

  3. Golang - Go is required in order to run the Factom dependencies.

  1. Java 8 - the Java app uses Java 8
  1. Factom Dependencies:
  • Factom Command Line Interface Programs - the Factom Command Line Interface Programs from the linked github contain the factomd and factom-walletd command line programs necessary for Mithra.
  • fatd - The Java app connects to fatd in order to submit transactions to the Factom blockchain. Installing fatd will also install the fat-cli for interacting with fatd. For this project, version for fatd/fat-cli is:
    $ fat-cli --version
    fat-cli:  v0.6.0.r0.g00ba028!
    fatd:     v0.6.0.r0.g00ba028!
    fatd API: 1
  • serveridentity - An application that creates and manages a Factom Server's identity. To install:
    git https://github.com/FactomProject/serveridentity.git $GOPATH/src/github.com/FactomProject/serveridentity
    cd $GOPATH/src/github.com/FactomProject/serveridentity
    glide install
    go install

Creating a new FAT-0 Token

The scripts included in the fat-utils repository https://github.com/Sphereon-Opensource/fat-utils. Walk through the process of creating and initializing a new token using the FAT daemon. Please run the scripts within the ./fat-token-issuance directory in the fat-ultils repository, as the scripts depend on each other.

git clone https://github.com/Sphereon/fat-utils
cd ./fat-token-issuance/

If any scripts won't run, you may need to make the script executable using:

chmod +x <name-of-script>.sh

or you can run them using bash

bash <name-of-script>.sh

These scripts, and Mithra in general, are not intended to be used in production as secret keys are not handled with adequate security. Therefore, it is highly recommended that these scripts be run with a local Factom net. To configure this, change the following variables in your ~/.factom/m2/factomd.conf

DirectoryBlockInSeconds   = 3
...
Network                   = LOCAL
...
NodeMode                  = SERVER

Once you have factomd, factom-walletd, and fatd installed and configured on your system, you can start all of them using

./start-factomd-factomwalletd-fatd.sh /path/to/fatd/directory

The first time you run this script, it will create a new Entry Credit address on the local testnet, fund it with ECs, and save it to entry_credit_address.sh in order for it to be used in the other scripts. Later when you run this script, it will look in this file and fund transactions on fatd using this address.

Once you have fatd, factomd, and factom-walletd running, you can run the issue-tokens.sh script, which will go through the process of creating a new FAT-0 token using fatd.

./issue-tokens.sh /path/to/fatd/directory TOKEN_ID TOKEN_SYMBOL SUPPLY

The TOKEN_ID is the name of the token you want to create, the TOKEN_SYMBOL is a 1-4 letter code for identifying the token (for example, the token symbol for Factoids is FCT), and SUPPLY is the maximum amount of tokens that can be created. For an unlimited supply, you can use -1.

This script will also create a new Factom server identity using the create-server-identity.sh script, and store the output in a new directory /serveridentity. This may take some time as the script will need to wait to ensure that the identity has been registered.

In order to test sending and recieving FAT Tokens using Mithra, the important things to keep from the output of this script are:

  • Newly created Factoid addresses and secret keys, eg:
    ------------------Factoid addresses------------------
    Newly created factoid address 1: FA3DAmmhsBDu5mkqN6TXwtToKnsi7EZrpqfzqehtuX3PiRoRZxSn
                                 sk: Fs2vWgAfoyNPf6miER8pCNiV5bMuTrikucF2u5v8JXQjyUrfJv9K
    Newly created factoid address 2: FA2pBZTFXUaKRza5J9927jygi9exZaZawUF4BSuVWPG3ozGmM9ae
                                 sk: Fs1xjess2sj82zNZt45sCKVTxoPbmzb3QCPzHFsVeT7wy3L1JKSR
  • tokenChainId which is printed at the end of the script execution, and is also present in the <TOKEN_ID>.json file.

Once the script is finished, it will output a TOKEN_ID.json file, which will need to be placed in .../src/main/resources/tokens in order to be used by the Mithra application.

cp <TOKEN_ID>.json ../src/main/resources/tokens/

Factomd and fatd need to be running to use Mithra. When you are done using Mithra, to kill the factomd, fatd, and factom-walletd instances started with start-factomd-factomwalletd-fatd.sh, you can use:

./kill-factomd-factomwalletd-fatd.sh

If you want to clear all data on your local Factom testnet for debugging purposes or otherwise (this will also delete any FAT Tokens that have been locally initialized), you can use:

./remove-fat-state.sh 

Building Mithra

Mithra uses the DAML-codegen to generate the Java code from DAML files that is necessary for the application. Therefore the DAML contracts must be compiled before the Java code. From the Mithra directory run:

daml build -o target/daml/mithra.dar

Now you should be able to compile Mithra:

mvn compile

Running Mithra

1. Starting DAML and fatd

In order to run Mithra, the following needs to be running:

  • fatd
  • factomd
  • DAML Sandbox
  • DAML Navigator

For running fatd, and factomd, we can run the same script as earlier, start-factomd-factomwalletd-fatd.sh, found in /token-init. To run the DAML Sandbox use the following from the Mithra root directory:

daml sandbox target/daml/mithra.dar

And to run the DAML Navigator frontend:

daml navigator server
2. Configuring Mithra

Before running Mithra, make sure that the pom.xml is configured to access fatd and the DAML Ledger. The default values are listed below. In addition, if you want to send FAT Tokens from a Factoid address, Mithra needs to use a secret key to sign transactions. For now, this is in the pom.xml, but in later versions will be moved to a keyvault for security.

    <properties>
        ...
        <ledgerHost>localhost</ledgerHost>
        <ledgerPort>6865</ledgerPort>
        <operatorParty>Alice</operatorParty>
        <clientParty>Bob</clientParty>
        <fatdEndpoint>http://localhost:8078</fatdEndpoint>
        <secretAddress>insert-secret-address-here</secretAddress>
        ...
    </properties>

The secret key in insert-secret-address-here can be taken from the Factoid addresses created from the issue-tokens.sh script, and should be the associated private address of the Factoid public address you want to send FAT Tokens from.

3. Starting the App

Mithra is a Spring Boot application with two different profile options. The operator profile models an admin user that can invite users to be able to send FAT Tokens using the Onboarding contracts. Once a user is onboarded, they can create TransferRequest contracts which are then processed by the operator app and sent to fatd once signed. By default in this example, Bob is designated as a client and Alice as an operator. More about how to use the roles is described in the next section. To run the app as operator use the following command:

mvn spring-boot:run -Dspring.profiles.active=operator

Running the app as client allows for the signing of transactions using the secret address provided in the pom.xml. To run the app as client use the following:

mvn spring-boot:run -Dspring.profiles.active=client

Note that in order to send transactions using DAML contracts, both the client and operator apps must be running.

Using Mithra

Once you have built Mithra and are running both the client and operator apps, you can open the DAML Navigator to interact with contracts as either Bob or Alice. The Navigator by default is running on http://localhost:4000 In the example model, Alice is the operator and must invite Bob to be a User before he can initiate transactions.

To Onboard Bob
  1. Under the dropdown at http://localhost:4000, choose Alice
  2. Under the "Templates" tab select the contract starting with "FAT.Onboarding:UserInvitation@"
  3. In the template, type "Alice" as the operator and "Bob" as the user and press submit.
  4. If the contract creation was successful, a check mark will briefly appear in the top right, and the contract will now be visible under the "Contracts" tab.
To Send a Transaction
  1. Before Bob can send a transaction, he must accept the UserInvitation. Change users to Bob by clicking the user icon on the top left.
  2. Under the "Contracts" tab, click on the "FAT.Onboarding:UserInvitation@" contract.
  3. On the top bar, next to the contract number, chose "UserInvitation_Accept" and press submit
  4. If this is successful there should be a contract "FAT.Onboarding:User@" available under the "Contracts" tab. By clicking on this contract, the "User_Send_FAT_Token" option will be available at the top bar.
  5. Selecting the "User_Send_FAT_Token" option will prompt for the fields: "to", "from", "value", and "tokenId". By filling in these fields and pressing Submit, the transaction will be sent by the bots.
    • from - Factoid address matching secret address for client bot (from pom.xml)
    • to - Factoid address to send to
    • value - Amount of FAT Tokens to send
    • tokenId - The name of the FAT Token to send
  6. Sent transactions will be present under the "FAT Token Transfers" tab.
Checking Balances

In order to check balances of FAT Tokens, you can either use FAT Wallet or the following command in the fat-cli

fat-cli get balance <ADDRESS>

For more information on how to use fat-cli see the FAT-CLI documentation.

Example Contract

An overview for an example contract using FAT token integration can be accesses here.