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; 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; 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();