|
||
---|---|---|
.github | ||
ansible | ||
docker | ||
docs | ||
server | ||
ui | ||
.dockerignore | ||
.gitignore | ||
.travis.yml | ||
install.sh | ||
LICENSE | ||
README.md |
Lemmy
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 |
---|---|
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.
- Cross-posting support.
- Can transfer site and communities to others.
- 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?
- Lead singer from motorhead.
- The old school video game.
- The Koopa from Super Mario.
- The furry rodents.
Made with Rust, Actix, Inferno, Typescript and Diesel.
Install
Docker
Make sure you have both docker and docker-compose(>=1.24.0
) installed.
mkdir lemmy/
cd lemmy/
wget https://raw.githubusercontent.com/dessalines/lemmy/master/docker/prod/docker-compose.yml
wget https://raw.githubusercontent.com/dessalines/lemmy/master/docker/prod/.env
# Edit the .env if you want custom passwords
docker-compose up -d
and goto http://localhost:8536
A sample nginx config, could be setup with:
wget https://raw.githubusercontent.com/dessalines/lemmy/master/docker/prod/nginx.conf
# Replace the {{ vars }}
sudo mv nginx.conf /etc/nginx/sites-enabled/lemmy.conf
Ansible
First, you need to install Ansible on your local computer,
eg using sudo apt install ansible
, or the equivalent for you platform.
Then run the following commands on your local computer:
git clone https://github.com/dessalines/lemmy.git
cd lemmy/ansible/
cp inventory.example inventory
nano inventory # enter your server, domain, contact email
ansible-playbook lemmy.yml
Develop
Docker Development
git clone https://github.com/dessalines/lemmy
cd lemmy/docker/dev
./docker_update.sh # This builds and runs it, updating for your changes
and goto http://localhost:8536
Local Development
Requirements
Set up Postgres DB
psql -c "create user lemmy with password 'password' superuser;" -U postgres
psql -c 'create database lemmy with owner lemmy;' -U postgres
export DATABASE_URL=postgres://lemmy:password@localhost:5432/lemmy
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.
- Support on Patreon.
- Sponsor List.
- bitcoin:
1Hefs7miXS5ff5Ck5xvmjKjXf5242KzRtK
- ethereum:
0x400c96c96acbC6E7B3B43B1dc1BB446540a88A01
- monero:
41taVyY6e1xApqKyMVDRVxJ76sPkfZhALLTjRvVKpaAh2pBd4wv9RgYj1tSPrx8wc6iE1uWUfjtQdTmTy2FGMeChGVKPQuV
Translations
If you'd like to add translations, take a look a look at the english translation file.
- Languages supported: English (
en
), Chinese (zh
), French (fr
), Spanish (es
), Swedish (sv
), German (de
), Russian (ru
).
Credits
Icon made by Andy Cuccaro (@andycuccaro).