forked from topology-foundation/ts-topology
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'topology-foundation:main' into main
- Loading branch information
Showing
32 changed files
with
506 additions
and
357 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,43 @@ | ||
# ts-topology | ||
The official TypeScript implementation of Topology Protocol | ||
<div align="center"> | ||
<img src="https://avatars.githubusercontent.com/u/157637200" height="128"> | ||
<br /> | ||
<h1>The TypeScript implementation of the Topology Protocol</h1> | ||
</div> | ||
|
||
<div align="center"> | ||
|
||
![Version](https://img.shields.io/github/package-json/v/topology-foundation/ts-topology) | ||
[![Docs](https://img.shields.io/badge/docs-page-blue)](https://topology-foundation.github.io/ts-topology/) | ||
[![License](https://img.shields.io/badge/license-MIT-green)](https://github.com/topology-foundation/ts-topology/blob/main/LICENSE) | ||
[![Issues](https://img.shields.io/badge/issues-report-red)](https://github.com/topology-foundation/ts-topology/issues) | ||
[![Pull Requests](https://img.shields.io/badge/pull_requests-open-orange)](https://github.com/topology-foundation/ts-topology/pulls) | ||
|
||
[![Website](https://img.shields.io/badge/Website-866678)](https://topology.gg) | ||
[![GitHub](https://img.shields.io/badge/GitHub-ffffff)](https://github.com/topology-foundation) | ||
[![X](https://img.shields.io/badge/X-000000)](https://x.com/topology_gg) | ||
[![Telegram](https://img.shields.io/badge/Telegram-24A1DE)](https://t.me/topologyfrens) | ||
[![Discord](https://img.shields.io/badge/Discord-7289da)](https://discord.gg/GUDGzBP5mn) | ||
</div> | ||
|
||
# Overview | ||
|
||
This is the official TypeScript implementation of the Topology Protocol. The Topology Protocol is a local-first decentralized protocol for real-time applications. It introduces a new concept for Conflict-free Replicated Objects (CRO), that are built on top of libp2p and composed of CRDTs. | ||
|
||
# Specifications | ||
|
||
The specifications of the Topology Protocol are shared across different client implementations and can be found in the [specs repository](https://github.com/topology-foundation/specs). Currently the specifications are starting to be written based on this implementation. | ||
|
||
# Packages | ||
|
||
This repository is a monorepo that contains the following packages: | ||
|
||
| Package | Description | | ||
|---------|--------------------------------------------------| | ||
| crdt | CRDT implementations intended to use as builtins | | ||
| network | Network middleware to abstract libp2p | | ||
| node | Topology Node library and CLI | | ||
| object | CRO objects structure implementation | | ||
|
||
# Examples | ||
|
||
All the examples are located in the `examples` directory. Currently, there is only one example, which is a simple canvas where you can paint pixels. You can also look into the [counter-splash](https://github.com/topology-foundation/counter-splash) (demo for EthCC 2024) repository for a more complex example. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -19,7 +19,7 @@ services: | |
dockerfile: Dockerfile | ||
ports: | ||
- 50000:50000 | ||
command: relay | ||
command: -m relay | ||
|
||
volumes: | ||
ssl_data: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
# Conflict-free Replicated Data Types (CRDTs) | ||
|
||
This package contains the CRDT implementations intended to use as builtins for the Topology Protocol. | ||
|
||
## Usage | ||
|
||
This package is intended to be used as a dependency for the Topology Protocol. However, you can use it as a standalone package. For that, you can install it using: | ||
|
||
```bash | ||
# yarn | ||
yarn add @topology-foundation/crdt | ||
|
||
# npm | ||
npm install @topology-foundation/crdt | ||
``` | ||
|
||
### Build | ||
|
||
To build the package, you can run: | ||
|
||
```bash | ||
yarn build | ||
``` | ||
|
||
### Tests | ||
|
||
To run the tests, you can run: | ||
|
||
```bash | ||
yarn test | ||
``` | ||
|
||
## CRDTs Implementations | ||
- [x] G-Counter | ||
- [x] PN-Counter | ||
- [x] G-Set | ||
- [x] 2P-Set |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,6 @@ | ||
{ | ||
"$schema": "https://typedoc.org/schema.json", | ||
"includeVersion": true, | ||
"entryPoints": ["src/index.ts"] | ||
"entryPoints": ["src/index.ts"], | ||
"readme": "README.md" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
# Topology Network Stack | ||
|
||
This package contains the network middleware to abstract libp2p for the Topology Protocol. | ||
|
||
To do so, we define a `TopologyNetworkNode` where we can pass the configs that we want and it "magically" configures libp2p and gives connectivity to the Topology Network. | ||
|
||
## Usage | ||
|
||
This package is intended to be used as a dependency for the Topology Protocol. However, you can use it as a standalone package. For that, you can install it using: | ||
|
||
```bash | ||
# yarn | ||
yarn add @topology-foundation/network | ||
|
||
# npm | ||
npm install @topology-foundation/network | ||
``` | ||
|
||
### Build | ||
|
||
To build the package, you can run: | ||
|
||
```bash | ||
yarn build | ||
``` | ||
|
||
### Tests | ||
|
||
To run the tests, you can run: | ||
|
||
```bash | ||
yarn test | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,6 @@ | ||
{ | ||
"$schema": "https://typedoc.org/schema.json", | ||
"includeVersion": true, | ||
"entryPoints": ["src/index.ts"] | ||
"entryPoints": ["src/index.ts"], | ||
"readme": "README.md" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
# Topology Node | ||
|
||
This package provides the implementation of a Topology Node, which is a node in a network that can be connected to other nodes and exchange messages with them. The Topology Node is the entrypoint for interacting with the Topology Protocol in the Topology Network. | ||
|
||
## Usage | ||
|
||
Topology Node can be used using the CLI or integrated into an existing application. | ||
|
||
### CLI | ||
|
||
The CLI provides a simple way to start a Topology Node and connect it to other nodes in the network. It can be installed globally using: | ||
|
||
```bash | ||
# yarn | ||
yarn global add @topology-foundation/node | ||
|
||
# npm | ||
npm install -g @topology-foundation/node | ||
``` | ||
|
||
> This part is a lie, the cli is being developed. | ||
For more information on what are the commands available, run: | ||
|
||
```bash | ||
topology-node --help | ||
``` | ||
|
||
### Integration | ||
|
||
To integrate the Topology Node into an existing application, you can install it using: | ||
|
||
```bash | ||
# yarn | ||
yarn add @topology-foundation/node | ||
|
||
# npm | ||
npm install @topology-foundation/node | ||
``` | ||
|
||
Then, you can import the Topology Node class and create a new instance: | ||
|
||
```javascript | ||
import { TopologyNode } from '@topology-foundation/node'; | ||
|
||
const node = new TopologyNode(); | ||
|
||
// Start the node | ||
node.start(); | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
{ | ||
"network_config": { | ||
"addresses": ["/webrtc"], | ||
"bootstrap_peers": [ | ||
"/dns4/relay.droak.sh/tcp/443/wss/p2p/Qma3GsJmB47xYuyahPZPSadh1avvxfyYQwk8R3UnFrQ6aP" | ||
] | ||
} | ||
} |
Oops, something went wrong.