Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/9ssi7/world.social
A truly decentralized, deployable and flexible social network
https://github.com/9ssi7/world.social
decentralized decentralized-social-networks
Last synced: about 1 month ago
JSON representation
A truly decentralized, deployable and flexible social network
- Host: GitHub
- URL: https://github.com/9ssi7/world.social
- Owner: 9ssi7
- License: apache-2.0
- Created: 2024-05-03T15:50:16.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-05-03T16:04:38.000Z (8 months ago)
- Last Synced: 2024-12-02T07:48:39.278Z (about 1 month ago)
- Topics: decentralized, decentralized-social-networks
- Homepage:
- Size: 7.81 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# world.social
## Overview
The project aims to create a decentralized social networking platform that provides users with a personalized feed curated from the accounts they follow. Unlike traditional centralized social networks, this platform is designed to be decentralized with multiple nodes serving as hubs. Users can communicate with each other directly or through these nodes, fostering a distributed and community-driven ecosystem.
## Key Features
- **Decentralized Architecture**: The platform operates on a decentralized architecture, reducing reliance on central servers and promoting user autonomy.
- **Personalized Feeds**: Users receive a customized feed comprising posts from accounts they follow, ensuring relevant content consumption.
- **Node Hierarchy**: The platform consists of main hubs akin to central offices, with subsidiary nodes branching out from them, mimicking the structure of administrative regions.
- **Inter-Node Communication**: Users can interact with each other and with nodes, facilitating seamless communication across the network.
- **Community Engagement**: Users can join communities directly or through referrals, each with its own set of rules and guidelines.
- **Trust-based Communication**: Communication between users is two-tiered, with initial interaction facilitated through the main hub and direct contact established upon mutual trust.## Components
The project comprises the following components:
1. **Main Application**: Acts as the central hub responsible for managing user data, authentication, and overall network coordination. This component's source code will be closed, ensuring the integrity and security of the core system.
2. **Subsidiary Applications**: These are auxiliary nodes connected to the main application, serving as access points for users and facilitating communication within specific regions or communities.
3. **Community Platforms**: Users can form and join communities, each with its own platform for discussion, content sharing, and collaboration. These platforms adhere to community-specific rules and guidelines.## Flow Diagrams
In the following diagrams, we illustrate the relationships between the main server, subsidiary applications, users, and communities, as well as the communication flow between these entities.
### Relationship between Main Server and Subsidiary Applications:
The main server connects to subsidiary applications, which in turn communicate with each other.
```mermaid
graph TD;
A[Main Server] -->|Connects to| B[Subsidiary Application 1];
A -->|Connects to| C[Subsidiary Application 2];
A -->|Connects to| D[Subsidiary Application 3];
B -->|Communicates with| C;
B -->|Communicates with| D;
C -->|Communicates with| D;
```### Relationship between User and Community:
Users can join communities, which are managed by the main server.
```mermaid
graph TD;
A[User] -->|Connects to| B[Main Server];
A -->|Joins| C[Community];
B -->|Defines| C;
B -->|Views| D[Other User];
D -->|Connects to| B;
```### Communication Flow:
The following sequence diagram illustrates the communication flow between a user, the main server, and another user.
```mermaid
sequenceDiagram
participant A as User
participant B as Main Server
participant C as Other User
A->>B: Communication Request
B->>A: Authentication
B->>C: Redirect to Other User
C->>B: Confirmation
B->>A: Communication Details with Other User
A->>C: Initiate Communication
```## Communication Protocol
The platform employs a secure communication protocol for interaction between nodes and users. Communication channels are encrypted to ensure privacy and security.
## Open Source
The project is open source, promoting transparency, collaboration, and community involvement. Developers are encouraged to contribute to the project by improving existing features, proposing new ideas, and addressing issues.
## Getting Started
To get started with the platform, follow these steps:
1. **Install Dependencies**: Ensure you have all the necessary dependencies installed on your system.
2. **Clone Repository**: Clone the project repository from GitHub.
3. **Set Up Environment**: Set up your development environment according to the provided guidelines.
4. **Contribute**: Contribute to the project by submitting pull requests, addressing issues, or proposing new features.## License
The project is licensed under the [Apache License, Version 2.0](LICENSE), allowing for free use, modification, and distribution.
## Support
For support or inquiries, please contact [[email protected]](mailto:[email protected]).