2025-01-18 19:32:18 +00:00
---
title: bluesky-pds
draft: false
date: 2025-01-18
---
2025-01-18 19:35:34 +00:00
2025-01-18 20:15:56 +00:00
| | |
| ------------- | -------------------------------------------------------------------------------------------------------- |
| image | [quartz-docker image ](https://code.modernleft.org/gravityfargo/-/packages/container/bluesky-pds/latest ) |
| base project | [GitHub - bluesky-social/pds ](https://github.com/bluesky-social/pds ) |
| image source | [Forgejo - gravityfargo/bluesky-pds-docker ](https://code.modernleft.org/gravityfargo/bluesky-pds-docker ) |
| Issue Tracker | [GitHub - gravityfargo/bluesky-pds-docker ](https://github.com/gravityfargo/bluesky-pds-docker ) |
2025-01-18 19:35:34 +00:00
```bash
docker pull code.modernleft.org/gravityfargo/bluesky-pds:latest
```
2025-01-18 19:37:22 +00:00
---
2025-01-18 19:35:34 +00:00
A self-contained Docker image for the [Bluesky PDS (Personal Data Server) ](https://github.com/bluesky-social/pds ) for use with Traefik. This image is pinned to v0.4.74.
2025-01-18 19:42:18 +00:00
It is required to run the instance behind a proxy (like [Traefik ](https://doc.traefik.io/traefik/ )) to generate SSL certificates. This will not work otherwise. The standard pds install includes caddy to handle this. A wildcard DNS assignment along with a wildcard SSL certificate is required. I use Cloudflare for this, see the screenshot below.
2025-01-18 19:35:34 +00:00
This is not intended for production, and I am not responsible for any data loss or security issues. This is a personal project, and I am not affiliated with Bluesky.
2025-01-18 19:57:21 +00:00
> [!warning] Data Warning
> Before changing images, upgrading, or any other modification always backup your data!
2025-01-18 19:37:22 +00:00
2025-01-18 19:42:18 +00:00
### Requirements
2025-01-18 19:37:22 +00:00
2025-01-18 19:42:18 +00:00
I haven't verified these are the minimum requirements, but they are what I found to be necessary during development. I probably had some dependencies installed already.
2025-01-18 19:37:22 +00:00
#### Manjaro/Arch
```bash
sudo pacman -S jq
```
2025-01-18 20:07:22 +00:00
#### Debian/Ubuntu
2025-01-18 19:37:22 +00:00
```bash
sudo apt install make xxd
```
2025-01-18 19:42:18 +00:00
### Setup
2025-01-18 20:15:56 +00:00
Generate secrets and add them to `.env` file.
See [example.env ](https://code.modernleft.org/gravityfargo/bluesky-pds-docker/src/branch/main/example.env ) as an example.
2025-01-18 19:42:18 +00:00
```bash
# Generate secret environment variables
echo PDS_ADMIN_PASSWORD: $(openssl rand --hex 16)
echo PDS_JWT_SECRET: $(openssl rand --hex 16)
echo PDS_PLC_ROTATION_KEY_K256_PRIVATE_KEY_HEX: $(openssl ecparam --name secp256k1 --genkey --noout --outform DER | tail --bytes=+8 | head --bytes=32 | xxd --plain --cols 32)
```
### Docker Compose Setup
2025-01-18 20:15:56 +00:00
Full list of additional Environment Variables provided by bluesky upstream can be found in the
[packages/pds/src/config/env.ts ](https://github.com/bluesky-social/atproto/blob/main/packages/pds/src/config/env.ts )
2025-01-18 19:42:18 +00:00
2025-01-18 20:15:56 +00:00
By default, the image uses 1000:1000 as the UID:GID for the user. This can be changed by setting the `PUID` and `PGID` environment variables.
The compose element `hostname` must be the same value as `PDS_HOSTNAME` .
2025-01-18 19:42:18 +00:00
2025-01-18 19:47:22 +00:00
![[traefik]]
2025-01-18 20:25:04 +00:00
Optionally, you can use the [[middleware|BlueskyHeaders]] middleware to set headers.
---
I do not run this, but it should be possible.
2025-01-18 19:47:22 +00:00
![[standalone]]
2025-01-18 19:57:21 +00:00
2025-01-18 20:07:22 +00:00
### Running Commands
2025-01-18 20:12:18 +00:00
Nothing has changed in this department, other than not needing `sudo` . The commands are the same as the upstream project. Such as
- [Creating an account using pdsadmin ](https://github.com/bluesky-social/pds?tab=readme-ov-file#creating-an-account-using-pdsadmin )
- [Creating an account using an invite code ](https://github.com/bluesky-social/pds?tab=readme-ov-file#creating-an-account-using-an-invite-code )
2025-01-18 20:07:22 +00:00
```bash
docker exec -it bluesky-pds bash
pdsadmin account create
pdsadmin create-invite-code
```
2025-01-18 20:12:18 +00:00
> [!danger] Update Warning
2025-01-18 20:15:56 +00:00
> Do not under any circumstances update the image using `pdsadmin update`. I have not tested this, and it may break the image. Submit an
> [issue to my repository](https://github.com/gravityfargo/bluesky-pds-docker) requesting an update,
> and I will update this image and pin the pds to the new version.
2025-01-18 20:12:18 +00:00
2025-01-18 19:57:21 +00:00
### Cloudflare DNS
2025-01-18 20:07:22 +00:00
2025-01-18 20:03:58 +00:00
After various testing, I have figured out two things.
2025-01-18 20:07:22 +00:00
2025-01-18 20:03:58 +00:00
1. In order for email verification to work, you cannot have the DNS Proxy enabled or `AAAA` records active.
2. After you have verified emails, and do not intend to use the email feature, you can re-enable the DNS Proxy and `AAAA` records.
2025-01-18 20:07:22 +00:00
![[bluesky-pds-cloudflare.png]]
2025-01-18 20:22:18 +00:00
## SMTP
I use protonmail for my SMTP server. You can use any SMTP server you like, but I figured I'd share this information.
These are the environment variables I use.
```
PDS_EMAIL_SMTP_URL: smtp://user@example.com:TOKEN@smtp.protonmail.ch:587/
PDS_EMAIL_FROM_ADDRESS: user@example.com
```