Skip to content
This repository has been archived by the owner on Dec 4, 2023. It is now read-only.

settlemint-archive/buidl-asset-tokenisation

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

hyperledger-besu-asset-tokenization

Context

Hyperledger Besu Asset Tokenization powered by SettleMint


Getting Started

  1. Register your interest here or Create an account on SettleMint here
  2. Create an Organisation (e.g. Your_Name_Organisation)
  3. Create an Application (e.g. Your_Name_Application)
  4. Click on Blockchain networks and add a Hyperledger Besu network and a node (e.g. Your_Name_Network, Your_Name_Node). Note: Choose the shared and small for the deployment plan
  5. Click on Storage and add a IPFS (decentralised) storage. Note: Choose the shared and small for the deployment plan
  6. Click on Integration Tools and add a Integration Studio tool. Note: Choose the shared and small for the deployment plan
  7. Click on Insights and add a Blockscout insights template and choose your deployed besu node. Note: Choose the shared and small for the deployment plan
  8. Click on Private keys and add a Accessible EC DSA P256 key
  9. Click on Smart Contracts sets and add a Empty template (e.g. Your_Name_Asset_Tokenization). Note: Choose the shared and small for the deployment plan

Setting up and Deployment of your Smart Contract

  1. In the SettleMint BPass Platform, head over to Smart contract sets
  2. Click on your deployed smart contract set and go to the IDE tab and click view in fullscreen mode
  3. In the terminal of the Internal IDE, clone the repo
git clone https://github.com/settlemint/buidl-asset-tokenisation.git
  1. Copy the template AssetTokenization.sol found in ./Smart-Contracts in the cloned repo and paste it in the IDE's folder ./contracts. Make sure your file name is the same as the contract name, e.g. AssetTokenization.sol == contract AssetTokezisation ...
  2. In the folder ./deploy, open the file named 00_deploy_example.ts and in line 13, change the name of the contract depending on your file name
  await deploy('AssetTokenization', {
    from: deployer,
    args: [],
    log: true,
  });
  1. Deploy your Asset Tokenization smart contract!
pnpm run smartcontract:deploy:reset
  1. You may create a notes.txt file or open up your (notes/stickies/word) to note down your deployed smart contract address

  2. Open the abi folder, go to AssetTokenization.json and copy the json contents

  3. Note down your json contents (txt/notes/stickies)

Set up your SettleMint API key

  1. In the SettleMint BPass Platform, click on your profile icon at the top right at click on API keys
  2. Check all the boxes and generate your API key
  3. Note down your API key (txt/notes/stickies)

Upload your Image to IPFS

  1. In the SettleMint BPass Platform, head over to Storage and click into your deployed IPFS (decentralised) storage
  2. Click on the File Manager tab and click on the Import button and choose File
  3. Choose an image that represents your asset and upload your image
  4. Click on the ellipsis at the far right and click Set pinning to pin your image
  5. Click on the ellipsis at the far right again and click Share link to copy the link to your image
  6. Note down your image uri (txt/notes/stickies)

Note down your JSON-RPC endpoint

  1. In the SettleMint BPass Platform, click on Blockchain nodes, click on your deployed node and click on Connect
  2. Note down your JSON-RPC endpoint (txt/notes/stickies)

Note down your private Key

  1. In the SettleMint BPass Platform, click on Private keys
  2. Note down your Private Key and Address (txt/notes/stickies)

BUIDL session

  1. Now, you are ready to BUIDL!
  2. In the SettleMint BPass Platform, click on Integration tools and deploy an Integration Studio tool
  3. Click on your deployed Integration Studio, click on Interface and click view in fullscreen mode
  4. At the top right dropdown box, click on Import and import the flows.json found in the Integration-Studio directory here in a new flow
  5. Once imported, click on the Asset Tokenization tab and click Deploy at the top right

1. Initialise your global variables

  1. Double click on the Set Global Variables module
  2. Go to the On Message tab and input your noted down variables and click Done
    'privateKey': '0x...',
    'contract': '0x...',
    'bpassKey': 'bpaas-...',
    'rpcEndpoint': 'https://...',
    'abi': []
  1. Click on Deploy at the top right and click on the blue button next to the inject module, next to Set Global Variables module.
  2. You can view the output at the debug window on the right side by clicking on the bug icon.

2. Initialise your asset

  1. Double click on the inject module next to the Initialise Asset module
  2. Input your variables and click Done
msg.assetName = ''
msg.assetSymbol = ''
msg.assetUri = ''
  1. Click on Deploy at the top right and click on the blue button next to the inject module, next to Initialise Asset module.
  2. You can view the output at the debug window on the right side by clicking on the bug icon.

3. Get your maturity time

  1. Click on the blue button next to the inject module, next to the Current Time + 10 Minutes module
  2. You can view the output at the debug window on the right side by clicking on the bug icon. Take note of the end value. This will be used as the maturity time input for the next step.

4. Create your asset

  1. Double click on the inject module next to the Create Asset module
  2. Input your variables and click Done
msg.assetId = e.g. 1 
msg.maxSupply = e.g. 100 
msg.faceValue = e.g. 1000 
msg.maturityTime = <end value>

4. View your created asset

  1. Click on the blue button next to the inject module, next to the View Asset module
  2. You can view the output at the debug window on the right side by clicking on the bug icon.

5. Mint your created asset

  1. Double click on the inject module next to the Mint Asset module
  2. Input your variables and click Done
msg.assetId = e.g. 1 
msg.amounts = e.g. 10 
msg.recipient = e.g. recipient address 
  1. Click on Deploy at the top right and click on the blue button next to the inject module, next to Mint Asset module.
  2. You can view the output at the debug window on the right side by clicking on the bug icon.

6. View your minted asset balance

  1. Click on the blue button next to the inject module, next to the View Balance module
  2. You can view the output at the debug window on the right side by clicking on the bug icon.

Congratuations! You have minted your first asset on an Asset Tokenisaton Contract through SettleMint

We encourage you to continue building your project after this BUIDL session!


About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published