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.11-cp311-abi3-win_amd64.whl (7.7 MB view details)

Uploaded CPython 3.11+Windows x86-64

lattica-1.0.11-cp311-abi3-manylinux_2_34_x86_64.whl (10.7 MB view details)

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

lattica-1.0.11-cp311-abi3-manylinux_2_34_aarch64.whl (11.0 MB view details)

Uploaded CPython 3.11+manylinux: glibc 2.34+ ARM64

lattica-1.0.11-cp311-abi3-macosx_11_0_arm64.whl (8.2 MB view details)

Uploaded CPython 3.11+macOS 11.0+ ARM64

lattica-1.0.11-cp311-abi3-macosx_10_12_x86_64.whl (8.4 MB view details)

Uploaded CPython 3.11+macOS 10.12+ x86-64

File details

Details for the file lattica-1.0.11-cp311-abi3-win_amd64.whl.

File metadata

  • Download URL: lattica-1.0.11-cp311-abi3-win_amd64.whl
  • Upload date:
  • Size: 7.7 MB
  • Tags: CPython 3.11+, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.9

File hashes

Hashes for lattica-1.0.11-cp311-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 07f893bf096051f2cc5646c491b7293596f569f29824518f50c28c20a19776d6
MD5 11d0f3e1f0858e419b101c9a861a06ac
BLAKE2b-256 17b5e4f3aec2323b8cbf7dad146b8427f5112fac0fb447aa1ae16e18f838c7e8

See more details on using hashes here.

File details

Details for the file lattica-1.0.11-cp311-abi3-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for lattica-1.0.11-cp311-abi3-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 b434091b5fc4045d401021b53f5d89cb66528a0de9974e75963d894f5be69228
MD5 5f584922028247d69c72af646af7a29d
BLAKE2b-256 b69f96c422592c69f741304a62c2e8f9f3009f4bdf5af8a5975c730116c35371

See more details on using hashes here.

File details

Details for the file lattica-1.0.11-cp311-abi3-manylinux_2_34_aarch64.whl.

File metadata

File hashes

Hashes for lattica-1.0.11-cp311-abi3-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 575f174645f7c604b7ccbf950465483de27b287813136bcac5f645fb945ff01a
MD5 20683e301117e309736f4d1b2cc835bf
BLAKE2b-256 71cdbc43aa1b6404235c95f1be2aa4f26368390d84d015f704e4088bce3cd5b0

See more details on using hashes here.

File details

Details for the file lattica-1.0.11-cp311-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for lattica-1.0.11-cp311-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 5368d43af9bcaaf44069d3031228286eda4149aef230b1edf7c18d5f4b57908c
MD5 92c29dac60c069dd4c1de7b55596d9d2
BLAKE2b-256 e35a54e75ac09b9e29b8427fa6077fbd89238c1560213cec976d0688e689cecb

See more details on using hashes here.

File details

Details for the file lattica-1.0.11-cp311-abi3-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for lattica-1.0.11-cp311-abi3-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 4a6f6fe765ccadc3e7f54702a14f6dfa0ffccfbe2a969bec7d874f9f12b62d40
MD5 8faa4098b41d71066a38f6b64da2e6c8
BLAKE2b-256 3718c20934a12080e690a8c34201641ac933d87ecab602759f34d889eaccebd4

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