add local move follower migration
This commit is contained in:
parent
25fc88afd6
commit
5a2bd3d379
2 changed files with 28 additions and 11 deletions
|
@ -58,9 +58,6 @@ export default async (actor: CacheableRemoteUser, activity: IMove): Promise<stri
|
||||||
followeeId: followee.id,
|
followeeId: followee.id,
|
||||||
});
|
});
|
||||||
|
|
||||||
//TODO remove this
|
|
||||||
console.log(followings);
|
|
||||||
|
|
||||||
followings.forEach(async following => {
|
followings.forEach(async following => {
|
||||||
//if follower is local
|
//if follower is local
|
||||||
if (!following.followerHost) {
|
if (!following.followerHost) {
|
||||||
|
@ -71,13 +68,7 @@ export default async (actor: CacheableRemoteUser, activity: IMove): Promise<stri
|
||||||
await deleteFollowing(follower!, followee);
|
await deleteFollowing(follower!, followee);
|
||||||
try {
|
try {
|
||||||
await create(follower!, followeeNew);
|
await create(follower!, followeeNew);
|
||||||
} catch (e) {
|
} catch (e) { /* empty */ }
|
||||||
if (e instanceof IdentifiableError) {
|
|
||||||
if (e.id === '710e8fb0-b8c3-4922-be49-d5d93d8e6a6e') return meta.errors.blocking;
|
|
||||||
if (e.id === '3338392a-f764-498d-8855-db939dcf8c48') return meta.errors.blocked;
|
|
||||||
}
|
|
||||||
return e;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,10 @@ import { genId } from '@/misc/gen-id.js';
|
||||||
import define from '../../define.js';
|
import define from '../../define.js';
|
||||||
import { ApiError } from '../../error.js';
|
import { ApiError } from '../../error.js';
|
||||||
import { apiLogger } from '../../logger.js';
|
import { apiLogger } from '../../logger.js';
|
||||||
import { Users } from '@/models/index.js';
|
import deleteFollowing from '@/services/following/delete.js';
|
||||||
|
import create from '@/services/following/create.js';
|
||||||
|
import { getUser } from '@/server/api/common/getters.js';
|
||||||
|
import { Followings, Users } from '@/models/index.js';
|
||||||
import { UserProfiles } from '@/models/index.js';
|
import { UserProfiles } from '@/models/index.js';
|
||||||
import config from '@/config/index.js';
|
import config from '@/config/index.js';
|
||||||
import { publishMainStream } from '@/services/stream.js';
|
import { publishMainStream } from '@/services/stream.js';
|
||||||
|
@ -44,6 +47,11 @@ export const meta = {
|
||||||
code: 'NOT_ADMIN_FORBIDDEN',
|
code: 'NOT_ADMIN_FORBIDDEN',
|
||||||
id: '4362e8dc-731f-4ad8-a694-be2a88922a24',
|
id: '4362e8dc-731f-4ad8-a694-be2a88922a24',
|
||||||
},
|
},
|
||||||
|
noSuchUser: {
|
||||||
|
message: 'No such user.',
|
||||||
|
code: 'NO_SUCH_USER',
|
||||||
|
id: 'fcd2eef9-a9b2-4c4f-8624-038099e90aa5',
|
||||||
|
},
|
||||||
},
|
},
|
||||||
} as const;
|
} as const;
|
||||||
|
|
||||||
|
@ -121,5 +129,23 @@ export default define(meta, paramDef, async (ps, user) => {
|
||||||
// Publish meUpdated event
|
// Publish meUpdated event
|
||||||
publishMainStream(user.id, 'meUpdated', iObj);
|
publishMainStream(user.id, 'meUpdated', iObj);
|
||||||
|
|
||||||
|
const followings = await Followings.findBy({
|
||||||
|
followeeId: user.id,
|
||||||
|
});
|
||||||
|
|
||||||
|
followings.forEach(async following => {
|
||||||
|
//if follower is local
|
||||||
|
if (!following.followerHost) {
|
||||||
|
const follower = await getUser(following.followerId).catch(e => {
|
||||||
|
if (e.id === '15348ddd-432d-49c2-8a5a-8069753becff') throw new ApiError(meta.errors.noSuchUser);
|
||||||
|
throw e;
|
||||||
|
});
|
||||||
|
await deleteFollowing(follower!, user);
|
||||||
|
try {
|
||||||
|
await create(follower!, moveTo);
|
||||||
|
} catch (e) { /* empty */ }
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
return iObj;
|
return iObj;
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue