_
_ . _ _|__ _ _|
|_)|(_(_)|(/_(/_(_| v8
|
Space Efficient Chain of Blocks
- Flat memory layout / zero copy access
- Single dependency EdDSA
- Fast & compact
Curve25519
+Ed25519
signatures - Pure ES6 (+JSDoc Type annotations)
- ~450LOC / +41.3kB bundle size
- Test Coverage 💯
- Uint8Arrays (no node:buffer or bn.js)
( For those who are new to linked blocks )
Imagine git as a jar, then using pliers pull out a branch. That single detached branch is synonymous with one picofeed - a memorybuffer containing cryptographically signed blocks:
This package provides 2 primitves
Feed
|------|------------------|----------------------|
| PiC0 | Block 0: "hello" | Block 1: "picoverse" |
|------|------------------|----------------------|
and
Block
| SIG: 64B |
| SIZE: varint |
| DATA: buffer[SIZE] |
minimal overhead, quite simple.
This library provides a high level API to append
, slice
and merge
such feeds - block contents is upto application.
We target user devices, picofeed is the basic building block for the frontend-block-engine picostack
yarn add picofeed
# or
npm install picofeed
import { Feed, toHex } from 'picofeed'
const { pk: publicKey, sk: secret } = Feed.signPair()
const feed = new Feed()
feed.append('Hello', secret) // => height 1
feed.blocks[0].body // => 'Hello'
feed.blocks[0].blockSize // => 71 bytes
const verifiableData = feed.buffer
// -- Share buffer anyhow --
const remoteFeed = Feed.from(verifiableData) // Verifies signatures
remoteFeed.blocks[0].body // => 'Hello'
toHex(remoteFeed.blocks[0].key) === alice.pk // true
Reworked binary format, less overhead
- removed
fmt
byte - added Headers instead
phat
-bit replaced withvarint
- changed
secp256k1
in favour ofEd25519
- fixed
merge()
bug - removed
u8n
util
signPair()
returnshexstring
keyssk.slice(32)
no longer works, usegetPublicKey(sk)
block.parentSig
renamed toblock.psig
block.isGenesis
renamed toblock.genesis
feed.get(n)
renamed tofeed.block(n)
feed.blocks()
removed in favour offeed.blocks
feed.pickle()
removed until further notice.feed.fromBlocksArray()
incorporated intofeedFrom()
/Feed.from()
- Not backwards compatible with 3.x feeds
- updated
README.md
- added Feed.fromBlocksArray(Block[]) to perform bulk-merge, 24x perf increase compared to Feed.merge(block)
- removed Feed subclassing/metaprogramming support, it was fun but footgun (don't solve problems by subclassing Feed).
- added Feed.first
- added Feed.get(-3) as equivalent of f.get(f.length - 3)
- added Block.isGenesis getter
- added static Feed.KEY_SIZE constant
- replaced hardcoded key-size lenghts with KEY_SIZE constant
- optimization feed._steal() also steals cache
- fixed bug feed._steal(other) causing cache corruption
- changed return value of feed.inspect() is now conditional
- fixed bug where A < B; A.merge(B, withCallback) did not merge
- fixed bug where keychain cache contained boatloads of duplicate keys
- added
feed.merge(block)
support
- removed automatic encodings
- changed
feed.get(n)
returns instance of BlockMapper. - changed
feed.slice(start, end)
- added block cache to avoid redundant signature-verifications
- added BlockMapper now also contains public-key
- sodium-universal upgraded to 3.0.0
- Added feed.merge(other, opts, indexingCallback) that allows validation + abort merge interactively
- Added feed.last which returns the block-contents using provided encoding.
- Added feed slices and merge
2020-2023 🄯 Tony Ivanov