Federated blogging application, thanks to ActivityPub
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Go to file
KitaitiMakoto 9662936b44 Merge pull request 'Update crates' (#1023) from update-crates into main
Reviewed-on: Plume/Plume#1023
2 年之前
.cargo Move Rust flag for plume-front to .cargo/config.toml from env var 3 年之前
.circleci Make Circle CI follow ructe change 2 年之前
.github Add dependabot.yml 2 年之前
assets Move bottombar styles to _article.scss 2 年之前
migrations Set null to email_blocklist table fields for SQLite 2 年之前
plume-api (cargo-release) version {{version}} 2 年之前
plume-cli (cargo-release) version {{version}} 2 年之前
plume-common Remove activitystreams from dependencies 2 年之前
plume-front Don't fill empty content when switching rich editor 2 年之前
plume-macro (cargo-release) version {{version}} 2 年之前
plume-models Remove activitystreams from dependencies 2 年之前
po Merge pull request 'Fix #1011 Add Basque' (#1013) from langs into main 2 年之前
script Update plume-buildenv Docker image to v0.4.0 2 年之前
snap Update Rust version 2 年之前
src Add Basque 2 年之前
templates Follow clippy 2 年之前
.codecov.yml Make Plume compile on release (#365) 5 年之前
.dockerignore Sample compose file and Dockerfile for deployment 6 年之前
.editorconfig Slightly improve the media experience (#452) 5 年之前
.env.sample Set default RUST_LOG to info 3 年之前
.gitignore Add SQlite journal files to .gitignore 3 年之前
CHANGELOG.md [skip ci]Add changelog 2 年之前
CODE_OF_CONDUCT.md Update some documents (#616) 5 年之前
Cargo.lock Update Cargo.lock 2 年之前
Cargo.toml Merge remote-tracking branches 'github/dependabot/cargo/ructe-0.14.0', 'github/dependabot/cargo/rsass-0.23.4' and 'github/dependabot/cargo/tracing-subscriber-0.3.8' into update-crates 2 年之前
Dockerfile Replace cargo-web with wasm-pack on build environment 3 年之前
Dockerfile.dev Revert "Remove unused diesel_cli from Docker env image" 3 年之前
LICENSE Add a license (AGPLv3) 6 年之前
README.md Make Feature list more clear 3 年之前
build.rs Follow rsass API change 2 年之前
crowdin.yml cargo release helper (again) (#835) 3 年之前
diesel.toml add sqlite migrations 6 年之前
release.toml Follow cargo-release update 2 年之前
rust-toolchain Update Rust 2 年之前

README.md

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. (Not implemented yet, but will be in 1.0)

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.