Federated blogging application, thanks to ActivityPub
Find a file
Ana Gelez 309e1200d0 Make a distinction between moderators and admins (#619)
* Make a distinction between moderators and admins

And rework the user list in the moderation interface, to be able to run the same action on many users,
and to have a huge list of actions whithout loosing space.

* Make user's role an enum + make it impossible for a moderator to escalate privileges

With the help of diesel-derive-enum (maybe it could be used in other places too?)

Also, moderators are still able to grant or revoke moderation rights to other people, but maybe only admins should be able to do it?

* Cargo fmt

* copy/pasting is bad

* Remove diesel-derive-enum and use an integer instead

It was not compatible with both Postgres and SQlite, because for one it generated a schema
with the "User_role" type, but for the other it was "Text"…

* Reset translations

* Use an enum to avoid magic numbers + fix the tests

* Reset translations

* Fix down.sql
2019-09-13 12:28:36 +02:00
.circleci Fix Crowdin upload (#576) 2019-05-12 20:14:59 +01:00
.github/ISSUE_TEMPLATE Update issue templates (#471) 2019-03-12 17:20:53 +01:00
assets Make a distinction between moderators and admins (#619) 2019-09-13 12:28:36 +02:00
migrations Make a distinction between moderators and admins (#619) 2019-09-13 12:28:36 +02:00
plume-api Remove Canapi (#540) 2019-04-28 22:17:21 +01:00
plume-cli Make a distinction between moderators and admins (#619) 2019-09-13 12:28:36 +02:00
plume-common update dependancies (#643) 2019-08-14 15:04:30 +02:00
plume-front Fix issue #642, frontend not in english if the user language does not exist (#648) 2019-08-23 11:02:24 +02:00
plume-macro update dependancies (#574) 2019-05-12 10:41:47 +02:00
plume-models Make a distinction between moderators and admins (#619) 2019-09-13 12:28:36 +02:00
po Make a distinction between moderators and admins (#619) 2019-09-13 12:28:36 +02:00
script Fix arm builds (#612) 2019-06-04 19:18:36 +01:00
src Make a distinction between moderators and admins (#619) 2019-09-13 12:28:36 +02:00
templates Make a distinction between moderators and admins (#619) 2019-09-13 12:28:36 +02:00
.codecov.yml Make Plume compile on release (#365) 2018-12-22 18:27:21 +01:00
.dockerignore Sample compose file and Dockerfile for deployment 2018-09-04 00:32:47 +02:00
.editorconfig Slightly improve the media experience (#452) 2019-03-06 14:11:36 +01:00
.gitignore Theming (#624) 2019-08-21 00:42:04 +02:00
build.rs Theming (#624) 2019-08-21 00:42:04 +02:00
Cargo.lock Fix theme caching (#647) 2019-08-21 21:41:11 +02:00
Cargo.toml update dependancies (#643) 2019-08-14 15:04:30 +02:00
CODE_OF_CONDUCT.md Update some documents (#616) 2019-06-15 21:42:24 +01:00
crowdin.yml Fix Crowdin upload (#576) 2019-05-12 20:14:59 +01:00
diesel.toml add sqlite migrations 2018-09-30 14:13:52 +02:00
Dockerfile import migrations and don't require diesel_cli for admins (#555) 2019-04-29 16:30:20 +02:00
Dockerfile.dev Use multi step build to limit the docker image size (#416) 2019-01-09 17:48:18 +01:00
LICENSE Add a license (AGPLv3) 2018-05-01 13:01:38 +01:00
README.md Fix logo URL (#664) 2019-09-06 10:06:16 +02:00
rust-toolchain use circleci instead of travis (#511) 2019-04-01 20:28:23 +02:00

Plume's logo Plume

CircleCI Code coverage Docker Pulls Liberapay patrons

WebsiteDocumentationContributeInstances list

Plume is a federated blogging engine, based on ActivityPub. It is written in Rust, with the Rocket framework, and Diesel to interact with the database. The front-end uses Ructe templates, WASM and SCSS.

Features

A lot of features are still missing, but what is already here should be quite stable. Current and planned features include:

  • A blog-centric approach: you can create as much blogs as you want with your account, to keep your different publications separated.
  • Media management: you can upload pictures to illustrate your articles, but also audio files if you host a podcast, and manage them all from Plume.
  • Federation: Plume is part of a network of interconnected websites called the Fediverse. Each of these websites (often called instances) have their own rules and thematics, but they can all communicate with each other.
  • Collaborative writing: invite other people to your blogs, and write articles together.

Get involved

If you want to have regular news about the project, the best place is probably our blog, or our Matrix room: #plume:disroot.org.

If you want to contribute more, a good first step is to read our contribution guides. We accept all kind of contribution:

But this list is not exhaustive and if you want to contribute differently you are welcome too!

As we want the various spaces related to the project (GitHub, Matrix, Loomio, etc) to be as safe as possible for everyone, we adopted a code of conduct. Please read it and make sure you accept it before contributing.

Starting your own instance

We provide various way to install Plume: from source, with pre-built binaries, with Docker or with YunoHost. For detailed explanations, please refer to the documentation.