Sui
Mysten / SUI
Mysten (Sui) can be accessed with the following coin types:
Environment | Coin Type | Faucet |
---|---|---|
Sui Production | sui | |
Sui Testnet | tsui | https://docs.sui.io/guides/developer/getting-started/get-coins |
Overview
Mysten is a protocol created by former Meta employees. The native asset of the Mysten protocol is Sui. It is an object based protocol, almost UTXO like. We support MPC transactions on SUI.
Explorerhttps://suiexplorer.com/
Generating Wallets
To create an Sui wallet using BitGoJS:
1 2 3 4 5 6 7 8 9 10 11 12 13
bitgo .coin('tsui') .wallets() .generateWallet({ label: 'My Test Wallet', passphrase: 'secretpassphrase1a5df8380e0e30', multisigType: 'tss', enterprise: '234578765432' }) .then(function (wallet) { // print the new wallet console.dir(wallet); });
To create a Sui wallet using the platform API:
1 2 3 4 5 6 7 8 9
LABEL="My Test Wallet" PASSPHRASE="secretpassphrase1a5df8380e0e30" MULTISIG="tss" curl -X POST \ -H "Content-Type: application/json" \ -H "Authorization: Bearer $ACCESS_TOKEN" \ -d "{ \"label\": \"$LABEL\", \"passphrase\": \"$PASSPHRASE\", \"multisigType\": \"$MULTISIG\" }" \ http://$BITGO_EXPRESS_HOST:3080/api/v2/tsui/wallet/generate
Staking
For Mysten there is a minimum requirement to stake 1 SUI. After initiating the staking request, there's a warmup period of 1 epoch, and a cooldown period of 1 epoch when you decide to unstake. When deciding to unstake, you must unstake the entire SUI object.
Rewards are automatically compounded.
Receive addresses
SUI has no minimum balance for receive addresses.
In order to create a receive address:
1 2 3 4 5 6 7 8 9 10 11
bitgo .coin('tsui') .wallets() .getWallet({ id: '585c51a5df8380e0e3082e46' }) .then(function (wallet) { return wallet.createAddress(); }) .then(function (newAddress) { // print new address details console.dir(newAddress); });
1 2 3 4 5
WALLET=585c51a5df8380e0e3082e46 curl -X POST \ -H "Authorization: Bearer $ACCESS_TOKEN" \ https://app.bitgo-test.com/api/v2/tsui/wallet/$WALLET/address
Transactions
SUI uses overall object modeling, which is similar to the UTXO model. With SUI, storage is centered around objects. Transactions take objects as input and output new or mutated objects.
You can make use of sendMany()
to send transactions. It's also important to note that while SUI does support batch transactions, these cannot be run sequentially. For the batch transactions, you'll need to wait for each to be confirmed on chain before submitting another. If you want to run a series of transactions, it's better to use sendMany
.
When sending SUI, you'll need to account for the fact that the base unit of SUI has 9 decimal places (1 SUI = 1000000000 MYST).
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
const recipients = [{ address: 'sui-address-1', amount: '10000000000', }, { address: 'sui-address-2', amount: '200000000000', }]; bitgo.authenticateWithAccessToken({ accessToken }); bitgo.unlock({otp: '000000'}) const wallet = await bitgo.coin(coin).wallets().getWallet({ id: walletId }); const response = await wallet.sendMany({ recipients, passphrase, type: 'transfer' });
Gas fees
A SUI transaction must pay a gas fee. SUI's Gas Pricing Mechanism ensures that any transaction pays fees according to both computational and storage costs.
A gas budget must be submitted with a SUI transaction. Gas budgets provide a limit to the amount of gas fees a user will pay. For more, see Gas in Sui.
Estimate Gas Fees in Sui
The gas fee is variable and differs from transaction to transaction. There's no way to get a precise fee estimate before a transaction. The fee estimate is composed of 3 components: computation cost, storage cost, and storage rebate. While the computation cost remains relatively constant, the storage cost and storage rebate can vary significantly.
Sui also has a concept of negative gas fees. If you overpay for a transaction, the excess gas fees are returned to you. This system promotes users to optimize storage usage on the blockchain, promoting cost efficiency and contributing to the efficient operation of the Sui network. However, this also makes predicting transaction fees more challenging.
Pre-build a transaction and generate an unsigned hex that you can use to obtain a fee estimate by running this script. This script, when run, will log a transaction hex. You can then pass this value to BitGo's API to receive a fee estimate.
Running the script
First, run yarn install
from the root directory of the repository.
Then change into the examples/ts/sui
directory and use npx ts-node
to run it:
1 2
cd examples/ts/sui/ npx ts-node get-transaction-hex.ts
Note
- Ensure your wallet ID and passphrase are correct.
- Replace placeholder values with actual data from your BitGo account.
Expected Output
The output should be as follows:
1 2
Required tx param: AAACAAgQJwAAAAAAAAAgWi8a831WVBkJYTbreVK3NAIGZI%2BhQCuftQI4dx1DSicCAgABAQAAAQECAAABAQDojrUgsPIyDtSTV6rS54xejLr67f2B%2B%2F159oq6evGnEwHu2GGYi3WJarkc27zGeL7%2FDmtIWy6IKEI5Uy6sGolMV1LgwAAAAAAAII2Sh%2FcsCB2AGmMSpi%2Bu65igNCuTAeYQ1ionZjpcAkBv6I61ILDyMg7Uk1eq0ueMXoy6%2Bu39gfv9efaKunrxpxPoAwAAAAAAAKSIIQAAAAAAAA%3D%3D
Copy this value and use it as a parameter in this URL:
1
https://app.bitgo-test.com/api/v2/tsui/tx/fee?tx=<tx-value>
The fee estimate result should look like this:
1 2 3 4 5 6
{ "feeEstimate": "3954120", "computationCost": "1000000", "storageCost": "1976000", "storageRebate": "978120" }