refactor(backend): User関連のスキーマ/型の指定を強くする (#12808)
* refactor(backend): User関連のスキーマ/型の指定を強くする * refactor(backend): `pack()`の引数にスキーマを指定するように * chore: fix ci * fix: 変更漏れ * fix ci --------- Co-authored-by: syuilo <Syuilotan@yahoo.co.jp>
This commit is contained in:
		| @@ -62,7 +62,7 @@ export class NotificationEntityService implements OnModuleInit { | ||||
| 		}, | ||||
| 		hint?: { | ||||
| 			packedNotes: Map<MiNote['id'], Packed<'Note'>>; | ||||
| 			packedUsers: Map<MiUser['id'], Packed<'User'>>; | ||||
| 			packedUsers: Map<MiUser['id'], Packed<'UserLite'>>; | ||||
| 		}, | ||||
| 	): Promise<Packed<'Notification'>> { | ||||
| 		const notification = src; | ||||
| @@ -76,9 +76,7 @@ export class NotificationEntityService implements OnModuleInit { | ||||
| 		const userIfNeed = 'notifierId' in notification ? ( | ||||
| 			hint?.packedUsers != null | ||||
| 				? hint.packedUsers.get(notification.notifierId) | ||||
| 				: this.userEntityService.pack(notification.notifierId, { id: meId }, { | ||||
| 					detail: false, | ||||
| 				}) | ||||
| 				: this.userEntityService.pack(notification.notifierId, { id: meId }) | ||||
| 		) : undefined; | ||||
| 		const role = notification.type === 'roleAssigned' ? await this.roleEntityService.pack(notification.roleId) : undefined; | ||||
|  | ||||
| @@ -131,9 +129,7 @@ export class NotificationEntityService implements OnModuleInit { | ||||
| 		const users = userIds.length > 0 ? await this.usersRepository.find({ | ||||
| 			where: { id: In(userIds) }, | ||||
| 		}) : []; | ||||
| 		const packedUsersArray = await this.userEntityService.packMany(users, { id: meId }, { | ||||
| 			detail: false, | ||||
| 		}); | ||||
| 		const packedUsersArray = await this.userEntityService.packMany(users, { id: meId }); | ||||
| 		const packedUsers = new Map(packedUsersArray.map(p => [p.id, p])); | ||||
|  | ||||
| 		// 既に解決されたフォローリクエストの通知を除外 | ||||
| @@ -161,7 +157,7 @@ export class NotificationEntityService implements OnModuleInit { | ||||
| 		}, | ||||
| 		hint?: { | ||||
| 			packedNotes: Map<MiNote['id'], Packed<'Note'>>; | ||||
| 			packedUsers: Map<MiUser['id'], Packed<'User'>>; | ||||
| 			packedUsers: Map<MiUser['id'], Packed<'UserLite'>>; | ||||
| 		}, | ||||
| 	): Promise<Packed<'Notification'>> { | ||||
| 		const notification = src; | ||||
| @@ -175,18 +171,14 @@ export class NotificationEntityService implements OnModuleInit { | ||||
| 		const userIfNeed = 'notifierId' in notification ? ( | ||||
| 			hint?.packedUsers != null | ||||
| 				? hint.packedUsers.get(notification.notifierId) | ||||
| 				: this.userEntityService.pack(notification.notifierId, { id: meId }, { | ||||
| 					detail: false, | ||||
| 				}) | ||||
| 				: this.userEntityService.pack(notification.notifierId, { id: meId }) | ||||
| 		) : undefined; | ||||
|  | ||||
| 		if (notification.type === 'reaction:grouped') { | ||||
| 			const reactions = await Promise.all(notification.reactions.map(async reaction => { | ||||
| 				const user = hint?.packedUsers != null | ||||
| 					? hint.packedUsers.get(reaction.userId)! | ||||
| 					: await this.userEntityService.pack(reaction.userId, { id: meId }, { | ||||
| 						detail: false, | ||||
| 					}); | ||||
| 					: await this.userEntityService.pack(reaction.userId, { id: meId }); | ||||
| 				return { | ||||
| 					user, | ||||
| 					reaction: reaction.reaction, | ||||
| @@ -206,9 +198,7 @@ export class NotificationEntityService implements OnModuleInit { | ||||
| 					return packedUser; | ||||
| 				} | ||||
|  | ||||
| 				return this.userEntityService.pack(userId, { id: meId }, { | ||||
| 					detail: false, | ||||
| 				}); | ||||
| 				return this.userEntityService.pack(userId, { id: meId }); | ||||
| 			})); | ||||
| 			return await awaitAll({ | ||||
| 				id: notification.id, | ||||
| @@ -275,9 +265,7 @@ export class NotificationEntityService implements OnModuleInit { | ||||
| 		const users = userIds.length > 0 ? await this.usersRepository.find({ | ||||
| 			where: { id: In(userIds) }, | ||||
| 		}) : []; | ||||
| 		const packedUsersArray = await this.userEntityService.packMany(users, { id: meId }, { | ||||
| 			detail: false, | ||||
| 		}); | ||||
| 		const packedUsersArray = await this.userEntityService.packMany(users, { id: meId }); | ||||
| 		const packedUsers = new Map(packedUsersArray.map(p => [p.id, p])); | ||||
|  | ||||
| 		// 既に解決されたフォローリクエストの通知を除外 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 zyoshoka
					zyoshoka