import renderImage from './image'; import renderKey from './key'; import config from '../../../config'; import { ILocalUser } from '../../../models/user'; import toHtml from '../../../mfm/toHtml'; import parse from '../../../mfm/parse'; import DriveFile from '../../../models/drive-file'; import { getEmojis } from './note'; import renderEmoji from './emoji'; import { IIdentifier } from '../models/identifier'; export default async (user: ILocalUser) => { const id = `${config.url}/users/${user._id}`; const [avatar, banner] = await Promise.all([ DriveFile.findOne({ _id: user.avatarId }), DriveFile.findOne({ _id: user.bannerId }) ]); const attachment: { type: string, name: string, value: string, verified_at?: string, identifier?: IIdentifier }[] = []; if (user.twitter) { attachment.push({ type: 'PropertyValue', name: 'Twitter', value: `@${user.twitter.screenName}`, identifier: { type: 'PropertyValue', name: 'misskey:authentication:twitter', value: `${user.twitter.userId}@${user.twitter.screenName}` } }); } if (user.github) { attachment.push({ type: 'PropertyValue', name: 'GitHub', value: `@${user.github.login}`, identifier: { type: 'PropertyValue', name: 'misskey:authentication:github', value: `${user.github.id}@${user.github.login}` } }); } if (user.discord) { attachment.push({ type: 'PropertyValue', name: 'Discord', value: `${user.discord.username}#${user.discord.discriminator}`, identifier: { type: 'PropertyValue', name: 'misskey:authentication:discord', value: `${user.discord.id}@${user.discord.username}#${user.discord.discriminator}` } }); } const emojis = await getEmojis(user.emojis); const apemojis = emojis.map(emoji => renderEmoji(emoji)); const tag = [ ...apemojis, ]; return { type: user.isBot ? 'Service' : 'Person', id, inbox: `${id}/inbox`, outbox: `${id}/outbox`, followers: `${id}/followers`, following: `${id}/following`, featured: `${id}/collections/featured`, sharedInbox: `${config.url}/inbox`, endpoints: { sharedInbox: `${config.url}/inbox` }, url: `${config.url}/@${user.username}`, preferredUsername: user.username, name: user.name, summary: toHtml(parse(user.description)), icon: user.avatarId && renderImage(avatar), image: user.bannerId && renderImage(banner), tag, manuallyApprovesFollowers: user.isLocked, publicKey: renderKey(user), isCat: user.isCat, attachment: attachment.length ? attachment : undefined }; };