Skip to main content

A unified Python SDK for P2P networking with integrated DHT and NAT capabilities

Project description

Lattica Python SDK

A unified Python SDK for P2P networking with integrated DHT and NAT capabilities, built on top of libp2p.

Features

  • Distributed Hash Table (DHT): Store and retrieve key-value pairs across the network
  • Remote Procedure Call (RPC): Execute remote functions with support for complex data types
  • Streaming RPC: Handle large data transfers with streaming capabilities
  • NAT Traversal: Automatic NAT traversal with UPnP support
  • Peer Discovery: mDNS and rendezvous-based peer discovery
  • High Performance: Built with Rust for optimal performance

Installation

You can install the released versions

pip install lattica

Or you can install from source using:

pip install git+https://github.com/GradientHQ/lattica.git#subdirectory=bindings/python

Quick Start

Basic Usage

from lattica import Lattica

# Create a Lattica instance
lattica = Lattica.builder().build()

# Get your peer ID
peer_id = lattica.peer_id()
print(f"My peer ID: {peer_id}")

Examples

1. DHT Operations

The DHT example demonstrates basic key-value storage and retrieval with subkey support.

from lattica import Lattica

# Create client1 as bootstrap node
lattica = Lattica.builder()
    .build()

# Create client2 with bootstrap nodes
lattica = Lattica.builder() \
    .with_bootstraps(["/ip4/127.0.0.1/tcp/54282/p2p/QmServerPeerId"]) \
    .build()

# Store a simple key-value pair with default expiration 10 minute
lattica.store("name", "alice")

# get the value
result = lattica.get("name")
if result:
    print(f"Value: {result.value}")
    print(f"Expires: {result.expiration_time}")


# Store values with subkeys (useful for voting, user data, etc.)
key = "peer_list"
peers = ["alice", "bob", "carol"]

# Each peer stores their vote with a subkey
lattica.store(key, "yes", expiration_time, subkey="alice")
lattica.store(key, "no", expiration_time, subkey="bob")
lattica.store(key, "maybe", expiration_time, subkey="carol")

# get all votes
votes_result = lattica.get(key)
if votes_result:
    for peer, vote_info in votes_result.value.items():
        print(f"{peer}: {vote_info.value}")

2. RPC Operations

The RPC example demonstrates remote procedure calls with support for complex data types and streaming.

from lattica import Lattica, rpc_method, rpc_stream, rpc_stream_iter, ConnectionHandler



class MyService(ConnectionHandler):
    @rpc_method
    def add(self, a: int, b: int) -> int:
        """Simple addition"""
        return a + b
    
    @rpc_stream
    def process_data(self, data: list) -> list:
        return data

    @rpc_stream_iter
    def stream_rpc_iter(self):
        while True:
            text = "hello world"
            yield text
            
# Create client1 as RPC server and bootstrap node
lattica = Lattica.builder()
    .build()
service = MyService(lattica)

# Create client2 with bootstrap nodes
lattica = Lattica.builder() \
    .with_bootstraps(["/ip4/127.0.0.1/tcp/54282/p2p/QmServerPeerId"]) \
    .build()
client_service = MyService(client_lattica)

# Make RPC calls
stub = client_service.get_stub(server_peer_id)
result = stub.add(10, 20)  # Returns 30

# Handle complex data types
num_floats = int(2 * 1024 * 1024 * 1024) // 8 #2GB
test_data = [random.random() for _ in range(num_floats)]
result = stub.process_data(test_data)

# stream iter call
for text in stub.stream_rpc_iter():
    print(f"recv: {text}")

Configuration

Builder Pattern

lattica = Lattica.builder() \
    .with_bootstraps([
        "/ip4/127.0.0.1/tcp/8080/p2p/QmBootstrap1",
        "/ip4/127.0.0.1/tcp/8081/p2p/QmBootstrap2"
    ]) \
    .with_listen_addrs(["/ip4/0.0.0.0/tcp/0", "/ip4/0.0.0.0/udp/0/quic-v1"])
    .with_external_addrs(["/ip4/0.0.0.0/tcp/0"])
    .with_mdns(True) \
    .with_upnp(True) \
    .build()

Configuration Options

  • with_bootstraps(nodes): Set bootstrap nodes for network discovery
  • with_listen_addrs(addrs): Set listening address
  • with_mdns(enabled): Enable/disable mDNS peer discovery
  • with_upnp(enabled): Enable/disable UPnP NAT traversal
  • with_relay_servers(servers): Set relay servers for network relay
  • with_autonat(enabled): Enable/disable AutoNAT detect[need relay servers]
  • with_dcutr(enabled): Enable/disable TCP/QUIC NAT travelsal[need relay servers]
  • with_external_addrs(addrs): Set external address
  • with_storage_path: Persistent storage path
  • with_dht_db_path: DHT Persistent db path
  • with_key_path: Set Keypair path

Development

Building from Source

# Install maturin
pip install maturin

# Build the package
cd bindings/python
pip install .

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

lattica-1.0.12-cp38-abi3-win_amd64.whl (7.7 MB view details)

Uploaded CPython 3.8+Windows x86-64

lattica-1.0.12-cp38-abi3-manylinux_2_34_x86_64.whl (10.8 MB view details)

Uploaded CPython 3.8+manylinux: glibc 2.34+ x86-64

lattica-1.0.12-cp38-abi3-manylinux_2_34_aarch64.whl (11.0 MB view details)

Uploaded CPython 3.8+manylinux: glibc 2.34+ ARM64

lattica-1.0.12-cp38-abi3-macosx_11_0_arm64.whl (8.2 MB view details)

Uploaded CPython 3.8+macOS 11.0+ ARM64

lattica-1.0.12-cp38-abi3-macosx_10_12_x86_64.whl (8.4 MB view details)

Uploaded CPython 3.8+macOS 10.12+ x86-64

File details

Details for the file lattica-1.0.12-cp38-abi3-win_amd64.whl.

File metadata

  • Download URL: lattica-1.0.12-cp38-abi3-win_amd64.whl
  • Upload date:
  • Size: 7.7 MB
  • Tags: CPython 3.8+, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.10

File hashes

Hashes for lattica-1.0.12-cp38-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 1a29f1389e4dd70601302fd9fc4c90a95c94af6f84fc4b9be82933ae5e825367
MD5 fe61a827c07877c3c2afbfc4c87c1246
BLAKE2b-256 f8df53f15e45b6fe31bdaf9ab429b7efa7b83b94452daf3993fd3e494d07a86f

See more details on using hashes here.

File details

Details for the file lattica-1.0.12-cp38-abi3-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for lattica-1.0.12-cp38-abi3-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 eba206ba752587ca7289a02d3a7bf9c008e09b46562fdcc3f1f7d649c3a82d5a
MD5 2902292e80896bd907590246e09b073b
BLAKE2b-256 4ccce08509d1a03913242b01418151794f4d2b553cff43cd5a414abdaeffdbf9

See more details on using hashes here.

File details

Details for the file lattica-1.0.12-cp38-abi3-manylinux_2_34_aarch64.whl.

File metadata

File hashes

Hashes for lattica-1.0.12-cp38-abi3-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 9436c691c39ccf9d67369f7af8dad1d08304454eb65db168ebecba849d0d090b
MD5 2a707afc0b39f56a4a85b6c8dd80c3ce
BLAKE2b-256 3b25b640ee826a274a1318bbf243b729068e9ebba9d438bb39ef4c4a2521c4c5

See more details on using hashes here.

File details

Details for the file lattica-1.0.12-cp38-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for lattica-1.0.12-cp38-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 991b85237028d395b7f32d0ffaf0e0c3eaaee0932432454b1b33f28924e251d5
MD5 e532ced721c2245c26776c27860be6f8
BLAKE2b-256 a21a8fcb1de6a18710afaaef03dffdad65d2aa96a3eca26d745aaab60cd4cf5a

See more details on using hashes here.

File details

Details for the file lattica-1.0.12-cp38-abi3-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for lattica-1.0.12-cp38-abi3-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 ba67748b6e964ffd8a6b77558073a89933c128743d24f423ac845ea9efa07e91
MD5 b735b2c11d7c402d4d8a9a26b41c93ea
BLAKE2b-256 92a9b183f61d05dbdcb8ca867438ed881fe5f2f58d698bae3517d6289bb0c720

See more details on using hashes here.

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