This manual assumes basic knowledge with Ethereum blockchain and in particular knowledge with how to make a contract call for an Ethereum smart contract.
Before starting to interact with the WBTC system, the merchant should be aware of two important smart contract addresses, namely the WBTC token and the Factory contracts. These addresses can be found here. All the function calls we describe in this guide are done to the factory smart contract (with the exception of the WBTC allowance call, which is sent to the WBTC Token contract)
The first step a merchant should do after they are approved by the DAO is to set up their BTC deposit address. When the merchant burns WBTC, the custodian will send BTC to this deposit address. The merchant sets up this address by calling:
setMerchantBtcDepositAddress(string btcDepositAddress)
The merchant can read the address they set by calling
merchantBtcDepositAddress(address merchant)
Minting is done by sending BTC to the custodian deposit address and by submitting a minting request.
The merchant can read the custodian deposit address by calling
custodianBtcDepositAddress(address merchant)
It should be noted that this address is unique per merchant and merchant should only send their BTC to this address.
The custodian will take fees from the mint operation. The exact fee percentage is determined by an off-chain agreement with the custodian.
The amount of WBTC that is expected to be minted after sending X
BTC to the custodian deposit address is
(X * (100 - fee))/100
Where fee
is percent unit. E.g., 0.2% is denoted by fee = 0.2
.
The merchant should send X
that corresponds to the amount of WBTC they wish to mint.
After sending BTC to the custodian deposit address the merchant submits an on-chain minting request by calling:
function addMintRequest(
uint amount,
string btcTxid,
string btcDepositAddress
)
Where:
amount
is the amount of WBTC token to mint in Satoshi units. i.e.,100000000
(1e8
) denotes 1 WBTC. IfX
BTC Satoshi were sent, thenamount
should be set to(X * (100 - fee))/100
.btcTxid
the txhash of the BTC transfer to the custodian address. The hash should not contain the0x
prefix.btcDepositAddress
the destination address of the BTC transfer. It must be equal to the custodian deposit address.
The mint is completed after the custodian on-chain approves the request, and the minted WBTC tokens are sent to the merchant's ethereum address.
Prior to the confirmation of the custodian the merchant is entitled to cancel their mint request.
This should happen, e.g., if the merchant realizes that the input parameters given to addMintRequest
were wrong.
It should be noted that the cancellation does not revert the BTC transfer, and it should be sent back by the custodian.
Burning WBTC is done by giving WBTC allowance to the factory contract and submitting a burn request on-chain. It should be noted that in order to burn WBTC, the merchant must hold them in the merchant Ethereum account.
WBTC is a standard ERC20 token and as such the factory contract can accept it from an address only if the merchant approved it. This is done by calling
approve(address _spender, uint256 _value)
function in the WBTC contract where
_spender
should be set to the Factory contract address._value
should be set to the amount of WBTC the merchant wish to burn (in Satoshi). This is the only transaction in this document that is sent to the WBTC Token contract address. The rest are sent to the Factory contract address.
Done by calling
burn(uint amount)
where the amount is in Satoshi.
When calling this function the merchant WBTC will be burned, and the custodian will later send equivalent amount of BTC (minus applicable fees) to the merchant BTC deposit address (that was set in the initial setup).
DO NOT call burn
in WBTC token contract, you will lose your wbtc forever