0.0.4 • Published 2 years ago

fummpel v0.0.4

Weekly downloads
-
License
ISC
Repository
-
Last release
2 years ago

Usage

API

TokenIDs

Main class representing a set of token IDs as BigInts. Construct either with a list / set of BigInts or decode from compressed bytes.

Generate Merkle tree roots / multi-proofs with root() and proof(...) and retrieve a compact binary representation with 'encode()`

new TokenIDs(tokenIDs: Iterable<bigint>)

Create a new list of tokens from any Iterable, e.g. Set / Array. Token IDs must be 256-bit BigInts

TokenIDs.decode(bytes: Uint8Array): TokenIDs

Decode tokens from a compressed byte stream.

encode()

Gets compressed binary representation of all token IDs

proof(subset: Iterable<bigint>)

Generates Merkle multi-proof for subset of token IDs

root()

Gets Merkle tree root hash

tokens()

Gets list of token IDs represented by this TokenIDs instance as a sorted array

verify(proof: string[], flags: boolean[], leaves: string[][]): boolean

Verify multiproof using essentially the same algo in OpenZeppelin's smart contract

Example

import { TokenIDs } from 'fummpel';

// keccak256 needs to be initialized
await TokenIDs.init();

const tokens = new TokenIDs([2n,3n,5n,7n])

// Merkle root for these 4 tokens
const root = tokens.root();
// '0xc97e9e1eb896293c19f2649c796c9a276d997cfa58164c5f25d9a3f29b894cc9'

// Merkle multiproof for 2 of the tokens
const proof = tokens.proof([2n, 5n]);
// {
//   leaves: [ 5n, 2n ],
//   proof: [
//     '0xcff8e1781584200105067c0684580a1524c9539de52c1f9889e2cf73830cfccc'
//   ],
//   proofFlags: [ true, false ]
// }

// Leaf error if token is not in tree
const bad = tokens.proof([1n]);
// Error: Leaf is not in tree

// Verify multiproof
const verified = tokens.verify(proof.proof, proof.proofFlags, proof.leaves);
// true

// Get encoded tokens list
const encoded = tokens.encoded();
// Uint8Array(2) [ ... ]

// Decode encoded tokens list
const decoded_tokens = TokenIDs.decode(encoded);
// TokenIDs { ... }

const decoded_token_ids = decoded_tokens.tokens();
// [ 2n, 3n, 5n, 7n ]

Development

npm install

Test

uvu is used for testing.

All

npm test

Single test

npx ts-node src/token_ids.test.ts

Browser Benchmark

Install parcel then parcel public/bench.html or npx parcel public/bench.html.

Build / Publish

npm run build and then npm publish --access public

0.0.4

2 years ago

0.0.3

2 years ago

0.0.2

2 years ago

0.0.1

2 years ago