From c2b25bc7988c22f15f8dd1a0c305f2d4954e1bb4 Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Thu, 28 Dec 2023 00:27:25 -0600 Subject: [PATCH] queries: refactor getEvent, getAuthor --- src/queries.ts | 34 ++++++++++++++++++---------------- 1 file changed, 18 insertions(+), 16 deletions(-) diff --git a/src/queries.ts b/src/queries.ts index 48aeaf4..1388cd5 100644 --- a/src/queries.ts +++ b/src/queries.ts @@ -22,23 +22,24 @@ const getEvent = async ( const { kind, relations, signal = AbortSignal.timeout(1000) } = opts; const microfilter: IdMicrofilter = { ids: [id] }; - let event: Event | undefined; + const [memoryEvent] = await memorelay.getFilters([microfilter], opts) as Event[]; - [event] = await memorelay.getFilters([microfilter], opts); - - if (event && !relations) return event; + if (memoryEvent && !relations) { + return memoryEvent; + } const filter: DittoFilter = { ids: [id], relations, limit: 1 }; if (kind) { filter.kinds = [kind]; } - event = await mixer.getFilters([filter], { limit: 1, signal }) - .then((events) => events[0] || event); + const dbEvent = await eventsDB.getFilters([filter], { limit: 1, signal }) + .then(([event]) => event); - if (event) return event; + if (dbEvent) return dbEvent; + if (memoryEvent) return memoryEvent; - return await reqmeister.req(microfilter).catch(() => event) as Event | undefined; + return await reqmeister.req(microfilter).catch(() => undefined) as Event | undefined; }; /** Get a Nostr `set_medatadata` event for a user's pubkey. */ @@ -46,20 +47,21 @@ const getAuthor = async (pubkey: string, opts: GetEventOpts<0> = {}): Promise | undefined; + const [memoryEvent] = await memorelay.getFilters([microfilter], opts); - [event] = await memorelay.getFilters([microfilter], opts); + if (memoryEvent && !relations) { + return memoryEvent; + } - if (event && !relations) return event; - - event = await eventsDB.getFilters( + const dbEvent = await eventsDB.getFilters( [{ authors: [pubkey], relations, kinds: [0], limit: 1 }], { limit: 1, signal }, - ).then((events) => events[0] || event); + ).then(([event]) => event); - if (event) return event; + if (dbEvent) return dbEvent; + if (memoryEvent) return memoryEvent; - return reqmeister.req(microfilter).catch(() => event); + return reqmeister.req(microfilter).catch(() => undefined); }; /** Get users the given pubkey follows. */