Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
blockstore-core
Advanced tools
Contains various implementations of the API contract described in interface-blockstore
Contains various implementations of the API contract described in interface-blockstore
Various Blockstore implementations are available.
src/base
src/memory
Provides a complete implementation of the Blockstore interface. You must implement .get
, .put
, etc.
import { BaseBlockstore } from 'blockstore-core/base'
class MyCustomBlockstore extends BaseBlockstore {
put (key, val, options) {
// store a block
}
get (key, options) {
// retrieve a block
}
// ...etc
}
A simple Blockstore that stores blocks in memory.
import { MemoryBlockstore } from 'blockstore-core/memory'
const store = new MemoryBlockstore()
A Blockstore that does not store any blocks.
import { BlackHoleBlockstore } from 'blockstore-core/black-hole'
const store = new BlackHoleBlockstore()
A tiered blockstore wraps one or more blockstores and will query each in parallel to retrieve a block - the operation will succeed if any wrapped store has the block.
Writes are invoked on all wrapped blockstores.
import { TieredBlockstore } from 'blockstore-core/tiered'
const store = new TieredBlockstore([
store1,
store2,
// ...etc
])
An identity blockstore is one that deals exclusively in Identity CIDs - this is a special CID with the codec 0x00 where the multihash digest is the data that makes up the block.
import { IdentityBlockstore } from 'blockstore-core/identity'
import { CID } from 'multiformats/cid'
const blockstore = new IdentityBlockstore()
blockstore.has(CID.parse('QmFoo')) // false
blockstore.has(CID.parse('bafkqac3imvwgy3zao5xxe3de')) // true
$ npm i blockstore-core
<script>
tagLoading this module through a script tag will make its exports available as BlockstoreCore
in the global namespace.
<script src="https://unpkg.com/blockstore-core/dist/index.min.js"></script>
Licensed under either of
Contributions welcome! Please check out the issues.
Also see our contributing document for more information on how we work, and about contributing in general.
Please be aware that all interactions related to this repo are subject to the IPFS Code of Conduct.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
FAQs
Contains various implementations of the API contract described in interface-blockstore
The npm package blockstore-core receives a total of 11,328 weekly downloads. As such, blockstore-core popularity was classified as popular.
We found that blockstore-core demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.