65 releases
Uses new Rust 2024
| new 0.1.0-alpha.6 | Jan 17, 2026 |
|---|---|
| 0.1.0-alpha.3 | Jan 14, 2026 |
| 0.1.0-alpha.1 | Dec 21, 2025 |
| 0.0.66 | Jun 19, 2025 |
| 0.0.11 | Mar 31, 2025 |
#74 in Magic Beans
Used in brk_bindgen
2MB
52K
SLoC
brk_query
Query interface for Bitcoin indexed and computed data.
What It Enables
Query blocks, transactions, addresses, and 1000+ on-chain metrics through a unified API. Supports pagination, range queries, and multiple output formats.
Key Features
- Unified access: Single entry point to indexer, computer, and mempool data
- Metric discovery: List metrics, filter by index type, fuzzy search
- Range queries: By height, date, or relative offsets (
from=-100) - Multi-metric bulk queries: Fetch multiple metrics in one call
- Async support: Tokio-compatible with
AsyncQuerywrapper - Format flexibility: JSON, CSV, or raw values
Core API
let query = Query::build(&reader, &indexer, &computer, Some(mempool));
// Current height
let height = query.height();
// Metric queries (two-phase: resolve then format)
let resolved = query.resolve(MetricSelection {
metrics: vec!["supply".into()],
index: Index::Height,
range: DataRangeFormat::default(),
}, usize::MAX)?;
let data = query.format(resolved)?;
// Block queries
let info = query.block_by_height(Height::new(840_000))?;
// Transaction queries
let tx = query.transaction(txid.into())?;
// Address queries
let stats = query.address(address)?;
Query Types
| Domain | Methods |
|---|---|
| Metrics | metrics, resolve, format, metric_to_indexes |
| Blocks | block, block_by_height, blocks, block_txs, block_status, block_by_timestamp |
| Transactions | transaction, transaction_status, transaction_hex, outspend, outspends |
| Addresses | address, address_txids, address_utxos |
| Mining | difficulty_adjustments, hashrate, mining_pools, reward_stats |
| Mempool | mempool_info, recommended_fees, mempool_blocks |
Async Usage
let async_query = AsyncQuery::build(&reader, &indexer, &computer, mempool);
// Run blocking queries in thread pool
let result = async_query.run(|q| q.block_by_height(height)).await;
// Access inner Query
let height = async_query.inner().height();
Recommended: mimalloc v3
Use mimalloc v3 as the global allocator to reduce memory usage.
Built On
brk_indexerfor raw indexed databrk_computerfor derived metricsbrk_mempoolfor mempool queriesbrk_readerfor raw block access
Dependencies
~32–44MB
~704K SLoC