import { Jetstream } from "@skyware/jetstream"; import { deleteNote, getCursor, saveCursor, upsertNote, } from "./src/data/db.ts"; import { Note } from "./src/data/note.ts"; import { log } from "./src/log.ts"; globalThis.addEventListener("unhandledrejection", (e) => { log("[jetstream] unhandled rejection:", e.reason); }); globalThis.addEventListener("error", (e) => { log("[jetstream] uncaught error:", e.error); }); const cursor = getCursor(); log(`[jetstream] starting with cursor: ${cursor ?? "none"}`); const jetstream = new Jetstream({ wantedCollections: ["space.remanso.note"], cursor: cursor ? Number(cursor) : undefined, }); jetstream.onCreate("space.remanso.note", (event) => { try { const { did, commit: { rkey, record } } = event; log(`[jetstream] creating ${did}/${rkey}...`); const note = record as unknown as Omit; upsertNote({ did, rkey, ...note }); log(`[jetstream] create ${did}/${rkey}: ${note.title}`); } catch (error) { log(`[jetstream] error on create:`, error); } }); jetstream.onUpdate("space.remanso.note", (event) => { try { const { did, commit: { rkey, record } } = event; log(`[jetstream] updating ${did}/${rkey}...`); const note = record as unknown as Omit; upsertNote({ did, rkey, ...note }); log(`[jetstream] update ${did}/${rkey}: ${note.title}`); } catch (error) { log(`[jetstream] error on update:`, error); } }); jetstream.onDelete("space.remanso.note", (event) => { try { const { did, commit: { rkey } } = event; log(`[jetstream] deleting ${did}/${rkey}...`); deleteNote({ did, rkey }); log(`[jetstream] delete ${did}/${rkey}`); } catch (error) { log(`[jetstream] error on delete:`, error); } }); jetstream.on("open", () => { log("[jetstream] connected"); }); jetstream.on("close", () => { log("[jetstream] connection closed"); }); jetstream.on("error", (error) => { log("[jetstream] connection closed with error", error); }); log("[jetstream] launching"); jetstream.start(); setInterval(() => { if (jetstream.cursor) { saveCursor(jetstream.cursor); console.log(`[jetstream] updated cursor: ${jetstream.cursor}`); } }, 5000);