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

Uploaded CPython 3.8+Windows x86-64

lattica-1.0.13-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.13-cp38-abi3-manylinux_2_34_aarch64.whl (11.0 MB view details)

Uploaded CPython 3.8+manylinux: glibc 2.34+ ARM64

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

Uploaded CPython 3.8+macOS 11.0+ ARM64

lattica-1.0.13-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.13-cp38-abi3-win_amd64.whl.

File metadata

  • Download URL: lattica-1.0.13-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.13-cp38-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 d493e15328c901ceb900f15cdc96f12014fb668d15632c6dc4e4ccf523b6be1b
MD5 bbeedc2aea4c7a237f37dd4fc4fde683
BLAKE2b-256 f368af2a6b5cb33bc88750e2df9ea450956971105f38b8add2e61d4be62f4850

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for lattica-1.0.13-cp38-abi3-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 b7f6eec0710b0887c7acd57a37ec4525449b33f9c9901174599bdc11f7fbad9f
MD5 a6475c27e99f5e51c43fee6036cb3d94
BLAKE2b-256 afb1b2251b0e78bad2438838804991a3a13c928c93e25bc699666947eab8b2ab

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for lattica-1.0.13-cp38-abi3-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 936e8b717afeb5d30fff368267432579d3869620020344ea3be56597185da6a1
MD5 6ebe8da29c047d524d64e9dbc60d192c
BLAKE2b-256 dd51b2310353b86e034f241966280db63c37ada8193587b7b0c269bd4e7adb01

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for lattica-1.0.13-cp38-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 dc445b1ad4bc9051d0433a43403fb0ca1883ef58b114d57e50fb16a58439ef76
MD5 155b7bfbfe1fe335ccbe2ee899ec7794
BLAKE2b-256 6cfd53d5bf0fed0f4673c6386df5ba56eecc5bde70ab50a731228c15ab90c16c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for lattica-1.0.13-cp38-abi3-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 f96d438e4c2261ffc8b76cc21c88cd0dc472b3cfb004b87e9b5670e338e797bf
MD5 b3442095c336af3b5ae58c1985e03eaa
BLAKE2b-256 c7dea0b7a055bbc90875541f53145c58d17a91639e35f6d2e7dd6cc4093d7f89

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