Skip to content

cgewecke/samwitch-orderbook

 
 

Repository files navigation

SWOB (SamWitchOrderBook) for ERC1155 NFTs

Continuous integration

swob

overall statements branches functions lines

This efficient order book utilises the BokkyPooBahsRedBlackTreeLibrary library for sorting prices allowing O(log n) for tree segment insertion, traversal, and deletion. It supports batch orders and batch cancelling, ERC2981 royalties, and a dev and burn fee on each trade.

It is kept gas efficient by packing data in many areas:

  • Four orders (uint24 quantity + uint40 order id) into a 256bit word giving a 4x improvement compared to using 1 storage slot per order
  • When taking from the order book no tokens/nfts are transferred. Instead the orderId is stored in a claimable array
  • The tokens claimable are packed with 3 orders per storage slot

The order book is kept healthy by requiring a minimum quantity that can be added - partial quantities can still be taken from the order book. Cancelling orders shifts all entries at that price level to remove gaps.

Constraints:

  • The order quantity to be added to the book is limited to ~16mil
  • The maximum number of orders in the book that can ever be added is limited to 1 trillion
  • The maximum number of orders that can be added to a specific price level in its lifetime is 16 billion
  • Cannot change tick for a tokenId after it's been set

While this order book was created for ERC1155 NFTs it could be adapted for ERC20 tokens.

Note: Not suitable for production until more tests are added with more code coverage.

Potential improvements:

  • TokenInfo could use uint64 for both members and packed 2 in an array if tokenIds are sequential and limited
  • Range delete of the red-black tree using split/join
  • When cancelling an order some of the shifting logic can be improved to move some orders in segments in 1 go.

To start copy the .env.sample file to .env and fill in PRIVATE_KEY at a minimum (starts with 0x).

yarn install

# To compile the contracts
yarn compile

# To run the tests
yarn test

# To get code coverage
yarn coverage

# To deploy all contracts
yarn deploy --network <network>
yarn deploy --network fantom_testnet

# Export abi
yarn abi

# To fork or open a node connection
yarn fork
yarn fork --fork <rpc_url>
yarn fork --fork https://rpc.ftm.tools

# To impersonate an account on a forked or local blockchain for debugging
yarn impersonate

About

ERC1155 NFT Order book

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 66.4%
  • Solidity 33.4%
  • Other 0.2%