🐀 Building a federated link aggregator in rust
Find a file
Dessalines d7ab85ab70 Squashed commit of the following:
commit ecd6c5a2f4
Author: Dessalines <happydooby@gmail.com>
Date:   Tue Aug 13 19:49:38 2019 -0700

    Adding some docs

commit 3babd09aff
Author: Dessalines <happydooby@gmail.com>
Date:   Tue Aug 13 19:28:46 2019 -0700

    Adding save user settings

commit 6e8da9cc9e
Merge: 3246d5d c148eef
Author: Dessalines <happydooby@gmail.com>
Date:   Tue Aug 13 17:26:25 2019 -0700

    Merge branch 'dev' into nsfw

commit b3d4a5c4ce
Author: Dessalines <happydooby@gmail.com>
Date:   Sun Aug 11 20:55:09 2019 -0700

    nsfw mostly done, except for settings page.
2019-08-13 19:52:43 -07:00
.github Update FUNDING.yml 2019-06-03 09:30:35 -07:00
docker Persist docker postgres data in a volume 2019-08-12 22:02:03 -07:00
docs Squashed commit of the following: 2019-08-13 19:52:43 -07:00
server Squashed commit of the following: 2019-08-13 19:52:43 -07:00
ui Squashed commit of the following: 2019-08-13 19:52:43 -07:00
.dockerignore Adding docker. 2019-04-05 22:29:20 -07:00
.travis.yml Travis 2019-04-06 10:49:27 -07:00
docker-compose.yml Persist docker postgres data in a volume 2019-08-12 22:02:03 -07:00
docker_db_backup.sh Squashed commit of the following: 2019-08-13 19:52:43 -07:00
docker_update.sh Add shebang to scripts 2019-04-26 17:49:14 +02:00
Dockerfile Docker image now down to 35 MB, using alpine. 2019-05-13 17:46:29 -07:00
install.sh Externalizing JWT token 2019-05-02 09:55:29 -07:00
LICENSE Initial commit 2019-02-14 09:17:18 -08:00
README.md Squashed commit of the following: 2019-08-13 19:52:43 -07:00

Lemmy

GitHub tag (latest SemVer) Build Status Docker Cloud Build Status star this repo fork this repo Docker Pulls GitHub issues GitHub repo size GitHub commit activity License Mastodon Matrix Patreon

A link aggregator / reddit clone for the fediverse.

Lemmy Dev instance for testing purposes only

This is a very early beta version, and a lot of features are currently broken or in active development, such as federation.

Front Page Post
main screen chat screen

Features

  • Open source, AGPL License.
  • Self hostable, easy to deploy.
  • Live-updating Comment threads.
  • Full vote scores (+/-) like old reddit.
  • Moderation abilities.
    • Public Moderation Logs.
    • Both site admins, and community moderators, who can appoint other moderators.
    • Can lock, remove, and restore posts and comments.
    • Can ban and unban users from communities and the site.
  • Clean, mobile-friendly interface.
  • i18n / internationalization support.
  • NSFW post / community support.
  • High performance.
    • Server is written in rust.
    • Front end is ~80kB gzipped.

About

Lemmy is similar to sites like Reddit, Lobste.rs, Raddle, or Hacker News: you subscribe to forums you're interested in, post links and discussions, then vote, and comment on them. Behind the scenes, it is very different; anyone can easily run a server, and all these servers are federated (think email), and connected to the same universe, called the Fediverse.

For a link aggregator, this means a user registered on one server can subscribe to forums on any other server, and can have discussions with users registered elsewhere.

The overall goal is to create an easily self-hostable, decentralized alternative to reddit and other link aggregators, outside of their corporate control and meddling.

Each lemmy server can set its own moderation policy; appointing site-wide admins, and community moderators to keep out the trolls, and foster a healthy, non-toxic environment where all can feel comfortable contributing.

Why's it called Lemmy?

Made with Rust, Actix, Inferno, Typescript and Diesel.

Install

Docker

Make sure you have both docker and docker-compose(>=1.24.0) installed.

git clone https://github.com/dessalines/lemmy
cd lemmy/docker
docker-compose up -d

and goto http://localhost:8536

Nginx Config

location / {
  rewrite (\/(user|u|inbox|post|community|c|login|search|sponsors|communities|modlog|home)+) /static/index.html break;
  proxy_pass http://0.0.0.0:8536;
  proxy_set_header X-Real-IP $remote_addr;
  proxy_set_header Host $host;
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

  # WebSocket support
  proxy_http_version 1.1;
  proxy_set_header Upgrade $http_upgrade;
  proxy_set_header Connection "upgrade";
}

Develop

Docker Development

git clone https://github.com/dessalines/lemmy
cd lemmy
./docker_update.sh # This pulls the newest version, builds and runs it

and goto http://localhost:8536

Local Development

Requirements

Set up Postgres DB

 psql -c "create user rrr with password 'rrr' superuser;" -U postgres
 psql -c 'create database rrr with owner rrr;' -U postgres

Running

git clone https://github.com/dessalines/lemmy
cd lemmy
./install.sh
# For live coding, where both the front and back end, automagically reload on any save, do:
# cd ui && yarn start
# cd server && cargo watch -x run

Documentation

Support

Lemmy is free, open-source software, meaning no advertising, monetizing, or venture capital, ever. Your donations directly support full-time development of the project.

Translations

If you'd like to add translations, take a look a look at the english translation file.

  • Languages supported: en, zh, fr.

Credits

Icons made by Freepik licensed by CC 3.0