A self-hosted, single-user, ActivityPub powered microblog. Uses SQLite, and Python 3.10+
 
 
 
 
 
 
Go to file
Thomas Sileo d3f6397999 Add persistency to RabbitMQ via Docker 2018-05-21 13:00:17 +02:00
config
data Add persistency to RabbitMQ via Docker 2018-05-21 13:00:17 +02:00
sass
static
templates
tests Add persistency to RabbitMQ via Docker 2018-05-21 13:00:17 +02:00
utils
.dockerignore
.env
.gitignore
.travis.yml
Dockerfile
LICENSE
Makefile
README.md
activitypub.py
app.py
config.py
dev-requirements.txt
docker-compose-dev.yml
docker-compose.yml Add persistency to RabbitMQ via Docker 2018-05-21 13:00:17 +02:00
requirements.txt
setup.cfg
tasks.py

README.md

microblog.pub

microblog.pub

Build Status License

A self-hosted, single-user, ActivityPub powered microblog.

Still in early development.

Features

  • Implements a basic ActivityPub server (with federation)
    • Compatible with Mastodon and others (Pleroma, Hubzilla...)
    • Also implements a remote follow compatible with Mastodon instances
  • Exposes your outbox as a basic microblog
  • Implements IndieAuth endpoints (authorization and token endpoint)
    • U2F support
    • You can use your ActivityPub identity to login to other websites/app
  • Admin UI with notifications and the stream of people you follow
  • Allows you to attach files to your notes
    • Privacy-aware image upload endpoint that strip EXIF meta data before storing the file
  • No JavaScript, that's it, even the admin UI is pure HTML/CSS
  • Easy to customize (the theme is written Sass)
  • Microformats aware (exports h-feed, h-entry, h-cards, ...)
  • Exports RSS/Atom feeds
  • Comes with a tiny HTTP API to help posting new content and performing basic actions
  • Deployable with Docker

Running your instance

Installation

$ git clone
$ make css
$ cp -r config/me.sample.yml config/me.yml

Configuration

$ make password

Deployment

$ docker-compose up -d

Development

The most convenient way to hack on microblog.pub is to run the server locally, and run

# One-time setup
$ pip install -r requirements.txt
# Start the Celery worker, RabbitMQ and MongoDB
$ docker-compose -f docker-compose-dev.yml up -d
# Run the server locally
$ FLASK_APP=app.py flask run -p 5005 --with-threads

Contributions

PRs are welcome, please open an issue to start a discussion before your start any work.