BRC-721 is inspired by the BRC-20, an experimental standard for creating fungible tokens on the Bitcoin network. BRC-20, which can be found at brc-20-experiment, aims to bring the functionality of issuing tokens to the Bitcoin ecosystem.
By building upon the ideas and principles of BRC-20, BRC-721 extends the capabilities of tokenization on the Bitcoin network to include non-fungible tokens, thus enabling a broader range of digital asset management and value representation.
BRC-721 is designed for non-fungible tokens (NFTs) on the Bitcoin network. It allows for the creation, ownership, and transfer of unique digital assets on the Bitcoin blockchain. Each token created under BRC-721 has a unique identifier, making them distinct and non-interchangeable.
Deploy NFT with an external base URI to provide metadata for each token:
{
"p": "brc-721",
"op": "deploy",
"tick": "ordinals",
"max": "10000",
"buri": "https://ipfs.io/abc/"
}
- For token ID 1, the metadata is located at
https://ipfs.io/abc/1
Deploy NFT with onchain metadata and make the collection immutable:
{
"p": "brc-721",
"op": "deploy",
"tick": "ordinals",
"max": "10000",
"meta": {
"name": "Ordinals",
"description": "Bring NFT to Bitcoin",
"image": "https://storage.googleapis.com/opensea-prod.appspot.com/puffs/3.png",
"attributes": [
{
"trait_type": "trait1",
"value": "value1"
}, ... ]
},
"upd": false
}
- All tokens of the collections will share the same metadata.
Key | Required? | Description |
---|---|---|
p | Yes | Protocol: Helps other systems identify and process brc-721 events |
op | Yes | Operation: Type of event (deploy, mint, update) |
tick | Yes | Ticker: identifier of the brc-721, more than 4 letters, case insensive |
max | Yes | Max supply: set max supply of the brc-721 |
upd | No | Whether the metadata is updatable, default is true |
buri | No | BaseURI URI for the brc-721, access {buri}{token_id} for the metadata of a token |
meta | No | The metadata of the collection |
- if
upd
istrue
, the deployer can update the metadata of the collection by sending anupdate
inscription; otherwise, the metadata is immutable, anyupdate
op will be invalid.
Deploy NFT with an external base URI to provide metadata for each token:
{
"p": "brc-721",
"op": "deploy",
"tick": "ordinals",
"max": "10000",
"buri": "https://ipfs.io/abc/"
}
- For token ID 1, the metadata is located at
https://ipfs.io/abc/1
Deploy NFT with onchain metadata and make the collection immutable:
{
"p": "brc-721",
"op": "deploy",
"tick": "ordinals",
"max": "10000",
"meta": {
"name": "Ordinals",
"description": "Bring NFT to Bitcoin",
"image": "https://storage.googleapis.com/opensea-prod.appspot.com/puffs/3.png",
"attributes": [
{
"trait_type": "trait1",
"value": "value1"
}, ... ]
},
"upd": false
}
- All tokens of the collections will share the same metadata.
Key | Required? | Description |
---|---|---|
p | Yes | Protocol: Helps other systems identify and process brc-721 events |
op | Yes | Operation: Type of event (deploy, mint, update) |
tick | Yes | Ticker: identifier of the brc-721, more than 4 letters, case insensive |
max | Yes | Max supply: set max supply of the brc-721 |
upd | No | Whether the metadata is updatable, default is true |
buri | No | BaseURI URI for the brc-721, access {buri}{token_id} for the metadata of a token |
meta | No | The metadata of the collection |
- if
upd
istrue
, the deployer can update the metadata of the collection by sending anupdate
inscription; otherwise, the metadata is immutable, anyupdate
op will be invalid.
{
"p": "brc-721",
"op": "mint",
"tick": "ordinals"
}
Key | Required? | Description |
---|---|---|
p | Yes | Protocol: Helps other systems identify and process brc-721 events |
op | Yes | Operation: Type of event (deploy, mint, update) |
tick | Yes | Ticker: identifier of the brc-721, 4 to 8 letters, case insensive |
- token ID is generated from 1 to
max
according to the order of inscription IDs.
It's simple to transfer an brc-721 token, just send the inscription minted above to the receiver. There is no need to mint a transfer inscription before sending like brc-20.
{
"p": "brc-721",
"op": "update",
"tick": "ordinals",
"upd": false,
"buri": "https://ipfs.io/abc/",
"meta": { ... }
}
Key | Required? | Description |
---|---|---|
p | Yes | Protocol: Helps other systems identify and process brc-721 events |
op | Yes | Operation: Type of event (deploy, mint, update) |
tick | Yes | Ticker: identifier of the brc-721, 4 to 8 letters, case insensive |
upd | No | Whether the metadata is updatable, default is true |
buri | No | BaseURI URI for the brc-721, access {buri}{token_id} for the metadata of a token |
meta | No | The metadata of the collection |
- This operation should be only allowed for the owner of the deploy inscription
- The
update
inscription must be minted to the same address as the deploy inscription. - Only
upd
,buri
andmeta
can be updated. - if
upd
istrue
, the deployer can update the metadata of the collection by sending an update inscription; otherwise, the metadata is immutable, anyupdate
op will be invalid after the inscription settingupd
tofalse
.
-
NFT Deployer
- The address holding the
deploy
inscription is the deployer - The receiving address of the first deploy inscription minting becomes the deployer
- If the deploy inscription is transferred to a new address, the new address becomes the deployer
- The address holding the
-
Token ID
- Similar to ERC721, each token in a BRC-721 collection has a unique ID
- Each
mint
operation's inscription generates a token with a token ID ranging from 1 tomax
(the total supply defined in the deploy inscription) in the order of inscription ID - Minting inscriptions beyond the total supply are invalid
mint
inscription ID should be larger than the deploy inscription ID
-
Token Owner
- The address holding the mint inscription is the owner of the token
- When the mint inscription is transferred to a new address, the owner changes to the new address
-
Transfer
- Transfer the NFT token using
ord wallet send <ADDRESS> <INSCRIPTION ID>
- Transfer the NFT token using
-
Metadata
- The metadata of the collection is immutable if
upd
isfalse
- The metadata of the collection can be updated by the deployer if
upd
istrue
- The metadata of the collection is initialized by the
deploy
inscription - The metadata of the collection can be updated by the
update
inscription - The
update
inscription must be minted by the owner ofdeploy
inscription and sent to the same address as thedeploy
inscription update
inscription ID should be larger than the deploy inscription ID
- The metadata of the collection is immutable if
BRC-721 is built upon the ordinals protocol. Although native ordinals NFT itself can store images, there are significant functional differences between brc-721 and native ordinals NFT:
-
Data storage
-
Native ordinals NFT stores images for each token, which can lead to high minting fees and occupy a large amount of Bitcoin network space.
-
BRC-721 only needs to save the image once during deployment, and the mint operation does not require saving the image, which can significantly save minting fees and Bitcoin network space. Additionally, brc-721 supports storing images in off-chain services like IPFS, saving Bitcoin space and providing flexible attribute information for each token.
-
Native ordinals NFT cannot effectively index a Collection, while brc-721 provides a JSON specification similar to brc-20, enabling effective indexing and searching of NFTs within a Collection.
-
-
BRC protocol compatibility
- BRC-721 adopts a protocol format similar to brc-20, defining different functions through JSON content, greatly improving the flexibility of NFTs. For example, the reveal function can be implemented through the update operation; the tick field enables effective indexing of NFTs within a Collection.
-
NFT ecosystem compatibility
- ERC-721 standard NFTs are more popular in the current market. BRC-721 adopts token URI and metadata specifications consistent with ERC-721, enabling quick adaptation to the existing NFT ecosystem. Meanwhile, native ordinals do not support traits and other fields, while brc-721 supports defining NFT attributes and rarity information.
-
BRC-721 is used for Non-Fungible Tokens (NFT), while brc-20 is used for Fungible Tokens
-
BRC-721 follows the brc-20 specifications, using JSON to define tokens and functions
-
BRC-20 requires minting an inscription before transferring, which is necessary for fungible tokens, but it leads to high transfer costs and increases invalid information on the Bitcoin network. BRC-721 takes advantage of the ordinals inscription feature and can complete the transfer directly by sending, significantly reducing costs and decreasing invalid information on the network.
brc721.com also proposes a Non-Fungible Token (NFT) solution based on the ordinals protocol, but its protocol is more complex and is not compatible with brc-20. BRC-721, on the other hand, is consistent with the brc-20 standard.
BRC-721 is an experimental standard that brings non-fungible tokens (NFTs) to the Bitcoin network. With this standard, users can create, mint, transfer, and update unique digital assets, enabling a wide range of use cases, such as digital art, collectibles, virtual goods, and more.
The standard allows for a series of operations that facilitate the management of non-fungible tokens, including deployment, minting, transferring, and updating metadata. Each token is assigned a unique identifier, ensuring that each NFT is distinct and cannot be exchanged on a one-to-one basis with another NFT.
As an experimental standard, BRC-721 invites improvements and modifications to enhance its functionality and adapt it to the growing needs of the NFT ecosystem.