refactor: fix types
This commit is contained in:
		| @@ -5,7 +5,7 @@ import type { Config } from '@/config.js'; | ||||
| import type { DriveFile } from '@/models/entities/DriveFile.js'; | ||||
| import type { MessagingMessage } from '@/models/entities/MessagingMessage.js'; | ||||
| import type { Note } from '@/models/entities/Note.js'; | ||||
| import type { User, CacheableUser, IRemoteUser } from '@/models/entities/User.js'; | ||||
| import type { User, IRemoteUser } from '@/models/entities/User.js'; | ||||
| import type { UserGroup } from '@/models/entities/UserGroup.js'; | ||||
| import { QueueService } from '@/core/QueueService.js'; | ||||
| import { toArray } from '@/misc/prelude/array.js'; | ||||
| @@ -48,7 +48,7 @@ export class MessagingService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async createMessage(user: { id: User['id']; host: User['host']; }, recipientUser: CacheableUser | undefined, recipientGroup: UserGroup | undefined, text: string | null | undefined, file: DriveFile | null, uri?: string) { | ||||
| 	public async createMessage(user: { id: User['id']; host: User['host']; }, recipientUser: User | undefined, recipientGroup: UserGroup | undefined, text: string | null | undefined, file: DriveFile | null, uri?: string) { | ||||
| 		const message = { | ||||
| 			id: this.idService.genId(), | ||||
| 			createdAt: new Date(), | ||||
|   | ||||
| @@ -1,10 +1,9 @@ | ||||
| import { Inject, Injectable } from '@nestjs/common'; | ||||
| import { Not } from 'typeorm'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import type { NotesRepository, UsersRepository, PollsRepository, PollVotesRepository } from '@/models/index.js'; | ||||
| import type { NotesRepository, UsersRepository, PollsRepository, PollVotesRepository, User } from '@/models/index.js'; | ||||
| import type { Note } from '@/models/entities/Note.js'; | ||||
| import { RelayService } from '@/core/RelayService.js'; | ||||
| import type { CacheableUser } from '@/models/entities/User.js'; | ||||
| import { IdService } from '@/core/IdService.js'; | ||||
| import { GlobalEventService } from '@/core/GlobalEventService.js'; | ||||
| import { ApRendererService } from '@/core/activitypub/ApRendererService.js'; | ||||
| @@ -39,7 +38,7 @@ export class PollService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async vote(user: CacheableUser, note: Note, choice: number) { | ||||
| 	public async vote(user: User, note: Note, choice: number) { | ||||
| 		const poll = await this.pollsRepository.findOneBy({ noteId: note.id }); | ||||
| 	 | ||||
| 		if (poll == null) throw new Error('poll not found'); | ||||
|   | ||||
| @@ -3,7 +3,7 @@ import Redis from 'ioredis'; | ||||
| import { In } from 'typeorm'; | ||||
| import type { Role, RoleAssignment, RoleAssignmentsRepository, RolesRepository, UsersRepository } from '@/models/index.js'; | ||||
| import { Cache } from '@/misc/cache.js'; | ||||
| import type { CacheableLocalUser, CacheableUser, ILocalUser, User } from '@/models/entities/User.js'; | ||||
| import type { User } from '@/models/entities/User.js'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| import { MetaService } from '@/core/MetaService.js'; | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
| import { Inject, Injectable, OnApplicationShutdown } from '@nestjs/common'; | ||||
| import Redis from 'ioredis'; | ||||
| import { IdService } from '@/core/IdService.js'; | ||||
| import type { CacheableUser, User } from '@/models/entities/User.js'; | ||||
| import type { User } from '@/models/entities/User.js'; | ||||
| import type { Blocking } from '@/models/entities/Blocking.js'; | ||||
| import { QueueService } from '@/core/QueueService.js'; | ||||
| import { GlobalEventService } from '@/core/GlobalEventService.js'; | ||||
| @@ -236,7 +236,7 @@ export class UserBlockingService implements OnApplicationShutdown { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async unblock(blocker: CacheableUser, blockee: CacheableUser) { | ||||
| 	public async unblock(blocker: User, blockee: User) { | ||||
| 		const blocking = await this.blockingsRepository.findOneBy({ | ||||
| 			blockerId: blocker.id, | ||||
| 			blockeeId: blockee.id, | ||||
|   | ||||
| @@ -2,7 +2,7 @@ import { Inject, Injectable } from '@nestjs/common'; | ||||
| import Redis from 'ioredis'; | ||||
| import type { UsersRepository } from '@/models/index.js'; | ||||
| import { Cache } from '@/misc/cache.js'; | ||||
| import type { CacheableLocalUser, CacheableUser, ILocalUser, User } from '@/models/entities/User.js'; | ||||
| import type { ILocalUser, User } from '@/models/entities/User.js'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import { UserEntityService } from '@/core/entities/UserEntityService.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| @@ -11,10 +11,10 @@ import type { OnApplicationShutdown } from '@nestjs/common'; | ||||
|  | ||||
| @Injectable() | ||||
| export class UserCacheService implements OnApplicationShutdown { | ||||
| 	public userByIdCache: Cache<CacheableUser>; | ||||
| 	public localUserByNativeTokenCache: Cache<CacheableLocalUser | null>; | ||||
| 	public localUserByIdCache: Cache<CacheableLocalUser>; | ||||
| 	public uriPersonCache: Cache<CacheableUser | null>; | ||||
| 	public userByIdCache: Cache<User>; | ||||
| 	public localUserByNativeTokenCache: Cache<ILocalUser | null>; | ||||
| 	public localUserByIdCache: Cache<ILocalUser>; | ||||
| 	public uriPersonCache: Cache<User | null>; | ||||
|  | ||||
| 	constructor( | ||||
| 		@Inject(DI.redisSubscriber) | ||||
| @@ -27,10 +27,10 @@ export class UserCacheService implements OnApplicationShutdown { | ||||
| 	) { | ||||
| 		//this.onMessage = this.onMessage.bind(this); | ||||
|  | ||||
| 		this.userByIdCache = new Cache<CacheableUser>(Infinity); | ||||
| 		this.localUserByNativeTokenCache = new Cache<CacheableLocalUser | null>(Infinity); | ||||
| 		this.localUserByIdCache = new Cache<CacheableLocalUser>(Infinity); | ||||
| 		this.uriPersonCache = new Cache<CacheableUser | null>(Infinity); | ||||
| 		this.userByIdCache = new Cache<User>(Infinity); | ||||
| 		this.localUserByNativeTokenCache = new Cache<ILocalUser | null>(Infinity); | ||||
| 		this.localUserByIdCache = new Cache<ILocalUser>(Infinity); | ||||
| 		this.uriPersonCache = new Cache<User | null>(Infinity); | ||||
|  | ||||
| 		this.redisSubscriber.on('message', this.onMessage); | ||||
| 	} | ||||
| @@ -45,10 +45,10 @@ export class UserCacheService implements OnApplicationShutdown { | ||||
| 				case 'userChangeSuspendedState': | ||||
| 				case 'remoteUserUpdated': { | ||||
| 					const user = await this.usersRepository.findOneByOrFail({ id: body.id }); | ||||
| 					this.userByIdCache.set(user.id, user as CacheableUser); | ||||
| 					this.userByIdCache.set(user.id, user); | ||||
| 					for (const [k, v] of this.uriPersonCache.cache.entries()) { | ||||
| 						if (v.value?.id === user.id) { | ||||
| 							this.uriPersonCache.set(k, user as CacheableUser); | ||||
| 							this.uriPersonCache.set(k, user); | ||||
| 						} | ||||
| 					} | ||||
| 					if (this.userEntityService.isLocalUser(user)) { | ||||
| @@ -78,7 +78,7 @@ export class UserCacheService implements OnApplicationShutdown { | ||||
|  | ||||
| 	@bindThis | ||||
| 	public findById(userId: User['id']) { | ||||
| 		return this.userByIdCache.fetch(userId, () => this.usersRepository.findOneByOrFail({ id: userId }) as Promise<CacheableUser>); | ||||
| 		return this.userByIdCache.fetch(userId, () => this.usersRepository.findOneByOrFail({ id: userId })); | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| import { Inject, Injectable } from '@nestjs/common'; | ||||
| import type { CacheableUser, ILocalUser, IRemoteUser, User } from '@/models/entities/User.js'; | ||||
| import type { ILocalUser, IRemoteUser, User } from '@/models/entities/User.js'; | ||||
| import { IdentifiableError } from '@/misc/identifiable-error.js'; | ||||
| import { QueueService } from '@/core/QueueService.js'; | ||||
| import PerUserFollowingChart from '@/core/chart/charts/per-user-following.js'; | ||||
| @@ -434,7 +434,7 @@ export class UserFollowingService { | ||||
| 		followee: { | ||||
| 			id: User['id']; host: User['host']; uri: User['host']; inbox: User['inbox']; sharedInbox: User['sharedInbox']; | ||||
| 		}, | ||||
| 		follower: User | CacheableUser, | ||||
| 		follower: User, | ||||
| 	): Promise<void> { | ||||
| 		const request = await this.followRequestsRepository.findOneBy({ | ||||
| 			followeeId: followee.id, | ||||
|   | ||||
| @@ -2,7 +2,7 @@ import { Inject, Injectable } from '@nestjs/common'; | ||||
| import { In } from 'typeorm'; | ||||
| import promiseLimit from 'promise-limit'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import type { CacheableRemoteUser, CacheableUser } from '@/models/entities/User.js'; | ||||
| import type { IRemoteUser, User } from '@/models/entities/User.js'; | ||||
| import { concat, toArray, toSingle, unique } from '@/misc/prelude/array.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| import { getApId, getApIds, getApType, isAccept, isActor, isAdd, isAnnounce, isBlock, isCollection, isCollectionOrOrderedCollection, isCreate, isDelete, isFlag, isFollow, isLike, isPost, isRead, isReject, isRemove, isTombstone, isUndo, isUpdate, validActor, validPost } from './type.js'; | ||||
| @@ -14,8 +14,8 @@ type Visibility = 'public' | 'home' | 'followers' | 'specified'; | ||||
|  | ||||
| type AudienceInfo = { | ||||
| 	visibility: Visibility, | ||||
| 	mentionedUsers: CacheableUser[], | ||||
| 	visibleUsers: CacheableUser[], | ||||
| 	mentionedUsers: User[], | ||||
| 	visibleUsers: User[], | ||||
| }; | ||||
|  | ||||
| @Injectable() | ||||
| @@ -26,16 +26,16 @@ export class ApAudienceService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async parseAudience(actor: CacheableRemoteUser, to?: ApObject, cc?: ApObject, resolver?: Resolver): Promise<AudienceInfo> { | ||||
| 	public async parseAudience(actor: IRemoteUser, to?: ApObject, cc?: ApObject, resolver?: Resolver): Promise<AudienceInfo> { | ||||
| 		const toGroups = this.groupingAudience(getApIds(to), actor); | ||||
| 		const ccGroups = this.groupingAudience(getApIds(cc), actor); | ||||
| 	 | ||||
| 		const others = unique(concat([toGroups.other, ccGroups.other])); | ||||
| 	 | ||||
| 		const limit = promiseLimit<CacheableUser | null>(2); | ||||
| 		const limit = promiseLimit<User | null>(2); | ||||
| 		const mentionedUsers = (await Promise.all( | ||||
| 			others.map(id => limit(() => this.apPersonService.resolvePerson(id, resolver).catch(() => null))), | ||||
| 		)).filter((x): x is CacheableUser => x != null); | ||||
| 		)).filter((x): x is User => x != null); | ||||
| 	 | ||||
| 		if (toGroups.public.length > 0) { | ||||
| 			return { | ||||
| @@ -69,7 +69,7 @@ export class ApAudienceService { | ||||
| 	} | ||||
| 	 | ||||
| 	@bindThis | ||||
| 	private groupingAudience(ids: string[], actor: CacheableRemoteUser) { | ||||
| 	private groupingAudience(ids: string[], actor: IRemoteUser) { | ||||
| 		const groups = { | ||||
| 			public: [] as string[], | ||||
| 			followers: [] as string[], | ||||
| @@ -101,7 +101,7 @@ export class ApAudienceService { | ||||
| 	} | ||||
| 	 | ||||
| 	@bindThis | ||||
| 	private isFollowers(id: string, actor: CacheableRemoteUser) { | ||||
| 	private isFollowers(id: string, actor: IRemoteUser) { | ||||
| 		return ( | ||||
| 			id === (actor.followersUri ?? `${actor.uri}/followers`) | ||||
| 		); | ||||
|   | ||||
| @@ -3,13 +3,13 @@ import escapeRegexp from 'escape-regexp'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import type { MessagingMessagesRepository, NotesRepository, UserPublickeysRepository, UsersRepository } from '@/models/index.js'; | ||||
| import type { Config } from '@/config.js'; | ||||
| import type { CacheableRemoteUser, CacheableUser } from '@/models/entities/User.js'; | ||||
| import { Cache } from '@/misc/cache.js'; | ||||
| import type { UserPublickey } from '@/models/entities/UserPublickey.js'; | ||||
| import { UserCacheService } from '@/core/UserCacheService.js'; | ||||
| import type { Note } from '@/models/entities/Note.js'; | ||||
| import type { MessagingMessage } from '@/models/entities/MessagingMessage.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| import { IRemoteUser, User } from '@/models/entities/User.js'; | ||||
| import { getApId } from './type.js'; | ||||
| import { ApPersonService } from './models/ApPersonService.js'; | ||||
| import type { IObject } from './type.js'; | ||||
| @@ -122,7 +122,7 @@ export class ApDbResolverService { | ||||
| 	 * AP Person => Misskey User in DB | ||||
| 	 */ | ||||
| 	@bindThis | ||||
| 	public async getUserFromApId(value: string | IObject): Promise<CacheableUser | null> { | ||||
| 	public async getUserFromApId(value: string | IObject): Promise<User | null> { | ||||
| 		const parsed = this.parseUri(value); | ||||
|  | ||||
| 		if (parsed.local) { | ||||
| @@ -130,11 +130,11 @@ export class ApDbResolverService { | ||||
|  | ||||
| 			return await this.userCacheService.userByIdCache.fetchMaybe(parsed.id, () => this.usersRepository.findOneBy({ | ||||
| 				id: parsed.id, | ||||
| 			}).then(x => (x as CacheableUser | null) ?? undefined)) ?? null; | ||||
| 			}).then(x => x ?? undefined)) ?? null; | ||||
| 		} else { | ||||
| 			return await this.userCacheService.uriPersonCache.fetch(parsed.uri, () => this.usersRepository.findOneBy({ | ||||
| 				uri: parsed.uri, | ||||
| 			}) as Promise<CacheableUser | null>); | ||||
| 			})); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -143,7 +143,7 @@ export class ApDbResolverService { | ||||
| 	 */ | ||||
| 	@bindThis | ||||
| 	public async getAuthUserFromKeyId(keyId: string): Promise<{ | ||||
| 		user: CacheableRemoteUser; | ||||
| 		user: IRemoteUser; | ||||
| 		key: UserPublickey; | ||||
| 	} | null> { | ||||
| 		const key = await this.publicKeyCache.fetch(keyId, async () => { | ||||
| @@ -159,7 +159,7 @@ export class ApDbResolverService { | ||||
| 		if (key == null) return null; | ||||
|  | ||||
| 		return { | ||||
| 			user: await this.userCacheService.findById(key.userId) as CacheableRemoteUser, | ||||
| 			user: await this.userCacheService.findById(key.userId) as IRemoteUser, | ||||
| 			key, | ||||
| 		}; | ||||
| 	} | ||||
| @@ -169,10 +169,10 @@ export class ApDbResolverService { | ||||
| 	 */ | ||||
| 	@bindThis | ||||
| 	public async getAuthUserFromApId(uri: string): Promise<{ | ||||
| 		user: CacheableRemoteUser; | ||||
| 		user: IRemoteUser; | ||||
| 		key: UserPublickey | null; | ||||
| 	} | null> { | ||||
| 		const user = await this.apPersonService.resolvePerson(uri) as CacheableRemoteUser; | ||||
| 		const user = await this.apPersonService.resolvePerson(uri) as IRemoteUser; | ||||
|  | ||||
| 		if (user == null) return null; | ||||
|  | ||||
|   | ||||
| @@ -2,7 +2,6 @@ import { Inject, Injectable } from '@nestjs/common'; | ||||
| import { In } from 'typeorm'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import type { Config } from '@/config.js'; | ||||
| import type { CacheableRemoteUser, CacheableUser } from '@/models/entities/User.js'; | ||||
| import { UserFollowingService } from '@/core/UserFollowingService.js'; | ||||
| import { ReactionService } from '@/core/ReactionService.js'; | ||||
| import { RelayService } from '@/core/RelayService.js'; | ||||
| @@ -23,6 +22,7 @@ import { QueueService } from '@/core/QueueService.js'; | ||||
| import { MessagingService } from '@/core/MessagingService.js'; | ||||
| import type { UsersRepository, NotesRepository, FollowingsRepository, MessagingMessagesRepository, AbuseUserReportsRepository, FollowRequestsRepository } from '@/models/index.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| import type { IRemoteUser } from '@/models/entities/User.js'; | ||||
| import { getApId, getApIds, getApType, isAccept, isActor, isAdd, isAnnounce, isBlock, isCollection, isCollectionOrOrderedCollection, isCreate, isDelete, isFlag, isFollow, isLike, isPost, isRead, isReject, isRemove, isTombstone, isUndo, isUpdate, validActor, validPost } from './type.js'; | ||||
| import { ApNoteService } from './models/ApNoteService.js'; | ||||
| import { ApLoggerService } from './ApLoggerService.js'; | ||||
| @@ -87,7 +87,7 @@ export class ApInboxService { | ||||
| 	} | ||||
| 	 | ||||
| 	@bindThis | ||||
| 	public async performActivity(actor: CacheableRemoteUser, activity: IObject) { | ||||
| 	public async performActivity(actor: IRemoteUser, activity: IObject) { | ||||
| 		if (isCollectionOrOrderedCollection(activity)) { | ||||
| 			const resolver = this.apResolverService.createResolver(); | ||||
| 			for (const item of toArray(isCollection(activity) ? activity.items : activity.orderedItems)) { | ||||
| @@ -115,7 +115,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async performOneActivity(actor: CacheableRemoteUser, activity: IObject): Promise<void> { | ||||
| 	public async performOneActivity(actor: IRemoteUser, activity: IObject): Promise<void> { | ||||
| 		if (actor.isSuspended) return; | ||||
|  | ||||
| 		if (isCreate(activity)) { | ||||
| @@ -152,7 +152,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async follow(actor: CacheableRemoteUser, activity: IFollow): Promise<string> { | ||||
| 	private async follow(actor: IRemoteUser, activity: IFollow): Promise<string> { | ||||
| 		const followee = await this.apDbResolverService.getUserFromApId(activity.object); | ||||
| 	 | ||||
| 		if (followee == null) { | ||||
| @@ -168,7 +168,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async like(actor: CacheableRemoteUser, activity: ILike): Promise<string> { | ||||
| 	private async like(actor: IRemoteUser, activity: ILike): Promise<string> { | ||||
| 		const targetUri = getApId(activity.object); | ||||
|  | ||||
| 		const note = await this.apNoteService.fetchNote(targetUri); | ||||
| @@ -186,7 +186,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async read(actor: CacheableRemoteUser, activity: IRead): Promise<string> { | ||||
| 	private async read(actor: IRemoteUser, activity: IRead): Promise<string> { | ||||
| 		const id = await getApId(activity.object); | ||||
|  | ||||
| 		if (!this.utilityService.isSelfHost(this.utilityService.extractDbHost(id))) { | ||||
| @@ -209,7 +209,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async accept(actor: CacheableRemoteUser, activity: IAccept): Promise<string> { | ||||
| 	private async accept(actor: IRemoteUser, activity: IAccept): Promise<string> { | ||||
| 		const uri = activity.id ?? activity; | ||||
|  | ||||
| 		this.logger.info(`Accept: ${uri}`); | ||||
| @@ -227,7 +227,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async acceptFollow(actor: CacheableRemoteUser, activity: IFollow): Promise<string> { | ||||
| 	private async acceptFollow(actor: IRemoteUser, activity: IFollow): Promise<string> { | ||||
| 		// ※ activityはこっちから投げたフォローリクエストなので、activity.actorは存在するローカルユーザーである必要がある | ||||
|  | ||||
| 		const follower = await this.apDbResolverService.getUserFromApId(activity.actor); | ||||
| @@ -251,7 +251,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async add(actor: CacheableRemoteUser, activity: IAdd): Promise<void> { | ||||
| 	private async add(actor: IRemoteUser, activity: IAdd): Promise<void> { | ||||
| 		if ('actor' in activity && actor.uri !== activity.actor) { | ||||
| 			throw new Error('invalid actor'); | ||||
| 		} | ||||
| @@ -271,7 +271,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async announce(actor: CacheableRemoteUser, activity: IAnnounce): Promise<void> { | ||||
| 	private async announce(actor: IRemoteUser, activity: IAnnounce): Promise<void> { | ||||
| 		const uri = getApId(activity); | ||||
|  | ||||
| 		this.logger.info(`Announce: ${uri}`); | ||||
| @@ -282,7 +282,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async announceNote(actor: CacheableRemoteUser, activity: IAnnounce, targetUri: string): Promise<void> { | ||||
| 	private async announceNote(actor: IRemoteUser, activity: IAnnounce, targetUri: string): Promise<void> { | ||||
| 		const uri = getApId(activity); | ||||
|  | ||||
| 		if (actor.isSuspended) { | ||||
| @@ -342,7 +342,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async block(actor: CacheableRemoteUser, activity: IBlock): Promise<string> { | ||||
| 	private async block(actor: IRemoteUser, activity: IBlock): Promise<string> { | ||||
| 		// ※ activity.objectにブロック対象があり、それは存在するローカルユーザーのはず | ||||
|  | ||||
| 		const blockee = await this.apDbResolverService.getUserFromApId(activity.object); | ||||
| @@ -360,7 +360,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async create(actor: CacheableRemoteUser, activity: ICreate): Promise<void> { | ||||
| 	private async create(actor: IRemoteUser, activity: ICreate): Promise<void> { | ||||
| 		const uri = getApId(activity); | ||||
|  | ||||
| 		this.logger.info(`Create: ${uri}`); | ||||
| @@ -396,7 +396,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async createNote(resolver: Resolver, actor: CacheableRemoteUser, note: IObject, silent = false, activity?: ICreate): Promise<string> { | ||||
| 	private async createNote(resolver: Resolver, actor: IRemoteUser, note: IObject, silent = false, activity?: ICreate): Promise<string> { | ||||
| 		const uri = getApId(note); | ||||
|  | ||||
| 		if (typeof note === 'object') { | ||||
| @@ -431,7 +431,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async delete(actor: CacheableRemoteUser, activity: IDelete): Promise<string> { | ||||
| 	private async delete(actor: IRemoteUser, activity: IDelete): Promise<string> { | ||||
| 		if ('actor' in activity && actor.uri !== activity.actor) { | ||||
| 			throw new Error('invalid actor'); | ||||
| 		} | ||||
| @@ -473,7 +473,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async deleteActor(actor: CacheableRemoteUser, uri: string): Promise<string> { | ||||
| 	private async deleteActor(actor: IRemoteUser, uri: string): Promise<string> { | ||||
| 		this.logger.info(`Deleting the Actor: ${uri}`); | ||||
| 	 | ||||
| 		if (actor.uri !== uri) { | ||||
| @@ -495,7 +495,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async deleteNote(actor: CacheableRemoteUser, uri: string): Promise<string> { | ||||
| 	private async deleteNote(actor: IRemoteUser, uri: string): Promise<string> { | ||||
| 		this.logger.info(`Deleting the Note: ${uri}`); | ||||
| 	 | ||||
| 		const unlock = await this.appLockService.getApLock(uri); | ||||
| @@ -528,7 +528,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async flag(actor: CacheableRemoteUser, activity: IFlag): Promise<string> { | ||||
| 	private async flag(actor: IRemoteUser, activity: IFlag): Promise<string> { | ||||
| 		// objectは `(User|Note) | (User|Note)[]` だけど、全パターンDBスキーマと対応させられないので | ||||
| 		// 対象ユーザーは一番最初のユーザー として あとはコメントとして格納する | ||||
| 		const uris = getApIds(activity.object); | ||||
| @@ -553,7 +553,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async reject(actor: CacheableRemoteUser, activity: IReject): Promise<string> { | ||||
| 	private async reject(actor: IRemoteUser, activity: IReject): Promise<string> { | ||||
| 		const uri = activity.id ?? activity; | ||||
|  | ||||
| 		this.logger.info(`Reject: ${uri}`); | ||||
| @@ -571,7 +571,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async rejectFollow(actor: CacheableRemoteUser, activity: IFollow): Promise<string> { | ||||
| 	private async rejectFollow(actor: IRemoteUser, activity: IFollow): Promise<string> { | ||||
| 		// ※ activityはこっちから投げたフォローリクエストなので、activity.actorは存在するローカルユーザーである必要がある | ||||
| 	 | ||||
| 		const follower = await this.apDbResolverService.getUserFromApId(activity.actor); | ||||
| @@ -595,7 +595,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async remove(actor: CacheableRemoteUser, activity: IRemove): Promise<void> { | ||||
| 	private async remove(actor: IRemoteUser, activity: IRemove): Promise<void> { | ||||
| 		if ('actor' in activity && actor.uri !== activity.actor) { | ||||
| 			throw new Error('invalid actor'); | ||||
| 		} | ||||
| @@ -615,7 +615,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async undo(actor: CacheableRemoteUser, activity: IUndo): Promise<string> { | ||||
| 	private async undo(actor: IRemoteUser, activity: IUndo): Promise<string> { | ||||
| 		if ('actor' in activity && actor.uri !== activity.actor) { | ||||
| 			throw new Error('invalid actor'); | ||||
| 		} | ||||
| @@ -641,7 +641,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async undoAccept(actor: CacheableRemoteUser, activity: IAccept): Promise<string> { | ||||
| 	private async undoAccept(actor: IRemoteUser, activity: IAccept): Promise<string> { | ||||
| 		const follower = await this.apDbResolverService.getUserFromApId(activity.object); | ||||
| 		if (follower == null) { | ||||
| 			return 'skip: follower not found'; | ||||
| @@ -661,7 +661,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async undoAnnounce(actor: CacheableRemoteUser, activity: IAnnounce): Promise<string> { | ||||
| 	private async undoAnnounce(actor: IRemoteUser, activity: IAnnounce): Promise<string> { | ||||
| 		const uri = getApId(activity); | ||||
|  | ||||
| 		const note = await this.notesRepository.findOneBy({ | ||||
| @@ -676,7 +676,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async undoBlock(actor: CacheableRemoteUser, activity: IBlock): Promise<string> { | ||||
| 	private async undoBlock(actor: IRemoteUser, activity: IBlock): Promise<string> { | ||||
| 		const blockee = await this.apDbResolverService.getUserFromApId(activity.object); | ||||
|  | ||||
| 		if (blockee == null) { | ||||
| @@ -687,12 +687,12 @@ export class ApInboxService { | ||||
| 			return 'skip: ブロック解除しようとしているユーザーはローカルユーザーではありません'; | ||||
| 		} | ||||
|  | ||||
| 		await this.userBlockingService.unblock(await this.usersRepository.findOneByOrFail({ id: actor.id }) as CacheableUser, blockee); | ||||
| 		await this.userBlockingService.unblock(await this.usersRepository.findOneByOrFail({ id: actor.id }), blockee); | ||||
| 		return 'ok'; | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async undoFollow(actor: CacheableRemoteUser, activity: IFollow): Promise<string> { | ||||
| 	private async undoFollow(actor: IRemoteUser, activity: IFollow): Promise<string> { | ||||
| 		const followee = await this.apDbResolverService.getUserFromApId(activity.object); | ||||
| 		if (followee == null) { | ||||
| 			return 'skip: followee not found'; | ||||
| @@ -726,7 +726,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async undoLike(actor: CacheableRemoteUser, activity: ILike): Promise<string> { | ||||
| 	private async undoLike(actor: IRemoteUser, activity: ILike): Promise<string> { | ||||
| 		const targetUri = getApId(activity.object); | ||||
|  | ||||
| 		const note = await this.apNoteService.fetchNote(targetUri); | ||||
| @@ -741,7 +741,7 @@ export class ApInboxService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async update(actor: CacheableRemoteUser, activity: IUpdate): Promise<string> { | ||||
| 	private async update(actor: IRemoteUser, activity: IUpdate): Promise<string> { | ||||
| 		if ('actor' in activity && actor.uri !== activity.actor) { | ||||
| 			return 'skip: invalid actor'; | ||||
| 		} | ||||
|   | ||||
| @@ -2,7 +2,7 @@ import { Inject, Injectable } from '@nestjs/common'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import type { DriveFilesRepository } from '@/models/index.js'; | ||||
| import type { Config } from '@/config.js'; | ||||
| import type { CacheableRemoteUser } from '@/models/entities/User.js'; | ||||
| import type { IRemoteUser } from '@/models/entities/User.js'; | ||||
| import type { DriveFile } from '@/models/entities/DriveFile.js'; | ||||
| import { MetaService } from '@/core/MetaService.js'; | ||||
| import { truncate } from '@/misc/truncate.js'; | ||||
| @@ -36,7 +36,7 @@ export class ApImageService { | ||||
| 	 * Imageを作成します。 | ||||
| 	 */ | ||||
| 	@bindThis | ||||
| 	public async createImage(actor: CacheableRemoteUser, value: any): Promise<DriveFile> { | ||||
| 	public async createImage(actor: IRemoteUser, value: any): Promise<DriveFile> { | ||||
| 		// 投稿者が凍結されていたらスキップ | ||||
| 		if (actor.isSuspended) { | ||||
| 			throw new Error('actor has been suspended'); | ||||
| @@ -88,7 +88,7 @@ export class ApImageService { | ||||
| 	 * リモートサーバーからフェッチしてMisskeyに登録しそれを返します。 | ||||
| 	 */ | ||||
| 	@bindThis | ||||
| 	public async resolveImage(actor: CacheableRemoteUser, value: any): Promise<DriveFile> { | ||||
| 	public async resolveImage(actor: IRemoteUser, value: any): Promise<DriveFile> { | ||||
| 		// TODO | ||||
|  | ||||
| 		// リモートサーバーからフェッチしてきて登録 | ||||
|   | ||||
| @@ -1,15 +1,14 @@ | ||||
| import { Inject, Injectable } from '@nestjs/common'; | ||||
| import promiseLimit from 'promise-limit'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import type { UsersRepository } from '@/models/index.js'; | ||||
| import type { User, UsersRepository } from '@/models/index.js'; | ||||
| import type { Config } from '@/config.js'; | ||||
| import { toArray, unique } from '@/misc/prelude/array.js'; | ||||
| import type { CacheableUser } from '@/models/entities/User.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| import { isMention } from '../type.js'; | ||||
| import { ApResolverService, Resolver } from '../ApResolverService.js'; | ||||
| import { ApPersonService } from './ApPersonService.js'; | ||||
| import type { IObject, IApMention } from '../type.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
|  | ||||
| @Injectable() | ||||
| export class ApMentionService { | ||||
| @@ -26,10 +25,10 @@ export class ApMentionService { | ||||
| 	public async extractApMentions(tags: IObject | IObject[] | null | undefined, resolver: Resolver) { | ||||
| 		const hrefs = unique(this.extractApMentionObjects(tags).map(x => x.href as string)); | ||||
|  | ||||
| 		const limit = promiseLimit<CacheableUser | null>(2); | ||||
| 		const limit = promiseLimit<User | null>(2); | ||||
| 		const mentionedUsers = (await Promise.all( | ||||
| 			hrefs.map(x => limit(() => this.apPersonService.resolvePerson(x, resolver).catch(() => null))), | ||||
| 		)).filter((x): x is CacheableUser => x != null); | ||||
| 		)).filter((x): x is User => x != null); | ||||
| 	 | ||||
| 		return mentionedUsers; | ||||
| 	} | ||||
|   | ||||
| @@ -3,7 +3,7 @@ import promiseLimit from 'promise-limit'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import type { MessagingMessagesRepository, PollsRepository, EmojisRepository, UsersRepository } from '@/models/index.js'; | ||||
| import type { Config } from '@/config.js'; | ||||
| import type { CacheableRemoteUser } from '@/models/entities/User.js'; | ||||
| import type { IRemoteUser } from '@/models/entities/User.js'; | ||||
| import type { Note } from '@/models/entities/Note.js'; | ||||
| import { toArray, toSingle, unique } from '@/misc/prelude/array.js'; | ||||
| import type { Emoji } from '@/models/entities/Emoji.js'; | ||||
| @@ -146,7 +146,7 @@ export class ApNoteService { | ||||
| 		this.logger.info(`Creating the Note: ${note.id}`); | ||||
| 	 | ||||
| 		// 投稿者をフェッチ | ||||
| 		const actor = await this.apPersonService.resolvePerson(getOneApId(note.attributedTo!), resolver) as CacheableRemoteUser; | ||||
| 		const actor = await this.apPersonService.resolvePerson(getOneApId(note.attributedTo!), resolver) as IRemoteUser; | ||||
| 	 | ||||
| 		// 投稿者が凍結されていたらスキップ | ||||
| 		if (actor.isSuspended) { | ||||
|   | ||||
| @@ -5,7 +5,7 @@ import { ModuleRef } from '@nestjs/core'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import type { FollowingsRepository, InstancesRepository, UserProfilesRepository, UserPublickeysRepository, UsersRepository } from '@/models/index.js'; | ||||
| import type { Config } from '@/config.js'; | ||||
| import type { CacheableUser, IRemoteUser } from '@/models/entities/User.js'; | ||||
| import type { IRemoteUser } from '@/models/entities/User.js'; | ||||
| import { User } from '@/models/entities/User.js'; | ||||
| import { truncate } from '@/misc/truncate.js'; | ||||
| import type { UserCacheService } from '@/core/UserCacheService.js'; | ||||
| @@ -197,7 +197,7 @@ export class ApPersonService implements OnModuleInit { | ||||
| 	 * Misskeyに対象のPersonが登録されていればそれを返します。 | ||||
| 	 */ | ||||
| 	@bindThis | ||||
| 	public async fetchPerson(uri: string, resolver?: Resolver): Promise<CacheableUser | null> { | ||||
| 	public async fetchPerson(uri: string, resolver?: Resolver): Promise<User | null> { | ||||
| 		if (typeof uri !== 'string') throw new Error('uri is not string'); | ||||
|  | ||||
| 		const cached = this.userCacheService.uriPersonCache.get(uri); | ||||
| @@ -206,13 +206,13 @@ export class ApPersonService implements OnModuleInit { | ||||
| 		// URIがこのサーバーを指しているならデータベースからフェッチ | ||||
| 		if (uri.startsWith(this.config.url + '/')) { | ||||
| 			const id = uri.split('/').pop(); | ||||
| 			const u = await this.usersRepository.findOneBy({ id }) as null | CacheableUser; | ||||
| 			const u = await this.usersRepository.findOneBy({ id }); | ||||
| 			if (u) this.userCacheService.uriPersonCache.set(uri, u); | ||||
| 			return u; | ||||
| 		} | ||||
|  | ||||
| 		//#region このサーバーに既に登録されていたらそれを返す | ||||
| 		const exist = await this.usersRepository.findOneBy({ uri }) as null | CacheableUser; | ||||
| 		const exist = await this.usersRepository.findOneBy({ uri }); | ||||
|  | ||||
| 		if (exist) { | ||||
| 			this.userCacheService.uriPersonCache.set(uri, exist); | ||||
| @@ -500,7 +500,7 @@ export class ApPersonService implements OnModuleInit { | ||||
| 	 * リモートサーバーからフェッチしてMisskeyに登録しそれを返します。 | ||||
| 	 */ | ||||
| 	@bindThis | ||||
| 	public async resolvePerson(uri: string, resolver?: Resolver): Promise<CacheableUser> { | ||||
| 	public async resolvePerson(uri: string, resolver?: Resolver): Promise<User> { | ||||
| 		if (typeof uri !== 'string') throw new Error('uri is not string'); | ||||
|  | ||||
| 		//#region このサーバーに既に登録されていたらそれを返す | ||||
| @@ -513,7 +513,7 @@ export class ApPersonService implements OnModuleInit { | ||||
|  | ||||
| 		// リモートサーバーからフェッチしてきて登録 | ||||
| 		if (resolver == null) resolver = this.apResolverService.createResolver(); | ||||
| 		return await this.createPerson(uri, resolver) as CacheableUser; | ||||
| 		return await this.createPerson(uri, resolver); | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 syuilo
					syuilo