Federated blogging application, thanks to ActivityPub https://joinplu.me
Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.
 
 
 
 
 
 
Přejít na soubor
Ana Gelez f6d169567c
Introduce Searcher::new
This function does what was previously done in main:
create a search index, and try to recover for errors
if possible.

This commit also fixes plume-cli to use the new Searcher
API (that depends on a DbPool, not on a single Connection).
před 4 roky
.circleci Build app and po files before upload pos to Crowdin (#748) před 4 roky
.github/ISSUE_TEMPLATE Update issue templates (#471) před 5 roky
assets Fix title před 4 roky
migrations Email blocklisting (#718) před 4 roky
plume-api Rust 2018! (#726) před 4 roky
plume-cli Introduce Searcher::new před 4 roky
plume-common upgrade rocket* to the latest stable před 4 roky
plume-front Use result of local storage insert operation to suppress Clippy před 4 roky
plume-macro Rust 2018! (#726) před 4 roky
plume-models Introduce Searcher::new před 4 roky
po Use plural form for 0 in French (#760) před 4 roky
script Bump llvm -> 9.0.0 (fixes arm builds) (#737) před 4 roky
snap Snapcraft updates (#731) před 4 roky
src Introduce Searcher::new před 4 roky
templates Escape expressions in @Html (#767) před 4 roky
.codecov.yml Make Plume compile on release (#365) před 5 roky
.dockerignore Sample compose file and Dockerfile for deployment před 6 roky
.editorconfig Slightly improve the media experience (#452) před 5 roky
.env.sample add support for ldap před 4 roky
.gitignore Theming (#624) před 5 roky
CODE_OF_CONDUCT.md Update some documents (#616) před 5 roky
Cargo.lock add riker as dependency, we will use it to replace searcher před 4 roky
Cargo.toml upgrade rocket* to the latest stable před 4 roky
DESIGN.md finish off the strategy document před 4 roky
Dockerfile Bump Docker base images to buster flavor (#797) před 4 roky
Dockerfile.dev Bump Docker base images to buster flavor (#797) před 4 roky
LICENSE Add a license (AGPLv3) před 6 roky
README.md Fix logo URL (#664) před 5 roky
build.rs Rust 2018! (#726) před 4 roky
crowdin.yml Fix Crowdin upload (#576) před 5 roky
diesel.toml add sqlite migrations před 6 roky
rust-toolchain Update compiler (#725) před 4 roky

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.

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.