Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Docs and docker stuff #42

Merged
merged 15 commits into from
Dec 15, 2024
Merged
10 changes: 5 additions & 5 deletions .github/workflows/deploy-docs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -24,17 +24,17 @@ jobs:
id: pages
uses: actions/configure-pages@v4
- name: Clean docs folder
run: cd swarm_nl && cargo clean --doc
run: cd swarm-nl && cargo clean --doc
- name: Build docs
run: cd swarm_nl && cargo doc --no-deps --features=tokio-runtime
run: cd swarm-nl && cargo doc --no-deps --features=tokio-runtime
- name: Add redirect
run: cd swarm_nl && echo '<meta http-equiv="refresh" content="0;url=aoc/index.html">' > target/doc/index.html
run: cd swarm-nl && echo '<meta http-equiv="refresh" content="0;url=aoc/index.html">' > target/doc/index.html
- name: Remove lock file
run: cd swarm_nl && rm target/doc/.lock
run: cd swarm-nl && rm target/doc/.lock
- name: Upload artifact
uses: actions/upload-pages-artifact@v3
with:
path: swarm_nl/target/doc
path: swarm-nl/target/doc
deploy:
name: Deploy
environment:
Expand Down
6 changes: 3 additions & 3 deletions .github/workflows/rust.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@ jobs:
steps:
- uses: actions/checkout@v3
# - name: Build with async-std-runtime
# run: cd swarm_nl && cargo build --features=async-std-runtime
# run: cd swarm-nl && cargo build --features=async-std-runtime
- name: Build with tokio-runtime
run: cd swarm_nl && cargo build --features=tokio-runtime
run: cd swarm-nl && cargo build --features=tokio-runtime
- name: Run tests
run: cd swarm_nl && cargo test --lib --features=tokio-runtime
run: cd swarm-nl && cargo test --lib --features=tokio-runtime
2 changes: 1 addition & 1 deletion .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"rust-analyzer.linkedProjects": [
"./client/Cargo.toml",
"./swarm_nl/Cargo.toml"
"./swarm-nl/Cargo.toml"
]
}
88 changes: 43 additions & 45 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,22 +6,26 @@

SwarmNL is a library designed for P2P networking in distributed systems. It's lightweight, scalable, and easy to configure, making it perfect for decentralized applications. Powered by [libp2p](https://docs.libp2p.io/), SwarmNL simplifies networking so developers can focus on building.

<!-- TOC start (generated with https://github.com/derlin/bitdowntoc) -->
Visit the deployed Rust docs [here](https://algorealminc.github.io/SwarmNL/swarm-nl/index.html).

<!-- TOC start -->

- [Why SwarmNL?](#why-swarmnl)
- [examples](#examples)
- [Documentation](#documentation)
- [Features and examples](#features-and-examples)
- [Node configuration](#node-configuration)
- [Node communication](#node-communication)
- [Tutorials and examples](#tutorials-and-examples)
- [Research and technicalities](#research-and-technicalities)
- [Node configuration](#node-configuration)
- [Example](#example-node-configuration-with-default-settings)
- [Event handling](#event-handling)
- [Node communication](#node-communication)
- [Example](#example-communicating-with-the-network-layer)
- [Replication](#replication)
- [Key features](#key-features)
- [Example](#example-configuring-and-using-replication)
- [Why use SwarmNl for Replication](#why-use-swarmnl-for-replication)
- [Why use SwarmNL for replication](#why-use-swarmnl-for-replication)
- [Sharding](#sharding)
- [Key features](#key-features-1)
- [Example](#example-configuring-and-operating-a-sharded-network)
- [Why use SwarmNl for Sharding](#why-use-swarmnl-for-sharding)
- [Why use SwarmNL for sharding](#why-use-swarmnl-for-sharding)
<!-- TOC end -->

## Why SwarmNL?
Expand All @@ -30,29 +34,23 @@ SwarmNL makes buiding a peer-to-peer decentralized and distributed networking st

Say goodbye to the complexities of networking and hello to simplicity. With SwarmNL, all the hard work is done for you, leaving you to focus on simple configurations and your application logic.

## Examples

Have a look at some examples that demonstrate the use of SwarmNl in various contexts:

- [Echo server tutorial](https://github.com/algorealmInc/SwarmNL/tree/dev/examples/echo_server): demonstrates a simple use case of setting up a node and querying the network layer.
- [File sharing application tutorial](https://github.com/algorealmInc/SwarmNL/tree/dev/examples/file_sharing_app): demonstrates interacting with the DHT and sending/recieving RPCs from peers.
- [Simple game tutorial](https://github.com/algorealmInc/SwarmNL/tree/dev/examples/simple_game): demonstrates communicating with peers over the network through gossiping.
- [The sharding tutorial](https://github.com/algorealmInc/SwarmNL/tree/dev/examples/sharding): demonstrates splitting a network into shards for scaling and handling communication between various nodes in a shard and across the network.
- [The replication tutorial](https://github.com/algorealmInc/SwarmNL/tree/dev/examples/replication): demonstrates the replication of data across nodes specially configured to provide redundancy to the network.
## Tutorials and examples

Visit the examples folder [here](https://github.com/algorealmInc/SwarmNL/tree/dev/examples) to understand more on how to use the library. The examples also contains integration with IPFS, HTTP servers etc.
Have a look at these step-by-step examples that demonstrate the use of SwarmNL in various contexts:

## Documentation
- [Echo server tutorial](https://github.com/algorealmInc/SwarmNL/tree/main/examples/echo-server): demonstrates a simple use case of setting up a node and querying the network layer.
- [File sharing application tutorial](https://github.com/algorealmInc/SwarmNL/tree/main/examples/file-sharing-app): demonstrates interacting with the DHT and sending/recieving RPCs from peers.
- [Simple game tutorial](https://github.com/algorealmInc/SwarmNL/tree/main/examples/simple-game): demonstrates communicating with peers over the network through gossiping.
- [Sharding tutorial](https://github.com/algorealmInc/SwarmNL/tree/main/examples/sharding): demonstrates splitting a network into shards for scaling and handling communication between various nodes in a shard and across the network.
- [Replication tutorials](https://github.com/algorealmInc/SwarmNL/tree/main/examples/replication): demonstrates the replication of data across nodes specially configured to provide redundancy to the network.

Visit the deployed Rust docs [here](https://algorealminc.github.io/SwarmNL/swarm_nl/index.html).
Visit the examples folder [here](https://github.com/algorealmInc/SwarmNL/tree/dev/examples/) to gain a fuller understanding on ways to use the library, including how to integrate SwarmNL with IPFS and HTTP servers.

## Research and Technicalities
## Research and technicalities

Please check [here](https://github.com/algorealmInc/SwarmNL/blob/main/research.md) for more technical details and understanding of SwarmNL and it's design choices.
Have a look at [this document](https://github.com/algorealmInc/SwarmNL/blob/main/research.md) for a technical overview of SwarmNL and it's design choices.

## Features and examples

### Node configuration
## Node configuration

SwarmNL provides a simple interface to configure a node and specify parameters to dictate its behaviour. This includes:

Expand All @@ -63,10 +61,10 @@ SwarmNL provides a simple interface to configure a node and specify parameters t
- Protocol specification and handlers
- Event handlers for network events and logging

#### Example
### Example: node configuration with default settings

```rust
#![cfg_attr(not(doctest))]
#![cfg_attr(not(doctest))]
//! Using the default node setup configuration

// Default config
Expand Down Expand Up @@ -105,9 +103,9 @@ SwarmNL provides a simple interface to configure a node and specify parameters t

```

Please look at a template `.ini` file [here](https://github.com/algorealmInc/SwarmNL/blob/dev/swarm_nl/bootstrap_config.ini) for configuring a node in the network.<br><br>
Please look at a template `.ini` file [here](https://github.com/algorealmInc/SwarmNL/blob/dev/swarm-nl/bootstrap_config.ini) for configuring a node in the network.<br><br>

### Event Handling
### Event handling

During network operations, various events are generated. These events help us track the activities in the network layer. When generated, they are stored in an internal buffer until they are explicitly polled and consumed, or until the queue is full. It is important to consume critical events promptly to prevent loss if the buffer becomes full.

Expand Down Expand Up @@ -181,18 +179,18 @@ During network operations, various events are generated. These events help us tr
}
```

### Node communication
## Node communication

For communication, SwarmNL leverages the powerful capabilities of libp2p. These includes:

- The Kadmlia DHT: Developers can use the DHT to store infomation and leverage the capabilities of the DHT to build powerful applications, easily.
- A simple RPC mechanism to exchange data quickly between peers.
- Gossiping: SwarmNL uses the Gossipsub 1.1 protocol, specified by the [libp2p spec](https://github.com/libp2p/specs/blob/master/pubsub/gossipsub/gossipsub-v1.1.md).

#### Communicate with the network layer
### Example: communicating with the network layer

```rust
#![cfg_attr(not(doctest))]
#![cfg_attr(not(doctest))]
//! Communicate with remote nodes using the simple and familiar async-await paradigm.

// Build node or network core
Expand Down Expand Up @@ -260,18 +258,18 @@ For communication, SwarmNL leverages the powerful capabilities of libp2p. These

**SwarmNL** makes fault tolerance through redundancy simple and easy to integrate into your application. With replication built into SwarmNL, you can achieve robust and scalable systems effortlessly.

### Key Features
### Key features

- **Consistency Models**: Choose from a variety of consistency models, including strong consistency with customizable parameters.
- **Dynamic Node Management**: Nodes can seamlessly join and leave replica networks without disrupting operations. Events are quickly propagated to all nodes.
- **Ease of Use**: Minimal setup is required to add replication to your system, ensuring quick integration and deployment.
- **Node Cloning**: Complete instant cloning of data in the buffer of a replica peer.
- **Consistency models**: Choose from a variety of consistency models, including strong consistency with customizable parameters.
- **Dynamic node management**: Nodes can seamlessly join and leave replica networks without disrupting operations. Events are quickly propagated to all nodes.
- **Ease of use**: Minimal setup is required to add replication to your system, ensuring quick integration and deployment.
- **Node cloning**: Complete instant cloning of data in the buffer of a replica peer.

### Example: Configuring and Using Replication
### Example: configuring and using replication

Here’s how you can set up and use SwarmNL's replication capabilities:

#### Configuring a Node for Replication
#### Configuring a node for replication

```rust
#![cfg_attr(not(doctest))]
Expand Down Expand Up @@ -299,7 +297,7 @@ Here’s how you can set up and use SwarmNL's replication capabilities:
node.replicate(payload, REPL_NETWORK_ID).await;
```

#### Handling Replication Events
#### Handling replication events

SwarmNL exposes network events to your application, allowing you to process incoming replica data effectively.

Expand All @@ -326,7 +324,7 @@ SwarmNL exposes network events to your application, allowing you to process inco

```

### Why Use SwarmNL for Replication?
### Why use SwarmNL for replication?

- **Reliability**: Ensures data integrity across multiple nodes with customizable consistency guarantees.
- **Scalability**: Handles dynamic node changes with ease, making it suitable for large distributed systems.
Expand All @@ -336,14 +334,14 @@ SwarmNL exposes network events to your application, allowing you to process inco

Sharding is a capability in distributed systems that enables networks to scale efficiently. SwarmNL provides a generic sharding functionality, allowing applications to easily partition their network and configure it for sharding.

### Key Features
### Key features

- **Customizable Sharding Algorithms**: SwarmNL supports generic interfaces that let you specify your own sharding algorithm, such as hash-based or range-based, while leveraging the full capabilities of the network.
- **Replication-Driven Sharding**: Sharding in SwarmNL is built on its replication capabilities, ensuring the library remains lightweight and highly functional.
- **Data Forwarding**: SwarmNL implements data-forwarding, allowing any node to handle requests for data stored on other nodes within any shard. Data is forwarded to the appropriate node for storage, and a network search algorithm enables retrieval from any node in any shard.
- **Integrated Application Layer Traps**: To maintain flexibility, SwarmNL permits nodes storing data to `trap` into the application layer when handling data requests. This ensures practicality and usability in real-world scenarios.

### Example: Configuring and Operating a Sharded Network
### Example: configuring and operating a sharded network

Here’s how you can set up and use SwarmNL's sharding capabilities:

Expand Down Expand Up @@ -498,7 +496,7 @@ Here’s how you can set up and use SwarmNL's sharding capabilities:
.await;
```

#### Handling Sharding Events
#### Handling sharding events

A node can receive data either through forwarding from a node in another shard or via replication from a peer node in the same shard. Below is an example demonstrating how to listen for and handle both types of events.

Expand Down Expand Up @@ -554,7 +552,7 @@ A node can receive data either through forwarding from a node in another shard o
}
```

### Why Use SwarmNL for Sharding?
### Why use SwarmNL for sharding?

SwarmNL integrates the networking and storage layers to deliver a seamless sharding experience. This approach enables nodes to interact directly with the application layer and local environment, providing a robust and flexible solution for scalable distributed systems.

Expand Down
12 changes: 7 additions & 5 deletions examples/README.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
## Tutorials
## Tutorials and examples

A collection of tutorials with running code examples that showcase the use of SwarmNl in different scenarios.

* [Echo server tutorial](/examples/echo_server/README.md): demonstrates a simple use case of setting up a node and querying the network layer.
* [File sharing application tutorial](/examples/file_sharing_app/README.md): demonstrates the use of storing records in a DHT.
* [Simple game tutorial](/examples/simple_game/README.md): demonstrates the use of gossiping messages over the network.
* [Echo server tutorial](/examples/echo-server/README.md): demonstrates a simple use case of setting up a node and querying the network layer.
* [File sharing application tutorial](/examples/file-sharing-app/README.md): demonstrates the use of storing records in a DHT.
* [Simple game tutorial](/examples/simple-game/README.md): demonstrates the use of gossiping messages over the network.
* [Sharding tutorials](/examples/sharding/README.md): demonstrates splitting a network into shards for scaling and handling communication between various nodes in a shard and across the network, including both hash-based and range-based sharding policies.
* [Replication tutorial](/examples/replication/README.md): demonstrates the replication of data across nodes specially configured to provide redundancy to the network, including peer-cloning, eventual consistency and strong consistency models.
* [Replication tutorials](/examples/replication/README.md): demonstrates the replication of data across nodes specially configured to provide redundancy to the network, including peer-cloning, eventual consistency and strong consistency models.
* [HTTP server example](/examples/http-client/README.md): send an HTTP POST request to a remote server in response to incoming replication data events.
* [IPFS example](/examples/ipfs/README.md): interact with IPFS in response to incoming replication data events.
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
[package]
name = "echo_server"
name = "echo-server"
version = "0.2.0"
edition = "2021"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
swarm_nl = { path = "../../swarm_nl", features = ["tokio-runtime"] }
swarm-nl = { path = "../../swarm-nl", features = ["tokio-runtime"] }
tokio = { version = "1.37.0", features = ["full"] }
File renamed without changes.
40 changes: 6 additions & 34 deletions examples/echo_server/README.md → examples/echo-server/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -28,50 +28,22 @@ Hit `Ctrl+D` to exit.

## Tutorial

1. Define a custom handler for application state.
1. Create an async function to set up a node using the default configuration provided by SwarmNl and specify the ports your want to use.

```rust
// 1a. Define your application state.
#[derive(Clone)]
struct EchoServer;

/// 1b. Define custom handler for application state.
impl EventHandler for EchoServer {
// We're just echoing the data back
fn rpc_incoming_message_handled(&mut self, data: Vec<Vec<u8>>) -> Vec<Vec<u8>> {
println!("Recvd incoming RPC: {:?}", data);
data
}

// Handle the incoming gossip message
fn gossipsub_incoming_message_handled(&mut self, _source: PeerId, data: Vec<String>) {
println!("Recvd incoming gossip: {:?}", data);
}
}
```

2. Create an async function to set up a node using the default configuration provided by SwarmNl and specify the ports your want to use.

```rust
// Setup the node
pub async fn setup_node(ports: (Port, Port)) -> Core<EchoServer> {
// Application state
let state = EchoServer;

/// Setup first node using default config.
pub async fn setup_node(ports: (Port, Port)) -> Core {
// Use the default config parameters and override a few configurations e.g ports, keypair
let config = BootstrapConfig::default()
.with_tcp(ports.0)
.with_udp(ports.1);

// Set up network
CoreBuilder::with_config(config, state)
.build()
.await
.unwrap()
CoreBuilder::with_config(config).build().await.unwrap()
}
```

3. Create a main function to run the server and echo lines read from stdin over the network.
2. Create a main function to run the server and echo lines read from stdin over the network.

```rust
#[tokio::main]
Expand Down Expand Up @@ -116,4 +88,4 @@ async fn main() {
}
```

The server simply creates an Echo request using [`AppData`](https://algorealminc.github.io/SwarmNL/swarm_nl/core/enum.AppData.html#variant.Echo), sends it to the network using [`query_network`](https://algorealminc.github.io/SwarmNL/swarm_nl/core/struct.Core.html#method.query_network) and prints the string received from [`AppResponse`](https://algorealminc.github.io/SwarmNL/swarm_nl/core/enum.AppResponse.html#variant.Echo) to the terminal.
The server simply creates an Echo request using [`AppData`](https://algorealminc.github.io/SwarmNL/swarm-nl/core/enum.AppData.html#variant.Echo), sends it to the network using [`query_network`](https://algorealminc.github.io/SwarmNL/swarm-nl/core/struct.Core.html#method.query_network) and prints the string received from [`AppResponse`](https://algorealminc.github.io/SwarmNL/swarm-nl/core/enum.AppResponse.html#variant.Echo) to the terminal.
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
// Copyright 2024 Algorealm, Inc.

use std::io::{self, BufRead};
/// This crate demonstrates how to use SwarmNl. Here, we build a simple echo server that
/// recieves inout from stdin, writes it to the network layer and then recieves it
/// back from the network.

use std::io::{self, BufRead};
use swarm_nl::core::{AppData, AppResponse, Core, CoreBuilder};
use swarm_nl::setup::BootstrapConfig;
use swarm_nl::Port;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
[package]
name = "file_sharing_app"
name = "file-sharing-app"
version = "0.2.0"
edition = "2021"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
rust-ini = "0.20.0"
swarm_nl = { path = "../../swarm_nl", features = ["async-std-runtime"] }
swarm-nl = { path = "../../swarm-nl", features = ["async-std-runtime"] }
async-std = { version = "1.12", features = ["attributes"] }

[features]
Expand Down
Loading
Loading