Bug fixes and some refactors
This commit is contained in:
		
							parent
							
								
									ef30390e76
								
							
						
					
					
						commit
						ba1a81dab1
					
				
					 3 changed files with 31 additions and 15 deletions
				
			
		| 
						 | 
					@ -16,8 +16,6 @@ export default async (actor: IRemoteUser, activity): Promise<void> => {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	log(`Create: ${uri}`);
 | 
						log(`Create: ${uri}`);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// TODO: 同じURIをもつものが既に登録されていないかチェック
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	const resolver = new Resolver();
 | 
						const resolver = new Resolver();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	let object;
 | 
						let object;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -4,23 +4,31 @@ import * as debug from 'debug';
 | 
				
			||||||
import Resolver from '../../resolver';
 | 
					import Resolver from '../../resolver';
 | 
				
			||||||
import Post, { IPost } from '../../../../models/post';
 | 
					import Post, { IPost } from '../../../../models/post';
 | 
				
			||||||
import createPost from '../../../../services/post/create';
 | 
					import createPost from '../../../../services/post/create';
 | 
				
			||||||
import { IRemoteUser, isRemoteUser } from '../../../../models/user';
 | 
					import { IRemoteUser } from '../../../../models/user';
 | 
				
			||||||
import resolvePerson from '../../resolve-person';
 | 
					import resolvePerson from '../../resolve-person';
 | 
				
			||||||
import createImage from './image';
 | 
					import createImage from './image';
 | 
				
			||||||
 | 
					import config from '../../../../config';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const log = debug('misskey:activitypub');
 | 
					const log = debug('misskey:activitypub');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * 投稿作成アクティビティを捌きます
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
export default async function createNote(resolver: Resolver, actor: IRemoteUser, note, silent = false): Promise<IPost> {
 | 
					export default async function createNote(resolver: Resolver, actor: IRemoteUser, note, silent = false): Promise<IPost> {
 | 
				
			||||||
	if (
 | 
						if (typeof note.id !== 'string') {
 | 
				
			||||||
		('attributedTo' in note && actor.account.uri !== note.attributedTo) ||
 | 
					 | 
				
			||||||
		typeof note.id !== 'string'
 | 
					 | 
				
			||||||
	) {
 | 
					 | 
				
			||||||
		log(`invalid note: ${JSON.stringify(note, null, 2)}`);
 | 
							log(`invalid note: ${JSON.stringify(note, null, 2)}`);
 | 
				
			||||||
		throw new Error('invalid note');
 | 
							throw new Error('invalid note');
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// 既に同じURIを持つものが登録されていないかチェックし、登録されていたらそれを返す
 | 
				
			||||||
 | 
						const exist = await Post.findOne({ uri: note.id });
 | 
				
			||||||
 | 
						if (exist) {
 | 
				
			||||||
 | 
							return exist;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	log(`Creating the Note: ${note.id}`);
 | 
						log(`Creating the Note: ${note.id}`);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						//#region 添付メディア
 | 
				
			||||||
	const media = [];
 | 
						const media = [];
 | 
				
			||||||
	if ('attachment' in note && note.attachment != null) {
 | 
						if ('attachment' in note && note.attachment != null) {
 | 
				
			||||||
		// TODO: attachmentは必ずしもImageではない
 | 
							// TODO: attachmentは必ずしもImageではない
 | 
				
			||||||
| 
						 | 
					@ -30,21 +38,31 @@ export default async function createNote(resolver: Resolver, actor: IRemoteUser,
 | 
				
			||||||
			media.push(created);
 | 
								media.push(created);
 | 
				
			||||||
		});
 | 
							});
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
						//#endregion
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						//#region リプライ
 | 
				
			||||||
	let reply = null;
 | 
						let reply = null;
 | 
				
			||||||
	if ('inReplyTo' in note && note.inReplyTo != null) {
 | 
						if ('inReplyTo' in note && note.inReplyTo != null) {
 | 
				
			||||||
		const inReplyToPost = await Post.findOne({ uri: note.inReplyTo.id || note.inReplyTo });
 | 
							// リプライ先の投稿がMisskeyに登録されているか調べる
 | 
				
			||||||
 | 
							const uri: string = note.inReplyTo.id || note.inReplyTo;
 | 
				
			||||||
 | 
							const inReplyToPost = uri.startsWith(config.url + '/')
 | 
				
			||||||
 | 
								? await Post.findOne({ _id: uri.split('/').pop() })
 | 
				
			||||||
 | 
								: await Post.findOne({ uri });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (inReplyToPost) {
 | 
							if (inReplyToPost) {
 | 
				
			||||||
			reply = inReplyToPost;
 | 
								reply = inReplyToPost;
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
 | 
								// 無かったらフェッチ
 | 
				
			||||||
			const inReplyTo = await resolver.resolve(note.inReplyTo) as any;
 | 
								const inReplyTo = await resolver.resolve(note.inReplyTo) as any;
 | 
				
			||||||
			const actor = await resolvePerson(inReplyTo.attributedTo);
 | 
					
 | 
				
			||||||
			if (isRemoteUser(actor)) {
 | 
								// リプライ先の投稿の投稿者をフェッチ
 | 
				
			||||||
				// TODO: silentを常にtrueにしてはならない
 | 
								const actor = await resolvePerson(inReplyTo.attributedTo) as IRemoteUser;
 | 
				
			||||||
				reply = await createNote(resolver, actor, inReplyTo);
 | 
					
 | 
				
			||||||
			}
 | 
								// TODO: silentを常にtrueにしてはならない
 | 
				
			||||||
 | 
								reply = await createNote(resolver, actor, inReplyTo);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
						//#endregion
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	const { window } = new JSDOM(note.content);
 | 
						const { window } = new JSDOM(note.content);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -19,11 +19,11 @@ export default async (user: IUser, post: IPost) => {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (inReplyToPost !== null) {
 | 
							if (inReplyToPost !== null) {
 | 
				
			||||||
			const inReplyToUser = await User.findOne({
 | 
								const inReplyToUser = await User.findOne({
 | 
				
			||||||
				_id: post.userId,
 | 
									_id: inReplyToPost.userId,
 | 
				
			||||||
			});
 | 
								});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (inReplyToUser !== null) {
 | 
								if (inReplyToUser !== null) {
 | 
				
			||||||
				inReplyTo = `${config.url}@${inReplyToUser.username}/${inReplyToPost._id}`;
 | 
									inReplyTo = inReplyToPost.uri || `${config.url}/@${inReplyToUser.username}/${inReplyToPost._id}`;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue