Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/davidbuchanan314/millipds
A from-scratch atproto PDS implementation in Python
https://github.com/davidbuchanan314/millipds
atproto atproto-pds atprotocol merkle-search-tree python python3
Last synced: 3 days ago
JSON representation
A from-scratch atproto PDS implementation in Python
- Host: GitHub
- URL: https://github.com/davidbuchanan314/millipds
- Owner: DavidBuchanan314
- License: mit
- Created: 2024-02-25T18:31:08.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2025-01-10T18:49:33.000Z (14 days ago)
- Last Synced: 2025-01-15T06:58:48.562Z (10 days ago)
- Topics: atproto, atproto-pds, atprotocol, merkle-search-tree, python, python3
- Language: Python
- Homepage:
- Size: 235 KB
- Stars: 103
- Watchers: 3
- Forks: 5
- Open Issues: 27
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# millipds [WIP]
A from-scratch atproto PDS implementation that dreams of becoming "production grade" software (it isn't, yet).millipds is a successor to [DavidBuchanan314/picopds](https://github.com/davidBuchanan314/picopds), which is even more minimalist, but hacky and no longer maintained.
It works to the extent that it can "federate" with the rest of the atproto network, but there are a lot of rough edges still. I wouldn't currently recommend using it for anything other than testing or experimentation (although, due to the nature of atproto, if you don't like it you can seamlessly migrate your whole account elsewhere). Until millipds reaches v1.0.0, I reserve the right to make breaking DB schema changes without providing a migration path.
It depends on [DavidBuchanan314/atmst](https://github.com/DavidBuchanan314/atmst) for implementing logic related to the Merkle Search Tree data structure, and [DavidBuchanan314/dag-cbrrr](https://github.com/DavidBuchanan314/dag-cbrrr) for DAG-CBOR parsing and serialisation.
See https://github.com/DavidBuchanan314/millipds/issues/12 for an incomplete list of differences between this implementation and the [reference implementation](https://github.com/bluesky-social/atproto/tree/main/packages/pds).
### Local dev install:
```sh
git clone https://github.com/DavidBuchanan314/millipds
cd millipds
python3 -m pip install -e .
```### Dockerised dev install, via podman:
(note: I have no idea what I'm doing with this!)
```sh
podman build -f millipds_dev.dockerfile -t millipds_dev
podman run --rm -it -p 8123:8123 millipds_dev
```### Production deployment on Ubuntu (and similar systems) [WIP]
See [./docs/DEPLOY.md](./docs/DEPLOY.md)
### Running the tests locally
```sh
python3 -m pip install -e .[test] # install the testing dependencies (only needed once, unless new deps are added)
python3 -m pytest . # run the tests
```