ditto/src/storages/hydrate.ts

58 lines
1.5 KiB
TypeScript
Raw Normal View History

2024-01-24 15:46:45 -06:00
import { type NostrEvent, type NStore } from '@/deps.ts';
import { type DittoEvent } from '@/interfaces/DittoEvent.ts';
import { type DittoRelation } from '@/interfaces/DittoFilter.ts';
interface HydrateEventOpts {
events: DittoEvent[];
relations: DittoRelation[];
2024-01-23 14:06:16 -06:00
storage: NStore;
2024-01-04 02:09:23 -06:00
signal?: AbortSignal;
}
/** Hydrate event relationships using the provided storage. */
async function hydrateEvents(opts: HydrateEventOpts): Promise<DittoEvent[]> {
const { events, relations, storage, signal } = opts;
if (!events.length || !relations.length) {
return events;
}
2024-03-30 16:30:48 -05:00
for (const relation of relations) {
switch (relation) {
case 'author':
await hydrateAuthors({ events, storage, signal });
break;
}
}
return events;
}
async function hydrateAuthors(opts: Omit<HydrateEventOpts, 'relations'>): Promise<DittoEvent[]> {
const { events, storage, signal } = opts;
const pubkeys = new Set([...events].map((event) => event.pubkey));
const authors = await storage.query([{ kinds: [0], authors: [...pubkeys], limit: pubkeys.size }], { signal });
for (const event of events) {
event.author = authors.find((author) => author.pubkey === event.pubkey);
}
return events;
}
2024-01-24 15:46:45 -06:00
/** Return a normalized event without any non-standard keys. */
2024-03-16 13:19:39 -05:00
function purifyEvent(event: NostrEvent): NostrEvent {
2024-01-24 15:46:45 -06:00
return {
id: event.id,
pubkey: event.pubkey,
kind: event.kind,
content: event.content,
tags: event.tags,
sig: event.sig,
created_at: event.created_at,
};
}
export { hydrateEvents, purifyEvent };