Skip to content

Latest commit

 

History

History
257 lines (160 loc) · 17 KB

web-ui-application.md

File metadata and controls

257 lines (160 loc) · 17 KB

Web UI Application

The Stablecoin Studio Web User Interface (Web UI) is designed to provide a more intuitive and user-friendly experience for managing stablecoins. Developed using React, this interface offers a visual representation of all our Web UI capabilities, from initial setup to advanced administration. Whether you're a newcomer looking for an easier entry point or a seasoned developer seeking a more efficient way to manage stablecoins, this documentation offers the insights and resources to harness the full power of our React-based Web UI.


Table of Contents

  1. Interactive Demo
  2. Prerequisites
  3. Installation
  4. Start Web UI
  5. Create Stablecoins
  6. Operate Stablecoins
  7. Manage Roles
  8. Stablecoin Details
  9. Additional Resources

Interactive Demo

Get firsthand experience with Stablecoin Studio's capabilities using the open-source, React-based demo application sandbox. The sandbox application is built using Stablecoin Studio's TypeScript SDK.

After setting up a Hedera testnet account, explore creating and managing stablecoins on Hedera through the interactive demo and follow along. Let's get started and explore the three paths for launching the Stablecoin Studio web application:

  1. Code Sandbox
For a quick and effortless start, you can use the pre-configured Code Sandbox environment directly from StablecoinStudio.com. This approach requires no setup and provides a fully functional demo application.stablecoin-code-sandbox-icon.pnghttps://www.stablecoinstudio.com
  1. GitPod Instance
Another easy way to get started is by launching a GitPod instance, which automates the initial setup and lets you dive into the application immediately. You can skip the prerequisites and installation steps.stablecoin-gitpod-icon.pnghttps://gitpod.io/#https://github.com/hashgraph/stablecoin-studio
  1. Local Environment
A more technical method to build and install on your local machine. This guide focuses on this method, walking you through the steps needed to set up your local environment. Start from the first step: Prerequisites.stablecoin-local-environment-Icon.png#prerequisites

Prerequisites


Install Stablecoin Studio

Open a new terminal and navigate to your preferred directory location where you want your Stablecoin Studio project to live. Clone the repo, cd in to the cloned directory, and install dependencies:

{% code fullWidth="false" %}

git clone https://github.com/hashgraph/stablecoin-studio.git
cd stablecoin-studio
npm install

{% endcode %}

cd in to the web directory:

cd web

Environment variables

Before we can start the web application, we need to configure the environment variables. From the root of the web project workspace, rename the .env.sample file to .env and configure the variables required to run the application. For the purposes of this demo, we will need:

  1. The factory contract ID.
  2. The REST API testnet endpoint.
  3. The JSON-RPC relay testnet endpoint.

The .env file contains the following parameters:

Environment VariableDescription
REACT_APP_LOG_LEVELLog level for the application. The default value is ERROR. Acceptable values are ERROR, WARN, INFO, HTTP, VERBOSE, DEBUG, and SILLY in order of priority (highest to lowest).
REACT_APP_FACTORIESJSON array with a factory contract ID in Hedera format 0.0.XXXXX per environment.
REACT_APP_MIRROR_NODEThe var must be a unique mirror node service for Hedera network, and this is the service that would be used when the UI starts. If the service doesn't require an API key to authorize requests the API_KEY and HEADER properties must remain empty. Here is a list of mirror node endpoints.
REACT_APP_RPC_NODEThe var must be a unique RPC node service for Hedera network, and this is the service that would be used when the UI starts. If the service doesn't require an API key to authorize requests the API_KEY and HEADER properties must remain empty. Here is a list of RPC providers.
GENERATE_SOURCEMAPThis is a proprietary Create React App configuration. You can read more information in its Create React App documentation.
Example configured .env file ✅

{% code title=".env" overflow="wrap" fullWidth="false" %}

REACT_APP_LOG_LEVEL=ERROR
REACT_APP_FACTORIES='[{"Environment":"testnet","STABLE_COIN_FACTORY_ADDRESS":"0.0.467235"}]'
REACT_APP_MIRROR_NODE='[{"Environment":"testnet","BASE_URL":"https://testnet.mirrornode.hedera.com/api/v1/", "API_KEY": "", "HEADER": ""}]'
REACT_APP_RPC_NODE='[{"Environment":"testnet","BASE_URL":"https://testnet.hashio.io/api", "API_KEY": "", "HEADER": ""}]'
GENERATE_SOURCEMAP=false

{% endcode %}


Start the Web UI

Once you have configured your environment variables, start the web UI from the web directory:

npm run start

If the application is successfully run, the web application interface will open in a new browser:

http://localhost:3000/

Click "Connect your wallet" and select the wallet (HashPack or MetaMask) and network you want to interact with. For the purposes of this demo, we will use HashPack and select Testnet.

Now that your project is set up and the web application is running let's create our first stablecoin!


Create Stablecoins

Basic details (Required)

To initiate the creation of your stablecoin, head to the top of the interface and click on the symbol. From the options that appear, select "Create coin." The required fields for basic details will be displayed:

  • HederaTokenManager impl.: By default, this is set to a factory contract ID provided by Hedera, in the format 0.0.XXXXXX. Advanced users have the option to deploy their own factory contract implementation.
  • Name: This is where you name your new stablecoin, for example, "NewStableCoin."
  • Symbol: Enter a symbol to represent your stablecoin, like "$NSC."

Optional details

While the basic details are mandatory, you also have an option to further specify:

  • Initial Supply: You can expand on the initial number of tokens that will be minted.
  • Max Supply: If you chose 'Finite' in the 'Supply Type,' you might want to set an upper limit.
  • Decimals: You can set additional decimal places if you need more precision.

Manage permissions

When creating a stablecoin, you have multiple key configuration options. One of those is the “Underlying Token’s Keys Definition.” This determines which accounts control various operations of the stablecoin, such as who can approve KYC checks or which account can change the coin supply. You have the flexibility to set these keys to be controlled by the stablecoin’s initial smart contract, assign them to a different key, or even leave them undefined.

If the KYC key is tied to the smart contract and the supply key isn't tied to the account that creates the stablecoin, you can opt to automatically grant KYC verification to the account creating the stablecoin at the time of its creation.

As for ownership settings, by default, the account that initiates the stablecoin creation also becomes the stablecoin proxy admin owner. However, you’re not locked into this default setup. You can alter this by specifying a different account ID during creation. This could be any account, including specialized accounts like a timelock controller for scheduled operations or a cold wallet for enhanced security.

Proof-of-reserve (PoR)

Choose if the stablecoin will be linked to a Proof of Reserve (PoR) contract. You can either use an existing PoR contract address or create a new one using the demo implementation included in the project and setting an initial reserve amount.

{% hint style="warning" %} Warning: You can change the PoR contract address at any time, but exercise caution. Altering the address can affect your stablecoin's cash-in functionality, as it refers to a new reserve verification contract. In cases where the new contract has a lower reserve than the previous one, minting new tokens may become restricted. {% endhint %}

For those using the project's demo PoR contract, you also have the option to modify its reserve amount. This can be done via the PoR admin account used during the stablecoin's deployment. Because the reserve can be changed arbitrarily in the demo, it's intended for demonstration purposes only.

Review

Final validation before creating the stablecoin. Review the stablecoin details and click the "Create stablecoin" button. Validate "Execute Smart Contract" and "Associate Token" transactions in your wallet. Once the stablecoin is created, it will be added to the drop-down list of coins you can access (with the account you used to create the stablecoin).


Operate Stablecoins

To operate your stablecoin, connect your wallet to the platform. After successful authentication, select the stablecoin you wish to interact with from the drop-down list of available coins. Once the stablecoin information is loaded, navigate to the "Operations" tab.

You'll see a variety of actions and your accessible operations will be tied to the roles assigned to your account for the chosen stablecoin. Here's a quick rundown of what each operation allows:

  • Cash In: Deposit assets into your stablecoin account.
  • Burn: Permanently remove specific tokens from circulation.
  • Get Balance: View the current balance of your stablecoin account.
  • Rescue: Recover tokens in unique scenarios.
  • Rescue HBAR: Specialized recovery for HBAR.
  • Wipe: Clear particular stablecoin balances.
  • Freeze Account: Temporarily disable transaction capabilities for an account.
  • Unfreeze: Lift the freeze status from an account.
  • Check Account Frozen Status: Verify whether an account is frozen.
  • Grant KYC: Approve an account for KYC verification.
  • Revoke KYC: Remove previously granted KYC approval.
  • Check KYC: Confirm the KYC status of an account.
  • Danger Zone: Access to operations that carry higher risk, generally because they affect every token owner (PAUSE) or can not be rolled back (DELETE).

To carry out an operation, simply click on the corresponding button and follow the on-screen prompts. The platform will automatically perform the operation based on the capabilities your account has been assigned.

The "Operations" tab in Stablecoin Studio is your hub for managing every aspect of your stablecoin, so make sure you're familiar with the roles and capabilities assigned to your account to leverage the suite of operations available to you fully.


Manage Roles

In Stablecoin Studio, role management is a pivotal feature that gives you control over various functions related to your stablecoin. If your account has been designated with the "Admin Role," you unlock the capability to manage other roles for your stablecoin, making governance easier and more secure.

Roles you can manage include:

  • Cash In: Permits an account to deposit or 'cash in' assets.
  • Burn: Authorizes an account to remove tokens from circulation permanently.
  • Wipe: Allows an account to clear specific balances.
  • Rescue: Grants the ability to recover tokens in special circumstances.
  • Pause: Enables stopping all transactions temporarily, which is useful in emergency situations.
  • Freeze: Authorizes freezing specific accounts, disabling their ability to transact.
  • Delete: Allows the removal of accounts or certain data, irreversible.
  • Admin Role: Provides overarching administrative privileges, often reserved for key governance participants.

Connect your wallet and select the stablecoin from the drop-down list you want to interact with. Once the stablecoin information loads, head to the "Role management" tab.


Stablecoin Details

This menu option displays stablecoin details and allows the user to update some token properties, like the name, symbol, and keys. Clicking on the pencil icon located at the top right side of the screen turns the information page into a form where these properties can be modified by the user.

🎉 Congrats on creating your first stablecoin with Stablecoin Studio! View the transaction details on HashScan by looking up your new token ID or clicking the HashScan Explorer link from the "Token ID" field.

HashScan Explorer link

HashScan


Additional Resources

{% embed url="https://portal.hedera.com/" %} Hedera Developer Portal (Testnet Accounts) {% endembed %}

{% embed url="https://docs.hedera.com/hedera/support-and-community/glossary" %} Hedera and Web3 Glossary {% endembed %}

{% embed url="https://www.hashpack.app/download" %} Hedera Non-Custodial Wallet {% endembed %}

{% embed url="https://hashscan.io" %} Hedera Network Explorer {% endembed %}

{% embed url="https://www.npmjs.com/package/@hashgraph/stablecoin-npm-sdk" %}