2
0
mirror of https://github.com/ComradCollective/Comrad synced 2024-11-03 23:15:33 +00:00
Go to file
2020-08-17 14:33:26 +01:00
client fixed bizarre new screen import error 2020-08-17 14:33:26 +01:00
server profile page stuff more 2020-08-13 18:41:31 +01:00
.gitignore updating p2p 2020-08-17 11:27:11 +01:00
README.md readme 2020-08-13 19:34:03 +01:00
requirements.txt updates 2020-08-13 20:31:05 +01:00

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, 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

GIF animation

Login screen

Got this working on front and backend.

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?

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, a variant of Kivy, 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.

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.