Go to file
2021-02-12 14:34:32 +09:00
.circleci Update Docker image for testing 2021-02-12 13:10:32 +09:00
.github Move GitHub pull request template 2020-12-13 19:01:55 +09:00
assets Use soft tabs instead of hard tabs in SCSS files 2021-01-17 23:14:46 +09:00
migrations Email blocklisting (#718) 2020-01-12 19:41:35 +01:00
plume-api start next development iteration 2020-12-29 18:01:18 +09:00
plume-cli Remove unused lifetime 2021-01-16 12:21:49 +09:00
plume-common Build client for every inbox in broadcast() 2021-02-09 18:15:14 +09:00
plume-front Return when required element is not present 2021-02-12 05:00:42 +09:00
plume-macro Replace string range access with strip_prefix() 2021-01-16 12:20:21 +09:00
plume-models Don't panic in loop 2021-02-01 01:36:36 +09:00
po Update pot 2021-01-16 16:44:20 +09:00
script Follow file name change 2021-02-12 13:31:22 +09:00
snap Replace cargo-web with wasm-pack on build environment 2021-02-12 05:00:34 +09:00
src Move worker tasks in routes::user::details to RemoteFetchActor 2021-02-01 00:51:37 +09:00
templates Load new JavaScript file 2021-02-10 23:50:41 +09:00
.codecov.yml Make Plume compile on release (#365) 2018-12-22 18:27:21 +01:00
.dockerignore
.editorconfig Slightly improve the media experience (#452) 2019-03-06 14:11:36 +01:00
.env.sample Set default log level to warn 2021-01-31 21:58:03 +09:00
.gitignore Add SQlite journal files to .gitignore 2021-01-10 18:05:17 +09:00
build.rs Prepare JavaScript on build process 2021-02-11 01:19:32 +09:00
Cargo.lock Remove unused stdweb crate from dependencies 2021-02-12 05:00:42 +09:00
Cargo.toml Add Riker to dependencies 2021-01-16 16:20:49 +09:00
CHANGELOG.md Add changelog about (request-target) 2021-02-04 22:14:25 +09:00
CODE_OF_CONDUCT.md Update some documents (#616) 2019-06-15 21:42:24 +01:00
crowdin.yml cargo release helper (again) (#835) 2020-12-06 15:52:27 +00:00
diesel.toml add sqlite migrations 2018-09-30 14:13:52 +02:00
Dockerfile Replace cargo-web with wasm-pack on build environment 2021-02-12 05:00:34 +09:00
Dockerfile.dev Install rustfmt and cargo-clippy explicitly in dev env 2021-02-12 14:34:32 +09:00
LICENSE
README.md Fix Matrix room ID in README 2020-12-29 16:29:43 +09:00
release.toml Define tag-name for cargo-release 2020-12-19 11:24:59 +00:00
rust-toolchain Update rust-toolchain to nightly-2021-01-15 2021-01-15 10:19:12 +09: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-blog:matrix.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.