2019-04-08 05:19:02 +00:00
< h1 > < img src = "https://image.flaticon.com/icons/svg/194/194242.svg" width = "50px" height = "50px" / > Lemmy< / h1 >
2019-02-14 17:36:53 +00:00
2019-04-06 15:32:34 +00:00
[![Build Status ](https://travis-ci.org/dessalines/lemmy.svg?branch=master )](https://travis-ci.org/dessalines/lemmy)
2019-04-06 20:03:44 +00:00
[![star this repo ](http://githubbadges.com/star.svg?user=dessalines&repo=lemmy&style=flat )](https://github.com/dessalines/lemmy)
[![fork this repo ](http://githubbadges.com/fork.svg?user=dessalines&repo=lemmy&style=flat )](https://github.com/dessalines/lemmy/fork)
[![GitHub issues ](https://img.shields.io/github/issues-raw/dessalines/lemmy.svg )](https://github.com/dessalines/lemmy/issues)
![GitHub repo size ](https://img.shields.io/github/repo-size/dessalines/lemmy.svg )
[![Matrix ](https://img.shields.io/matrix/rust-reddit-fediverse:matrix.org.svg?label=matrix-chat )](https://riot.im/app/#/room/#rust-reddit-fediverse:matrix.org)
2019-04-22 20:35:51 +00:00
[![Patreon ](https://img.shields.io/badge/-Support%20on%20Patreon-blueviolet.svg )](https://www.patreon.com/dessalines)
2019-04-06 20:03:44 +00:00
[![License ](https://img.shields.io/github/license/dessalines/lemmy.svg )](LICENSE)
2019-04-06 15:32:34 +00:00
2019-04-06 17:19:05 +00:00
A link aggregator / reddit clone for the fediverse.
2019-02-14 17:36:53 +00:00
2019-04-27 13:55:12 +00:00
[Lemmy Dev instance ](https://dev.lemmy.ml ) *for testing purposes only*
2019-02-15 01:42:04 +00:00
2019-04-22 20:35:51 +00:00
This is a **very early beta version** , and a lot of features are currently broken or in active development, such as federation.
2019-04-27 00:56:33 +00:00
2019-04-27 13:55:12 +00:00
|Front Page|Post|
|-|-|
|![main screen](https://i.imgur.com/y64BtXC.png)|![chat screen](https://i.imgur.com/vsOr87q.png)|
2019-02-15 18:27:37 +00:00
2019-04-06 17:19:05 +00:00
## Features
2019-04-27 00:56:33 +00:00
2019-04-22 20:55:29 +00:00
- Open source, [AGPL License ](/LICENSE ).
2019-04-17 00:32:13 +00:00
- Self hostable, easy to deploy.
2019-04-27 13:49:50 +00:00
- Comes with [Kubernetes ](#kubernetes )
- Comes with [Docker ](#docker ).
2019-04-17 00:32:13 +00:00
- Live-updating Comment threads.
- Full vote scores `(+/-)` like old reddit.
2019-04-22 20:55:29 +00:00
- 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.
2019-04-17 00:32:13 +00:00
- High performance.
- Server is written in rust.
- Front end is `~80kB` gzipped.
2019-04-08 05:19:02 +00:00
2019-04-21 17:15:40 +00:00
## About
2019-04-27 00:56:33 +00:00
2019-04-22 20:55:29 +00:00
[Lemmy ](https://github.com/dessalines/lemmy ) is similar to sites like [Reddit ](https://reddit.com ), [Lobste.rs ](https://lobste.rs ), [Raddle ](https://raddle.me ), or [Hacker News ](https://news.ycombinator.com/ ): 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 ](https://en.wikipedia.org/wiki/Fediverse ).
2019-04-22 20:35:51 +00:00
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.
2019-04-21 17:15:40 +00:00
2019-04-16 23:04:23 +00:00
## Why's it called Lemmy?
2019-04-27 00:56:33 +00:00
2019-04-16 23:04:23 +00:00
- Lead singer from [motorhead ](https://invidio.us/watch?v=pWB5JZRGl0U ).
2019-04-27 00:56:33 +00:00
- The old school [video game ](<https://en.wikipedia.org/wiki/Lemmings_(video_game )>).
2019-04-16 23:04:23 +00:00
- The [furry rodents ](http://sunchild.fpwc.org/lemming-the-little-giant-of-the-north/ ).
2019-04-08 05:19:02 +00:00
2019-04-22 20:35:51 +00:00
Made with [Rust ](https://www.rust-lang.org ), [Actix ](https://actix.rs/ ), [Inferno ](https://www.infernojs.org ), [Typescript ](https://www.typescriptlang.org/ ) and [Diesel ](http://diesel.rs/ ).
2019-04-08 05:19:02 +00:00
2019-04-27 00:56:33 +00:00
## Usage
2019-04-27 13:49:50 +00:00
### Kubernetes
2019-04-27 00:56:33 +00:00
2019-04-27 13:49:50 +00:00
#### Requirements
2019-04-27 00:56:33 +00:00
2019-04-27 13:49:50 +00:00
- Local or remote Kubernetes cluster, i.e. [`minikube` ](https://kubernetes.io/docs/tasks/tools/install-minikube/ )
- [`kubectl` ](https://kubernetes.io/docs/tasks/tools/install-kubectl/ )
- [`skaffold` ](https://skaffold.dev/ )
2019-04-27 00:56:33 +00:00
2019-04-27 13:49:50 +00:00
#### Production
2019-04-27 00:56:33 +00:00
2019-04-27 13:49:50 +00:00
```bash
# 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
```
2019-04-27 00:56:33 +00:00
```bash
skaffold run -p lemmy--prod
2019-04-27 13:49:50 +00:00
```
2019-04-27 00:56:33 +00:00
2019-04-27 13:49:50 +00:00
Now go to http://dev.lemmy.local.
2019-04-27 00:56:33 +00:00
2019-04-27 13:49:50 +00:00
#### Development
2019-04-27 00:56:33 +00:00
```bash
skaffold dev -p lemmy--dev
```
2019-04-27 13:49:50 +00:00
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.
### Docker
Make sure you have both docker and docker-compose installed.
2019-04-27 01:39:06 +00:00
2019-04-27 13:49:50 +00:00
```
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
2019-04-27 00:56:33 +00:00
2019-04-27 13:49:50 +00:00
### Native
2019-04-27 00:56:33 +00:00
2019-04-27 13:49:50 +00:00
#### Requirements
2019-04-27 00:56:33 +00:00
2019-04-06 17:19:05 +00:00
- [Rust ](https://www.rust-lang.org/ )
- [Yarn ](https://yarnpkg.com/en/ )
- [Postgres ](https://www.sqlite.org/index.html )
2019-04-27 00:56:33 +00:00
2019-04-27 13:49:50 +00:00
#### Set up Postgres DB
2019-04-27 00:56:33 +00:00
2019-04-06 17:19:05 +00:00
```
psql -c "create user rrr with password 'rrr' superuser;" -U postgres
psql -c 'create database rrr with owner rrr;' -U postgres
```
2019-04-27 00:56:33 +00:00
2019-04-27 13:49:50 +00:00
#### Running
2019-04-27 00:56:33 +00:00
2019-04-06 17:19:05 +00:00
```
git clone https://github.com/dessalines/lemmy
cd lemmy
./install.sh
2019-04-18 16:24:24 +00:00
# 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
2019-04-06 17:19:05 +00:00
```
2019-04-27 00:56:33 +00:00
2019-04-06 23:48:54 +00:00
and goto http://localhost:8536
2019-03-30 06:08:02 +00:00
2019-04-06 17:19:05 +00:00
## Documentation
2019-04-27 00:56:33 +00:00
2019-04-06 22:49:51 +00:00
- [ActivityPub API.md ](docs/API.md )
- [Goals ](docs/goals.md )
- [Ranking Algorithm ](docs/ranking.md )
2019-03-21 01:22:31 +00:00
2019-04-17 00:32:13 +00:00
## Support
2019-04-27 00:56:33 +00:00
2019-04-24 16:28:20 +00:00
Lemmy is free, open-source software, meaning no advertising, monetizing, or venture capital, ever. Your donations directly support full-time development of the project.
2019-04-27 00:56:33 +00:00
2019-04-24 16:28:20 +00:00
- [Support on Patreon ](https://www.patreon.com/dessalines ).
- [Sponsor List ](https://dev.lemmy.ml/#/sponsors ).
2019-04-17 00:32:13 +00:00
- bitcoin: `bc1queu73nwuheqtsp65nyh5hf4jr533r8rr5nsj75`
- ethereum: `0x400c96c96acbC6E7B3B43B1dc1BB446540a88A01`
2019-04-06 22:49:51 +00:00
## Credits
Icons made by [Freepik ](https://www.freepik.com/ ) licensed by [CC 3.0 ](http://creativecommons.org/licenses/by/3.0/ )