Files
remanso-jetstream/README.md
Julien Calixte c84b4c5f97 robustness: split jetstream into own container, add cursor persistence
Jetstream was running backgrounded in the same container as the API server,
so crashes went undetected and Docker never restarted it. Now each process
runs as a separate docker-compose service with independent restart policies.

Also adds cursor persistence to SQLite (saved every 5s) so restarts resume
from where they left off, moves event destructuring inside try/catch blocks,
and adds global unhandled error/rejection handlers for crash visibility.
2026-02-17 01:17:42 +01:00

54 lines
1.2 KiB
Markdown

# litenote-jetstream
Backend for [Remanso](https://remanso.space), a blogging platform on the AT
Protocol. Listens to the Jetstream firehose for `space.remanso.note` records and
serves them via a REST API.
## Prerequisites
- [Deno](https://deno.land/)
## Setup
```bash
# Initialize the SQLite database
deno task migrate
```
## Development
```bash
# Run the Jetstream listener (with watch)
deno task jetstream
# Run the API server (with watch)
deno task server
```
## Production
```bash
# Run both processes
deno task jetstream:prod & deno task server:prod
```
### Docker
```bash
docker build -t litenote-jetstream .
docker run -p 8080:8080 -v litenote-data:/data litenote-jetstream
```
## API
| Endpoint | Description |
| -------------------------------- | ---------------------------------- |
| `GET /notes?cursor=&limit=` | Paginated notes from all users |
| `GET /:did/notes?cursor=&limit=` | Paginated notes for a specific DID |
## Environment Variables
| Variable | Default | Description |
| ------------- | ---------- | -------------------------------- |
| `SQLITE_PATH` | `notes.db` | Path to the SQLite database file |