import { CID } from "multiformats/cid"; import { AtUri, normalizeDatetimeAlways } from "@atp/syntax"; import * as lex from "../../../lex/lexicons.ts"; import * as Audio from "../../../lex/types/so/sprk/sound/audio.ts"; import { BackgroundQueue } from "../../background.ts"; import { Database } from "../../db/index.ts"; import { AudioDocument } from "../../db/models.ts"; import { RecordProcessor } from "../processor.ts"; const lexId = lex.ids.SoSprkSoundAudio; type IndexedAudio = AudioDocument; const insertFn = async ( db: Database, uri: AtUri, cid: CID, obj: Audio.Record, timestamp: string, ): Promise => { const audio: Record = { uri: uri.toString(), cid: cid.toString(), authorDid: uri.host, sound: obj.sound || null, origin: obj.origin ? { uri: obj.origin.uri, cid: obj.origin.cid } : null, title: obj.title, labels: obj.labels || null, details: obj.details || null, createdAt: normalizeDatetimeAlways(obj.createdAt), indexedAt: timestamp, }; // Use findOneAndUpdate with upsert to handle potential duplicate key errors const insertedAudio = await db.models.Audio.findOneAndUpdate( { uri: audio.uri }, { $set: audio }, { upsert: true, new: true }, ); return insertedAudio; }; const findDuplicate = (): AtUri | null => { return null; }; const notifsForInsert = () => { return []; }; const deleteFn = async ( db: Database, uri: AtUri, ): Promise => { const deleted = await db.models.Audio.findOneAndDelete({ uri: uri.toString(), }); return deleted; }; const notifsForDelete = () => { return { notifs: [], toDelete: [] }; }; export type PluginType = RecordProcessor; export const makePlugin = ( db: Database, background: BackgroundQueue, ): PluginType => { return new RecordProcessor(db, background, { lexId, insertFn, findDuplicate, deleteFn, notifsForInsert, notifsForDelete, }); }; export default makePlugin;