enhance: account migration (#10592)
* copy block and mute then create follow and unfollow jobs * copy block and mute and update lists when detecting an account has moved * no need to care promise orders * refactor updating actor and target * automatically accept if a locked account had accepted an old account * fix exception format * prevent the old account from calling some endpoints * do not unfollow when moving * adjust following and follower counts * check movedToUri when receiving a follow request * skip if no need to adjust * Revert "disable account migration" This reverts commit2321214c98. * fix translation specifier * fix checking alsoKnownAs and uri * fix updating account * fix refollowing locked account * decrease followersCount if followed by the old account * adjust following and followers counts when unfollowing * fix copying mutings * prohibit moved account from moving again * fix move service * allow app creation after moving * fix lint * remove unnecessary field * fix cache update * add e2e test * add e2e test of accepting the new account automatically * force follow if any error happens * remove unnecessary joins * use Array.map instead of for const of * ユーザーリストの移行は追加のみを行う * nanka iroiro * fix misskey-js? * ✌️ * 移行を行ったアカウントからのフォローリクエストの自動許可を調整 * newUriを外に出す * newUriを外に出す2 * clean up * fix newUri * prevent moving if the destination account has already moved * set alsoKnownAs via /i/update * fix database initialization * add return type * prohibit updating alsoKnownAs after moving * skip to add to alsoKnownAs if toUrl is known * skip adding to the list if it already has * use Acct.parse instead * rename error code * 🎨 * 制限を5から10に緩和 * movedTo(Uri), alsoKnownAsはユーザーidを返すように * test api res * fix * 元アカウントはミュートし続ける * 🎨 * unfollow * fix * getUserUriをUserEntityServiceに * ? * job! * 🎨 * instance => server * accountMovedShort, forbiddenBecauseYouAreMigrated * accountMovedShort * fix test * import, pin禁止 * 実績を凍結する * clean up * ✌️ * change message * ブロック, フォロー, ミュート, リストのインポートファイルの制限を32MiBに * Revert "ブロック, フォロー, ミュート, リストのインポートファイルの制限を32MiBに" This reverts commit3bd7be35d8. * validateAlsoKnownAs * 移行後2時間以内はインポート可能なファイルサイズを拡大 * clean up * どうせactorをupdatePersonで更新するならupdatePersonしか移行処理を発行しないことにする * handle error? * リモートからの移行処理の条件を是正 * log, port * fix * fix * enhance(dev): non-production環境でhttpサーバー間でもユーザー、ノートの連合が可能なように * refactor (use checkHttps) * MISSKEY_WEBFINGER_USE_HTTP * Environment Variable readme * NEVER USE IN PRODUCTION * fix punyHost * fix indent * fix * experimental --------- Co-authored-by: tamaina <tamaina@hotmail.co.jp> Co-authored-by: syuilo <Syuilotan@yahoo.co.jp>
This commit is contained in:
		| @@ -9,8 +9,7 @@ import type { Packed } from '@/misc/json-schema.js'; | ||||
| import type { Promiseable } from '@/misc/prelude/await-all.js'; | ||||
| import { awaitAll } from '@/misc/prelude/await-all.js'; | ||||
| import { USER_ACTIVE_THRESHOLD, USER_ONLINE_THRESHOLD } from '@/const.js'; | ||||
| import type { Instance } from '@/models/entities/Instance.js'; | ||||
| import type { LocalUser, RemoteUser, User } from '@/models/entities/User.js'; | ||||
| import type { LocalUser, PartialLocalUser, PartialRemoteUser, RemoteUser, User } from '@/models/entities/User.js'; | ||||
| import { birthdaySchema, descriptionSchema, localUsernameSchema, locationSchema, nameSchema, passwordSchema } from '@/models/entities/User.js'; | ||||
| import type { UsersRepository, UserSecurityKeysRepository, FollowingsRepository, FollowRequestsRepository, BlockingsRepository, MutingsRepository, DriveFilesRepository, NoteUnreadsRepository, ChannelFollowingsRepository, UserNotePiningsRepository, UserProfilesRepository, InstancesRepository, AnnouncementReadsRepository, AnnouncementsRepository, PagesRepository, UserProfile, RenoteMutingsRepository, UserMemoRepository } from '@/models/index.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| @@ -35,13 +34,13 @@ type IsMeAndIsUserDetailed<ExpectsMe extends boolean | null, Detailed extends bo | ||||
| const ajv = new Ajv(); | ||||
|  | ||||
| function isLocalUser(user: User): user is LocalUser; | ||||
| function isLocalUser<T extends { host: User['host'] }>(user: T): user is T & { host: null; }; | ||||
| function isLocalUser<T extends { host: User['host'] }>(user: T): user is (T & { host: null; }); | ||||
| function isLocalUser(user: User | { host: User['host'] }): boolean { | ||||
| 	return user.host == null; | ||||
| } | ||||
|  | ||||
| function isRemoteUser(user: User): user is RemoteUser; | ||||
| function isRemoteUser<T extends { host: User['host'] }>(user: T): user is T & { host: string; }; | ||||
| function isRemoteUser<T extends { host: User['host'] }>(user: T): user is (T & { host: string; }); | ||||
| function isRemoteUser(user: User | { host: User['host'] }): boolean { | ||||
| 	return !isLocalUser(user); | ||||
| } | ||||
| @@ -280,6 +279,17 @@ export class UserEntityService implements OnModuleInit { | ||||
| 		return `${this.config.url}/identicon/${user.username.toLowerCase()}@${user.host ?? this.config.host}`; | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public getUserUri(user: LocalUser | PartialLocalUser | RemoteUser | PartialRemoteUser): string { | ||||
| 		return this.isRemoteUser(user) | ||||
| 			? user.uri : this.genLocalUserUri(user.id); | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public genLocalUserUri(userId: string): string { | ||||
| 		return `${this.config.url}/users/${userId}`; | ||||
| 	} | ||||
|  | ||||
| 	public async pack<ExpectsMe extends boolean | null = null, D extends boolean = false>( | ||||
| 		src: User['id'] | User, | ||||
| 		me?: { id: User['id'] } | null | undefined, | ||||
| @@ -369,8 +379,11 @@ export class UserEntityService implements OnModuleInit { | ||||
| 			...(opts.detail ? { | ||||
| 				url: profile!.url, | ||||
| 				uri: user.uri, | ||||
| 				movedToUri: user.movedToUri ? await this.apPersonService.resolvePerson(user.movedToUri) : null, | ||||
| 				alsoKnownAs: user.alsoKnownAs, | ||||
| 				movedTo: user.movedToUri ? this.apPersonService.resolvePerson(user.movedToUri).then(user => user.id).catch(() => null) : null, | ||||
| 				alsoKnownAs: user.alsoKnownAs | ||||
| 					? Promise.all(user.alsoKnownAs.map(uri => this.apPersonService.fetchPerson(uri).then(user => user?.id).catch(() => null))) | ||||
| 						.then(xs => xs.length === 0 ? null : xs.filter(x => x != null) as string[]) | ||||
| 					: null, | ||||
| 				createdAt: user.createdAt.toISOString(), | ||||
| 				updatedAt: user.updatedAt ? user.updatedAt.toISOString() : null, | ||||
| 				lastFetchedAt: user.lastFetchedAt ? user.lastFetchedAt.toISOString() : null, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Namekuji
					Namekuji