Federated blogging application, thanks to ActivityPub
Find a file
KITAITI Makoto 847d6f7fac
Fix Atom feed (#764)
* Percent-encode URI segments in ap_url

* Fix invalid Atoms

* Remove redundant clone according to cargo clippy

* Revert "Percent-encode URI segments in ap_url"

This reverts commit 8253aa79bd.
ActivityPub(JSON-LD) accepts URI.
See https://github.com/Plume-org/Plume/pull/764#issuecomment-623105734

* Use absolute IRI for IDs in Atom

* Reuse formatted string

* Use parent element's creation date for Atom updated if there's no post

* Remove uncecessary UTC conversion

* Extract routes::build_atom_feed function
2020-05-04 15:28:52 +02:00
.circleci Build app and po files before upload pos to Crowdin (#748) 2020-04-14 20:51:53 +02:00
.github/ISSUE_TEMPLATE Update issue templates (#471) 2019-03-12 17:20:53 +01:00
assets Move stylesheets for header from _global.sccss to _header.scss (#749) 2020-04-14 23:32:27 +02:00
migrations Email blocklisting (#718) 2020-01-12 19:41:35 +01:00
plume-api Rust 2018! (#726) 2020-01-21 07:02:03 +01:00
plume-cli Rust 2018! (#726) 2020-01-21 07:02:03 +01:00
plume-common Keep atmarks and hashes in link (#765) 2020-05-03 14:50:32 +02:00
plume-front Rust 2018! (#726) 2020-01-21 07:02:03 +01:00
plume-macro Rust 2018! (#726) 2020-01-21 07:02:03 +01:00
plume-models Fix user subscription URI so that plume::routes:interact accept it (#762) 2020-05-02 12:07:45 +02:00
po Use plural form for 0 in French (#760) 2020-04-30 15:35:12 +02:00
script Bump llvm -> 9.0.0 (fixes arm builds) (#737) 2020-01-29 21:37:54 +01:00
snap Snapcraft updates (#731) 2020-01-22 14:10:49 +02:00
src Fix Atom feed (#764) 2020-05-04 15:28:52 +02:00
templates Make blocklist deletion possible (#750) 2020-04-18 11:46:10 +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
.env.sample Add a sample .env file (#687) 2019-10-30 15:38:39 +01:00
.gitignore Theming (#624) 2019-08-21 00:42:04 +02:00
build.rs Rust 2018! (#726) 2020-01-21 07:02:03 +01:00
Cargo.lock Fixes #757 Allow Unicode hashtags (#758) 2020-04-29 15:13:31 +02:00
Cargo.toml Rust 2018! (#726) 2020-01-21 07:02:03 +01: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 Add missing dep on clang needed for crate builds (#724) 2020-01-15 10:03:52 +01: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 Update compiler (#725) 2020-01-19 12:52:32 +01: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.