fix(updateCredentialsController): stop overwriting kind 0 unnecessarily

This commit is contained in:
P. Reis 2024-11-29 11:49:37 -03:00
parent 45cb9757b4
commit 342ba7d4b1

View file

@ -1,4 +1,4 @@
import { NostrFilter, NSchema as n } from '@nostrify/nostrify'; import { NostrEvent, NostrFilter, NSchema as n } from '@nostrify/nostrify';
import { nip19 } from 'nostr-tools'; import { nip19 } from 'nostr-tools';
import { z } from 'zod'; import { z } from 'zod';
@ -288,59 +288,78 @@ const updateCredentialsController: AppController = async (c) => {
const pubkey = await signer.getPublicKey(); const pubkey = await signer.getPublicKey();
const body = await parseBody(c.req.raw); const body = await parseBody(c.req.raw);
const result = updateCredentialsSchema.safeParse(body); const result = updateCredentialsSchema.safeParse(body);
const store = await Storages.db();
if (!result.success) { if (!result.success) {
return c.json(result.error, 422); return c.json(result.error, 422);
} }
const event = await updateEvent( const kind0fields = {
{ kinds: [0], authors: [pubkey], limit: 1 }, avatar: result.data.avatar,
async (prev) => { header: result.data.header,
const meta = n.json().pipe(metadataSchema).catch({}).parse(prev.content); display_name: result.data.display_name,
const { fields_attributes: result.data.fields_attributes,
avatar: avatarFile, note: result.data.note,
header: headerFile, nip05: result.data.nip05,
display_name, lud16: result.data.lud16,
fields_attributes, website: result.data.website,
note, bot: result.data.bot,
nip05, };
lud16, const values = Object.values(kind0fields).filter((value) => value !== undefined);
website, let event: NostrEvent;
bot,
} = result.data;
const [avatar, header] = await Promise.all([ if (values.length) {
avatarFile ? uploadFile(c, avatarFile, { pubkey }) : undefined, event = await updateEvent(
headerFile ? uploadFile(c, headerFile, { pubkey }) : undefined, { kinds: [0], authors: [pubkey], limit: 1 },
]); async (prev) => {
const meta = n.json().pipe(metadataSchema).catch({}).parse(prev.content);
const {
avatar: avatarFile,
header: headerFile,
display_name,
fields_attributes,
note,
nip05,
lud16,
website,
bot,
} = kind0fields;
meta.name = display_name ?? meta.name; const [avatar, header] = await Promise.all([
meta.about = note ?? meta.about; avatarFile ? uploadFile(c, avatarFile, { pubkey }) : undefined,
meta.picture = avatar?.url ?? meta.picture; headerFile ? uploadFile(c, headerFile, { pubkey }) : undefined,
meta.banner = header?.url ?? meta.banner; ]);
meta.nip05 = nip05 ?? meta.nip05;
meta.lud16 = lud16 ?? meta.lud16;
meta.website = website ?? meta.website;
meta.bot = bot ?? meta.bot;
if (avatarFile === '') delete meta.picture; meta.name = display_name ?? meta.name;
if (headerFile === '') delete meta.banner; meta.about = note ?? meta.about;
if (nip05 === '') delete meta.nip05; meta.picture = avatar?.url ?? meta.picture;
if (lud16 === '') delete meta.lud16; meta.banner = header?.url ?? meta.banner;
if (website === '') delete meta.website; meta.nip05 = nip05 ?? meta.nip05;
meta.lud16 = lud16 ?? meta.lud16;
meta.website = website ?? meta.website;
meta.bot = bot ?? meta.bot;
if (fields_attributes) { if (avatarFile === '') delete meta.picture;
meta.fields = fields_attributes.map(({ name, value }) => [name, value]); if (headerFile === '') delete meta.banner;
} if (nip05 === '') delete meta.nip05;
if (lud16 === '') delete meta.lud16;
if (website === '') delete meta.website;
return { if (fields_attributes) {
kind: 0, meta.fields = fields_attributes.map(({ name, value }) => [name, value]);
content: JSON.stringify(meta), }
tags: [],
}; return {
}, kind: 0,
c, content: JSON.stringify(meta),
); tags: [],
};
},
c,
);
} else {
[event] = await store.query([{ kinds: [0], authors: [pubkey] }]);
}
const settingsStore = result.data.pleroma_settings_store; const settingsStore = result.data.pleroma_settings_store;
const account = await renderAccount(event, { withSource: true, settingsStore }); const account = await renderAccount(event, { withSource: true, settingsStore });