A platform for blockchain education and prototyping
Project description
Chaincraft
A platform for blockchain research and prototyping
Chaincraft is a Python-based framework for building and experimenting with blockchain protocols. It provides the fundamental components needed to create distributed networks, implement consensus mechanisms, and prototype blockchain applications.
Key Features
- Decentralized Network: Built-in peer discovery, connection management, and message propagation
- Shared Objects: Extensible framework for maintaining distributed state across nodes
- Cryptographic Primitives: Implementation of essential blockchain cryptography
- Persistence: Optional persistent storage for nodes and messages
- Data Validation: Type checking and schema validation for messages
- Merklelized Storage: Support for efficient state synchronization
Installation
Install from PyPI
The easiest way to install Chaincraft is via pip:
pip install chaincraft
Install from Source
For development or to get the latest features:
git clone https://github.com/jio-gl/chaincraft.git
cd chaincraft
pip install -e .
Development Installation
To install with development dependencies:
git clone https://github.com/jio-gl/chaincraft.git
cd chaincraft
pip install -e ".[dev]"
Requirements
- Python 3.8 or higher
cryptography>=44.0.1
Code quality (pre-commit hooks)
After cloning, run ./scripts/setup-hooks.sh to enable black and flake8 checks on commit.
Import Guide
After installing chaincraft, you can import its components using the package namespace:
# Main node component
from chaincraft import ChaincraftNode
# Core components
from chaincraft.shared_object import SharedObject
from chaincraft.shared_message import SharedMessage
# Exceptions
from chaincraft.shared_object import SharedObjectException
# Cryptographic primitives
from chaincraft.crypto_primitives.pow import ProofOfWorkPrimitive
from chaincraft.crypto_primitives.sign import ECDSASignaturePrimitive
Quick Start
Command Line Interface
After installation, you can use the chaincraft-cli command:
# Start a node with default settings
chaincraft-cli
# Start a node on a specific port
chaincraft-cli -p 8000
# Start a node and connect to a seed peer
chaincraft-cli -s 127.0.0.1:21000
# Enable debugging and use memory storage
chaincraft-cli -d -m
Python API
import chaincraft
# Create and start a node
node = chaincraft.ChaincraftNode()
node.start()
# Connect to another node
node.connect_to_peer("127.0.0.1", 21000)
# Create and broadcast a message
node.create_shared_message("Hello, Chaincraft!")
Architecture
Chaincraft is built on several core components:
ChaincraftNode: Handles networking, peer discovery, and message gossipSharedMessage: Wraps and serializes data for network transmissionSharedObject: Abstract base class for implementing distributed data structures- Cryptographic primitives: PoW, VDF, secure ECDSA, and VRF implementations
Usage
Basic Node Setup
from chaincraft import ChaincraftNode
# Create a node with default settings
node = ChaincraftNode()
node.start()
# Connect to another node
node.connect_to_peer("127.0.0.1", 21000)
# Create and broadcast a message
node.create_shared_message("Hello, Chaincraft!")
Creating a Custom Shared Object
from chaincraft.shared_object import SharedObject
from chaincraft.shared_message import SharedMessage
import hashlib
import json
class MySharedState(SharedObject):
def __init__(self):
self.state = {}
self.chain = [] # For merklelized sync
def is_valid(self, message: SharedMessage) -> bool:
# Validate incoming messages
return isinstance(message.data, dict) and "key" in message.data
def add_message(self, message: SharedMessage) -> None:
# Update state based on message
self.state[message.data["key"]] = message.data["value"]
self.chain.append(message.data)
def is_merkelized(self) -> bool:
return True
def get_latest_digest(self) -> str:
# Return latest state digest for sync
return hashlib.sha256(json.dumps(self.chain).encode()).hexdigest()
# Additional required methods...
Using Cryptographic Primitives
from chaincraft.crypto_primitives.pow import ProofOfWorkPrimitive
# Create a Proof of Work challenge
pow_primitive = ProofOfWorkPrimitive(difficulty_bits=16)
challenge = "block_data_here"
nonce, hash_hex = pow_primitive.create_proof(challenge)
# Verify the proof
is_valid = pow_primitive.verify_proof(challenge, nonce, hash_hex)
Blockchain Prototyping
Chaincraft provides the building blocks for implementing various blockchain designs:
- Proof of Work Blockchains: Using the PoW primitive
- State-Based Applications: Using
SharedObjects for consensus - Transaction Validation: Using the message validation framework
- Custom Consensus Mechanisms: By extending
SharedObjects with validation rules
Examples
The project includes various examples:
- Simple Blockchain: A basic blockchain with PoW consensus
- Message Chain: A merklelized append-only log of messages
- ECDSA Transactions: Signed transactions with balance tracking
- Chatroom: A real-time chat example with auto-accept membership
- See
examples/chatroom.mdfor details!
- See
Running Tests
Run all tests:
python -m unittest discover -v -s tests
Run a specific test file:
python -m unittest tests/test_blockchain_example.py
Run a specific test:
python -m unittest -v -k test_local_discovery_enabled tests/test_local_discovery.py
Design Principles
Chaincraft is designed to help explore blockchain tradeoffs:
- Blockchain Trilemma:
- Security vs. Scalability vs. Decentralization
- Time Synchronization:
- Asynchronous vs. Time-Bounded vs. Synchronized
- Identity Models:
- Anonymous vs. Resource-Based vs. Identity-Based
Contributing
Contributions to Chaincraft are welcome! This is an educational project aimed at helping developers understand blockchain concepts through hands-on implementation.
Current Status (Roadmap)
Roadmap to version 1.0.0
- ✅ Gossip Protocol: Sharing JSON messages between nodes
- ✅ Persistent Storage: Key-value storage for messages
- ✅ Peer Discovery: Global and local node discovery
- ✅ Message Validation: Field and type validation with peer banning
- ✅ Shared Objects: State synchronization between nodes
- ✅ Merklelized Storage: Efficient state synchronization
- ✅ Additional Cryptographic Primitives
- ✅ Indexing (Validated Message Type can have some indexed fields)
- ✅ Consensus Mechanisms
- ✅ Proof of Work
- ✅ Practical Byzantine Fault Tolerance (PBFT) or Tenderming (simpler)
- ⬜ Transaction Validation for Ledgers (Balance-based and UTXO-based)
- ⬜ Proof of Stake
- ⬜ Proof of Authority
- ⬜ Proof of Elapsed Time
- ⬜ Smart Contracts
- ⬜ State Machine Replication
- ⬜ Sharding
Ideas for version 2.0.0
- Configurable Building Blocks:
- choose consensys protocol (PoS, PoW, PoA, etc)
- choose ledger type (UTXO, Account Balances, etc)
- choose gas auction (Lower Price First, Median Price, etc)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file chaincraft-0.4.7.tar.gz.
File metadata
- Download URL: chaincraft-0.4.7.tar.gz
- Upload date:
- Size: 103.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e6159aaa3829059a42d46eebbc7c00933e9ab1b2f04c91d2258eb1361ac351d0
|
|
| MD5 |
f622c701d6c115d8b091dded942616b7
|
|
| BLAKE2b-256 |
e65775cef58d847d30e9d02ad8eb4f23e2fcdec8acb1c7b49bff77707c5a2872
|
Provenance
The following attestation bundles were made for chaincraft-0.4.7.tar.gz:
Publisher:
publish-to-pypi.yml on jose-compu/chaincraft
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
chaincraft-0.4.7.tar.gz -
Subject digest:
e6159aaa3829059a42d46eebbc7c00933e9ab1b2f04c91d2258eb1361ac351d0 - Sigstore transparency entry: 1247163110
- Sigstore integration time:
-
Permalink:
jose-compu/chaincraft@3ed4cea637cc927325adfe416efd40e62b2991b1 -
Branch / Tag:
refs/tags/v0.4.7 - Owner: https://github.com/jose-compu
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@3ed4cea637cc927325adfe416efd40e62b2991b1 -
Trigger Event:
push
-
Statement type:
File details
Details for the file chaincraft-0.4.7-py3-none-any.whl.
File metadata
- Download URL: chaincraft-0.4.7-py3-none-any.whl
- Upload date:
- Size: 77.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a3a11aa6006a24a1545ea40454b474e270721ba1270a5c501ae6c2aa0788d381
|
|
| MD5 |
71fc797b972a001e53dbb3a42c5af6b3
|
|
| BLAKE2b-256 |
e83a2d3f4ab2c24cb7ce065a54c0514e124dc37d8b04c4fb3f21af95e59d9237
|
Provenance
The following attestation bundles were made for chaincraft-0.4.7-py3-none-any.whl:
Publisher:
publish-to-pypi.yml on jose-compu/chaincraft
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
chaincraft-0.4.7-py3-none-any.whl -
Subject digest:
a3a11aa6006a24a1545ea40454b474e270721ba1270a5c501ae6c2aa0788d381 - Sigstore transparency entry: 1247163126
- Sigstore integration time:
-
Permalink:
jose-compu/chaincraft@3ed4cea637cc927325adfe416efd40e62b2991b1 -
Branch / Tag:
refs/tags/v0.4.7 - Owner: https://github.com/jose-compu
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@3ed4cea637cc927325adfe416efd40e62b2991b1 -
Trigger Event:
push
-
Statement type: