mirror of
https://gitlab.com/soapbox-pub/ditto.git
synced 2025-12-06 03:19:46 +00:00
refactor: insert each event per iteration in for loop - db:populate-search
This commit is contained in:
parent
f99ea7c33f
commit
d7ae3722c8
1 changed files with 15 additions and 18 deletions
|
|
@ -1,12 +1,9 @@
|
|||
import { NSchema as n } from '@nostrify/nostrify';
|
||||
import { Storages } from '@/storages.ts';
|
||||
import { DittoTables } from '@/db/DittoTables.ts';
|
||||
|
||||
const store = await Storages.db();
|
||||
const kysely = await Storages.kysely();
|
||||
|
||||
const values: DittoTables['author_search'][] = [];
|
||||
|
||||
for await (const msg of store.req([{ kinds: [0] }])) {
|
||||
if (msg[0] === 'EVENT') {
|
||||
const { pubkey, content } = msg[2];
|
||||
|
|
@ -14,15 +11,11 @@ for await (const msg of store.req([{ kinds: [0] }])) {
|
|||
const { name, nip05 } = n.json().pipe(n.metadata()).catch({}).parse(content);
|
||||
const search = [name, nip05].filter(Boolean).join(' ').trim();
|
||||
|
||||
values.push({
|
||||
pubkey: pubkey,
|
||||
search,
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
try {
|
||||
await kysely.insertInto('author_search').values(values).onConflict(
|
||||
await kysely.insertInto('author_search').values({
|
||||
pubkey,
|
||||
search,
|
||||
}).onConflict(
|
||||
(oc) =>
|
||||
oc.column('pubkey')
|
||||
.doUpdateSet((eb) => ({ search: eb.ref('excluded.search') })),
|
||||
|
|
@ -31,5 +24,9 @@ try {
|
|||
} catch {
|
||||
// do nothing
|
||||
}
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
Deno.exit();
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue