Skip to main content

A platform for blockchain education and prototyping

Project description

Chaincraft

Python 3.8+ Python Unit Tests License: MIT Blockchain ECDSA Project Status PyPI version PyPI Downloads

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 gossip
  • SharedMessage: Wraps and serializes data for network transmission
  • SharedObject: 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

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

chaincraft-0.5.1.tar.gz (110.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

chaincraft-0.5.1-py3-none-any.whl (80.6 kB view details)

Uploaded Python 3

File details

Details for the file chaincraft-0.5.1.tar.gz.

File metadata

  • Download URL: chaincraft-0.5.1.tar.gz
  • Upload date:
  • Size: 110.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for chaincraft-0.5.1.tar.gz
Algorithm Hash digest
SHA256 f65427af8f9936ac62d3601be6ec15de104d10311b71bc7a6baf8ca300a5e362
MD5 7890c3a672d343a0d7fd46aff162b1ce
BLAKE2b-256 6d34a8bc93fa358e1890372f36d4a0905dbb9a86f563ebf075f5e1faed8332a1

See more details on using hashes here.

Provenance

The following attestation bundles were made for chaincraft-0.5.1.tar.gz:

Publisher: publish-to-pypi.yml on jose-compu/chaincraft

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file chaincraft-0.5.1-py3-none-any.whl.

File metadata

  • Download URL: chaincraft-0.5.1-py3-none-any.whl
  • Upload date:
  • Size: 80.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for chaincraft-0.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 20c0918552badd2bf7907d428922c7755d97ff9bb657ad370cc3175ee8b7a66c
MD5 89cc14789ba6fd69d57b4ad971a792dc
BLAKE2b-256 4ab01fc7e8622ef5172166e61a15f12caa095d99f03df694dc86dad7e0efc4df

See more details on using hashes here.

Provenance

The following attestation bundles were made for chaincraft-0.5.1-py3-none-any.whl:

Publisher: publish-to-pypi.yml on jose-compu/chaincraft

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page