Welcome to the sBTC developer documentation.
Here you will find the most up-to-date description of what sBTC is, how it's implemented and how you can get involved.
For deep technical dive into the sBTC system in its entirety, we recommend reading the proposed SIP as well.
To understand sBTC, we first need to understand the current limitations of Bitcoin (BTC).
Bitcoin is to date the most secure and decentralized blockchain. While Bitcoin is the largest cryptocurrency by market cap, comparatively few applications exist within the Bitcoin ecosystem. Developers interested in building applications for the Bitcoin community often find it difficult or impossible to implement their logic directly on the Bitcoin chain. Although Bitcoin has a simple scripting system built in, it lacks the expressiveness of many other smart contract languages.
sBTC is for:
- Bitcoin holders who want to participate in smart contracts.
- Developers who want to build applications on Bitcoin.
sBTC empowers developers to build applications on Bitcoin by bridging Bitcoin and Stacks. We achieve this by introducing a fungible token (sBTC) on the Stacks blockchain. The token has the following properties:
- 1:1 redeemability. sBTC can always be exchanged 1:1 for BTC on the Bitcoin chain, as long as the Stacks blockchain is operational.
- Open membership. Anyone can participate in the sBTC protocol. No centralized entity maintains custody over any BTC in the protocol.
Other tokens which try to achieve the same end as sBTC are
While these tokens all achieve the same value as BTC, they maintain BTC reserves through trusted entities. sBTC is the only truly decentralized Bitcoin backed asset on Stacks.
Bitcoin holders can do two things to interact with sBTC, deposit and withdraw. Both of these operations are controlled through special Bitcoin transactions.
To deposit BTC into sBTC, a Bitcoin holder would create a deposit transaction on the Bitcoin chain. This deposit transaction informs the protocol how much BTC the holder has deposited, and to which Stacks address the holder wishes to receive the sBTC. The sBTC system responds to the deposit transaction by minting sBTC to the given Stacks address.
To withdraw BTC, a Bitcoin holder creates a withdrawal transaction on the Bitcoin chain. This withdrawal transaction informs the protocol how much sBTC the holder wishes to withdraw, from which stacks address the sBTC should be withdrawn and which Bitcoin address should receive the withdrawn BTC. In response to this transaction, the sBTC system burns the requested amount of sBTC from the given Stacks address and fulfills the withdrawal by issuing a BTC payment to the given BTC address with the same amount.
The following diagram illustrates the deposit and withdrawal flows.
sequenceDiagram
Actor Bitcoin holder
participant Bitcoin
Actor sBTC Protocol
participant Stacks
Bitcoin holder ->> Bitcoin: Deposit transaction
Bitcoin -->> sBTC Protocol: Read sBTC operations
sBTC Protocol ->> Stacks: Mint sBTC
Bitcoin holder ->> Bitcoin: Withdrawal transaction
Bitcoin -->> sBTC Protocol: Read sBTC operations
sBTC Protocol ->> Stacks: Burn sBTC
sBTC Protocol ->> Bitcoin: Fulfill withdrawal
If you want to use sBTC as user, check out How to Deposit and Withdraw.
If you're a developer looking to build applications with sBTC, check out the Quickstart.
If you want to dive into the details and understand how sBTC achieves a secure open-membership wrapping of Bitcoin, look into the design documentation. A good start is the Architecture Overview