No description
Find a file
Claude 53311b14d1
fix(chain): resolve missing block blobs from daemon RPC
The Zano daemon's get_blocks_details RPC does not populate the blob
field. This adds resolveBlockBlobs() which batch-fetches miner tx
blobs via /gettransactions and reconstructs block wire blobs from
the parsed header (object_in_json AGGREGATED section) and raw tx
bytes. Also fixes regular tx processing to skip the miner tx entry
that the daemon includes in transactions_details.

Co-Authored-By: Charon <charon@lethean.io>
2026-02-21 20:46:56 +00:00
chain fix(chain): resolve missing block blobs from daemon RPC 2026-02-21 20:46:56 +00:00
config feat(consensus): scaffold package with error types 2026-02-21 00:39:41 +00:00
consensus feat(consensus): wire up NLSAG ring signature verification 2026-02-21 20:26:33 +00:00
crypto feat(crypto): wire BPP/BPPE/BGE proof verification with real testnet data 2026-02-21 18:37:08 +00:00
difficulty feat: Phase 0 scaffold -- config, types, wire, difficulty 2026-02-20 15:10:33 +00:00
docs docs: add block sync design and implementation plan 2026-02-21 20:21:14 +00:00
mining test(mining): integration test against C++ testnet daemon 2026-02-21 02:20:05 +00:00
p2p test(p2p): integration test against C++ testnet daemon 2026-02-20 19:45:24 +00:00
rpc feat(rpc): add GetBlockTemplate endpoint 2026-02-21 02:01:12 +00:00
types feat(wire): v2+ transaction serialisation with real testnet verification 2026-02-21 19:09:34 +00:00
wallet feat(chain): integrate consensus validation into sync 2026-02-21 01:11:33 +00:00
wire feat(wire): v2+ transaction serialisation with real testnet verification 2026-02-21 19:09:34 +00:00
.gitignore feat(crypto): Phase 2a scaffold — vendored C++ and CMake build 2026-02-20 18:21:44 +00:00
CLAUDE.md docs: Phase 2 crypto bridge documentation 2026-02-20 18:49:21 +00:00
go.mod feat(consensus): scaffold package with error types 2026-02-21 00:39:41 +00:00
go.sum feat(consensus): scaffold package with error types 2026-02-21 00:39:41 +00:00
README.md docs: graduate Phase 0 into production documentation 2026-02-20 15:24:38 +00:00

go-blockchain

Pure Go implementation of the Lethean blockchain protocol. Provides chain configuration, core cryptographic data types, CryptoNote wire serialisation, and LWMA difficulty adjustment for the Lethean CryptoNote/Zano-fork chain. Follows ADR-001: protocol logic in Go, cryptographic primitives deferred to a C++ bridge in later phases. Lineage: CryptoNote to IntenseCoin (2017) to Lethean to Zano rebase.

Module: forge.lthn.ai/core/go-blockchain Licence: EUPL-1.2 Language: Go 1.25

Quick Start

import (
    "forge.lthn.ai/core/go-blockchain/config"
    "forge.lthn.ai/core/go-blockchain/types"
    "forge.lthn.ai/core/go-blockchain/wire"
    "forge.lthn.ai/core/go-blockchain/difficulty"
)

// Query the active hardfork version at a given block height
version := config.VersionAtHeight(config.MainnetForks, 10081) // returns HF2

// Check if a specific hardfork is active
active := config.IsHardForkActive(config.MainnetForks, config.HF4Zarcanum, 50000) // false

// Encode and decode a Lethean address
addr := &types.Address{SpendPublicKey: spendKey, ViewPublicKey: viewKey}
encoded := addr.Encode(config.AddressPrefix)
decoded, prefix, err := types.DecodeAddress(encoded)

// Varint encoding for the wire protocol
buf := wire.EncodeVarint(0x1eaf7)
val, n, err := wire.DecodeVarint(buf)

// Calculate next block difficulty
nextDiff := difficulty.NextDifficulty(timestamps, cumulativeDiffs, 120)

Documentation

Build & Test

go test ./...
go test -race ./...
go vet ./...
go build ./...

Licence

European Union Public Licence 1.2 -- see LICENCE for details.