Phase-2 of the Babylon mainnet will launch a Babylon PoS blockchain as the first Bitcoin Secured Network (BSN). This will be accompanied by the registration of the stakes created during Phase-1 to the Babylon blockchain allowing them to provide finality service for the it and earn PoS rewards for the service.
Scope
If you are integrating tokens, are you allowing only whitelisted tokens to work with the codebase or any complying with the standard? Are they assumed to have certain properties, e.g. be non-reentrant? Are there any types of weird tokens you want to integrate?
The Babylon Phase-2 network will involve two tokens:
Babylon token: A Cosmos SDK token serving as the native token of the Babylon chain. Only the Babylon token can be used for governance and for gas payments.
Bitcoin: Used for Bitcoin staking. It is not bridged or transferred to Babylon. Instead it remains on the Bitcoin ledger and the Babylon blockchain learns about it through associated proofs. Action on the Babylon ledger can lead to the Bitcoin's spending on the Bitcoin blockchain.
Are there any limitations on values set by admins (or other roles) in the codebase, including restrictions on array lengths?
The Babylon x/btclightclient
module parameters specify a list of Babylon addresses that are the only ones that can submit Bitcoin headers to the Babylon on-chain Bitcoin light client. If the list is empty, then anyone can submit Bitcoin headers. This parameter is specified for when the Babylon network interacts with the Bitcoin Signet network which has reduced work requirements due to only certain entities being able to produce blocks and therefore a trusted Bitcoin headers reported is required. For the mainnet, this is not the case and the list of allow-listed reporters is expected to be empty so that anyone can act as a reporter.
All APIs, including for transaction submission and querying have public access. There are no Admin or other privileged roles within Babylon.
Bitcoin staking transactions on the Bitcoin ledger should adhere to the parameters specified in the x/btcstaking
module. These are Bitcoin-height versioned parameters that even include Bitcoin heights prior to the Babylon chain launch in order to accommodate staking transactions created during phase-1 (which followed versioned parameters in a JSON file, e.g. for the phase-1 mainnet the ones here https://github.com/babylonlabs-io/networks/tree/main/bbn-1/parameters)
Are there any limitations on values set by admins (or other roles) in protocols you integrate with, including restrictions on array lengths?
No
Are there any off-chain mechanisms involved in the protocol (e.g., keeper bots, arbitrage bots, etc.)? We assume these mechanisms will not misbehave, delay, or go offline unless otherwise specified.
These components are off-chain but in scope and we should cover the cases in which they misbehave.
Listing the major off-chain components and the Github repositories for which their documentation can be found:
There are also web service components that index blockchain data in order to serve a Bitcoin staking web application.
What properties/invariants do you want to hold even if breaking them has a low/unknown impact?
We want to ensure staked bitcoins cannot be spent outside one of these authorized operations
Please discuss any design choices you made.
n/a
Please provide links to previous audits (if any).
Please list any relevant protocol resources.
Additional audit information.
Blockchain/DLT
High
Medium
Web
High
Medium
All the crypto primitive implementations
https://github.com/babylonlabs-io/babylon/blob/cd0bbcd98be5e4dda081f7330140cf9dbee4c94d/crypto
BTC staking script utilities
https://github.com/babylonlabs-io/babylon/blob/cd0bbcd98be5e4dda081f7330140cf9dbee4c94d/btcstaking
BTC timestamping tx utiilities
Inflation Control. This module is not battletested yet
https://github.com/babylonlabs-io/babylon/blob/b3da9cbaf0575d8e8f371d60d89be10e381dafc1/x/mint
Reward distribution. This module is not battletested
https://github.com/babylonlabs-io/babylon/blob/be9eb6b9f4db544eb35db8b4767852d12910b9eb/x/incentive
Updates our voting power table. High complexity and High Criticality.
Our staking handler. This is the most critical piece handling new delegations / unbonding etc.
https://github.com/babylonlabs-io/babylon/blob/v1.0.0-rc.3/x/btcstaking/keeper/msg_server.go
BTC light client module is the unsung hero module on Babylon. Timestamping and staking depends on it. If this is broken, everything is broken.
https://github.com/babylonlabs-io/babylon/tree/v1.0.0-rc.3/x/btclightclient .
Finality handler, everything related to finality originates from there so it is critical.
https://github.com/babylonlabs-io/babylon/blob/v1.0.0-rc.3/x/finality/keeper/msg_server.go .
Our timestamping integration with ABCI. High complexity (interaction with comet-bft ) and critical for our system
https://github.com/babylonlabs-io/babylon/blob/v1.0.0-rc.3/x/checkpointing/proposal.go and https://github.com/babylonlabs-io/babylon/blob/v1.0.0-rc.3/x/checkpointing/vote_ext.go
Total Rewards
Contest Pool
Lead Senior Watson
Lead Judge
300,000 USDC
50,000 USDC
25,000 USDC
Status
Scope
Start Time
End Time
Judging Rules