2
0
mirror of https://github.com/ComradCollective/Comrad synced 2024-11-03 23:15:33 +00:00
Comrad/README.md
quadrismegistus 037a2b4dde readme
2020-08-13 19:34:03 +01:00

121 lines
4.3 KiB
Markdown

# Komrade
Komrade is a socialist network. It is predicated on anti-capitalist and anti-racist principles of community and solidarity.
## Why another social network?
Is a 'socialist network' possible? Although the internet began with anarchic design principles, it quickly consolidated into the hands of a few of the largest corporations in the world. It has effectively recreated the capitalist mode of production within itself: the *means* of content production (social media platforms) are privatized while the *labor* of production (posting) remains socially distributed. Exploitation inheres in that relation, whether in the industrial factory or the digital platform.
But the digital platform can be redesigned. The technology behind these social media platforms is actually quite simple. We can easily build our own social network, one which is secure, insurveillable, and unmonetizable—one which would give people the security they need to communicate about whatever they want, including protesting against capital and the state.
## Features
### Your traffic is untraceable
All traffic is routed via [Tor](https://www.torproject.org/), a global maze of computers so dense that even the FBI can't trace your footsteps. And what's untraceable is also unmonetizable: your data can't be harvested by technology companies and used for advertising algorithms. You're protected from both surveillance capitalism and the surveillance state.
### Be as anonymous as you wish
Design a profile and account which is as anonymous as you want to make it. If you don't reveal yourself, your traffic or behavior elsewhere on the internet won't either.
### Best of what's out there
We present a simplified set of social media features drawn from everything that's out there and then some:
* Profile
* Curate a profile with photo and posts (e.g. Twitter)
* Show profile to world (e.g. Twitter)
* Show profile only to friends (e.g. Facebook)
* Show profile only to your local area (e.g. Nextdoor)
* Posting
* Post up to 1 image and/or 1000 characters
* Post to the entire world (e.g. Twitter)
* Post to your friends (e.g. Facebook)
* Post to your surrounding area by a distance radius (e.g. Nextdoor)
* Anonymously up-vote or down-vote posts (e.g. Reddit)
* Post anonymously or from your account (new)
* Organizing
* Host events and invite others (e.g. Facebook)
* Host events like protests anonymously (new)
* Anonymously pin on a map sites of danger, like police (e.g. Waze)
* Messaging
* Message securely with encrypted contents (e.g. Signal)
* Message securely with untraceable metadata (new)
### Open-source and community run
Not just non-profit, we're anti-profit.
## Progress
### Screens
#### Preview animation
<img src="client/assets/komrade-peek-2.gif" height="600" alt="GIF animation" />
#### Login screen
Got this working on front and backend.
<img src="client/assets/screen-login.png" height="600" alt="Login screen" />
#### Post
Experimenting with posts as 'cards', kind of like Tinder, which you can swipe up to up-vote or amplify, swipe down to down-vote or dampen, swipe left to see the next card and swipe right to see the previous. A horizontal feed basically. One image or video allowed; up to 1000? words allowed; maybe a title?
<img src="client/assets/screen-feed.png" height="600" alt="Post screen" />
## Technical details
Design details are changing rapidly, but these are what we have so far.
### App
The 'client' or app is made with [KivyMD](https://github.com/kivymd/KivyMD), a variant of [Kivy](https://kivy.org/), a cross-platform mobile development framework in Python. Python is an easy and versatile progamming language to learn, which keeps the code accessible to as many people as possible.
### Server
The server also runs on Python, serving a graph database powered by [Neo4j](https://neo4j.com/).
## Install
### As developer
The usual installation:
```
git clone https://github.com/quadrismegistus/Komrade.git
cd Komrade
pip install -r requirements.txt
```
Then run the client:
```
cd client
./run.sh
```
This is configured to use my server. Optionally, you can run your own server:
```
cd server
./run.sh
```
Change the SERVER_ADDR constant at the top of client/main.py to point to your server. You will need neo4j installed. You will also need to change the neo4j login configuration at the top of server/models.py.
### As user
Coming soon.