Files
remanso-jetstream/jetstream.ts
2026-02-16 22:21:21 +01:00

57 lines
1.6 KiB
TypeScript

import { Jetstream } from "@skyware/jetstream";
import { deleteNote, upsertNote } from "./src/data/db.ts";
import { Note } from "./src/data/note.ts";
import { log } from "./src/log.ts";
const jetstream = new Jetstream({
wantedCollections: ["space.remanso.note"],
});
jetstream.onCreate("space.remanso.note", (event) => {
const { did, commit: { rkey, record } } = event;
log(`[jetstream] creating ${did}/${rkey}...`);
const note = record as unknown as Omit<Note, "did" | "rkey">;
try {
upsertNote({ did, rkey, ...note });
log(`[jetstream] create ${did}/${rkey}: ${note.title}`);
} catch (error) {
log(`[jetstream] error on create ${did}/${rkey}:`, error);
}
});
jetstream.onUpdate("space.remanso.note", (event) => {
const { did, commit: { rkey, record } } = event;
log(`[jetstream] updating ${did}/${rkey}...`);
const note = record as unknown as Omit<Note, "did" | "rkey">;
try {
upsertNote({ did, rkey, ...note });
log(`[jetstream] update ${did}/${rkey}: ${note.title}`);
} catch (error) {
log(`[jetstream] error on update ${did}/${rkey}:`, error);
}
});
jetstream.onDelete("space.remanso.note", (event) => {
const { did, commit: { rkey } } = event;
log(`[jetstream] deleting ${did}/${rkey}...`);
try {
deleteNote({ did, rkey });
log(`[jetstream] delete ${did}/${rkey}`);
} catch (error) {
log(`[jetstream] error on delete ${did}/${rkey}:`, error);
}
});
jetstream.on("close", () => {
log("[jetstream] connection closed");
});
jetstream.on("error", (error) => {
log("[jetstream] connection closed with error", error);
});
log("[jetstream] launching");
jetstream.start();