🐀 Building a federated link aggregator in rust
Find a file
2019-05-15 13:50:18 -07:00
docker Adding a docker image. 2019-05-14 12:05:43 -07:00
docs Updating api.md. 2019-05-15 13:50:18 -07:00
server Enforce -1 or 1 like scores 2019-05-15 09:46:39 -07:00
ui Version bump. 2019-05-15 09:47:23 -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 Docker image now down to 35 MB, using alpine. 2019-05-13 17:46:29 -07:00
docker_db_backup.sh Adding a docker db backup script. 2019-05-13 18:52:53 -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 Adding API docs for app developers. 2019-05-15 09:04:05 -07:00
skaffold.yaml build: Minimize build time with multi-stage build, add Ingress and production versions 2019-04-27 15:49:50 +02: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 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.
  • 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 installed.

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

and goto http://localhost:8536

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

Kubernetes

Requirements

Production

# Deploy the Traefik Ingress
kubectl apply -f https://raw.githubusercontent.com/containous/traefik/v1.7/examples/k8s/traefik-rbac.yaml
kubectl apply -f https://raw.githubusercontent.com/containous/traefik/v1.7/examples/k8s/traefik-ds.yaml
# Replace ${IP} with your Ingress' IP
echo "${IP} dev.lemmy.local" >> /etc/hosts
skaffold run -p lemmy--prod

Now go to http://dev.lemmy.local.

Development

skaffold dev -p lemmy--dev

Now go to http://localhost:4444. It automatically proxies to localhost, both if the cluster is local or remote; it also hot-reloads the UI and automatically recompiles and restarts the server.

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

and goto http://localhost:8536

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.

Credits

Icons made by Freepik licensed by CC 3.0