2022-07-11 20:01:37 +00:00
# Developer's guide
This guide assume you have some knoweldge of [ActivityPub ](https://activitypub.rocks/ ).
[TOC]
## Architecture
Microblog.pub is a "modern" Python application with "old-school" server-rendered templates.
- [Poetry ](https://python-poetry.org/ ) is used for dependency management.
- Most of the code is asynchronous, using [asyncio ](https://docs.python.org/3/library/asyncio.html ).
2022-08-31 17:31:17 +00:00
- SQLite3 for data storage
2022-07-11 20:01:37 +00:00
2022-08-28 20:21:22 +00:00
The server has 3 components:
2022-07-11 20:01:37 +00:00
- The web server (powered by [FastAPI ](https://fastapi.tiangolo.com/ ) and [Jinja2 ](https://jinja.palletsprojects.com/en/3.1.x/ ) templates)
2022-08-28 20:21:22 +00:00
- One process that takes care of sending "outgoing activities"
- One process that takes care of processing "incoming activities"
2022-07-11 20:01:37 +00:00
2022-07-11 20:06:12 +00:00
### Tasks
2022-07-11 20:01:37 +00:00
The project uses [Invoke ](https://www.pyinvoke.org/ ) to manage tasks (a Python powered Makefile).
You can find the tasks definition in `tasks.py` and list the tasks using:
```bash
inv -l
```
### Media storage
2022-08-31 17:31:17 +00:00
The uploads are stored in the `data/` directory, using a simple content-addressed storage system (file contents hash is BLOB filename).
2022-07-11 20:01:37 +00:00
Files metadata are stored in the database.
## Installation
Running a local version requires:
- Python 3.10+
- SQLite 3.35+
You can follow the [Python developer version of the install instructions ](https://docs.microblog.pub/installing.html#python-developer-edition ).
## Documentation
The documention is managed as Markdown files in `docs/` and the online documentation is built using a homegrown Python script (`scripts/build_docs.py`).
You can build the documentation locally by running:
```bash
inv build-docs
```
And check out the result by starting a static server using Python standard library:
```bash
cd docs/dist
python -m http.server 8001
```