94 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // for Node.js interpret
 | |
| 
 | |
| const { default: Following } = require('../../../built/models/following');
 | |
| const { default: FollowingLog } = require('../../../built/models/following-log');
 | |
| const { default: FollowedLog } = require('../../../built/models/followed-log');
 | |
| const { default: zip } = require('@prezzemolo/zip')
 | |
| 
 | |
| const migrate = async (following) => {
 | |
| 	const followingCount = await Following.count({
 | |
| 		followerId: following.followerId,
 | |
| 		createdAt: { $lt: following.createdAt },
 | |
| 		$or: [
 | |
| 			{ deletedAt: { $exists: false } },
 | |
| 			{ deletedAt: { $gt: following.createdAt } }
 | |
| 		]
 | |
| 	});
 | |
| 	await FollowingLog.insert({
 | |
| 		createdAt: following.createdAt,
 | |
| 		userId: following.followerId,
 | |
| 		count: followingCount + 1
 | |
| 	});
 | |
| 
 | |
| 	const followersCount = await Following.count({
 | |
| 		followeeId: following.followeeId,
 | |
| 		createdAt: { $lt: following.createdAt },
 | |
| 		$or: [
 | |
| 			{ deletedAt: { $exists: false } },
 | |
| 			{ deletedAt: { $gt: following.createdAt } }
 | |
| 		]
 | |
| 	});
 | |
| 	await FollowedLog.insert({
 | |
| 		createdAt: following.createdAt,
 | |
| 		userId: following.followeeId,
 | |
| 		count: followersCount + 1
 | |
| 	});
 | |
| 
 | |
| 	if (following.deletedAt) {
 | |
| 		const followingCount2 = await Following.count({
 | |
| 			followerId: following.followerId,
 | |
| 			createdAt: { $lt: following.deletedAt },
 | |
| 			$or: [
 | |
| 				{ deletedAt: { $exists: false } },
 | |
| 				{ deletedAt: { $gt: following.createdAt } }
 | |
| 			]
 | |
| 		});
 | |
| 		await FollowingLog.insert({
 | |
| 			createdAt: following.deletedAt,
 | |
| 			userId: following.followerId,
 | |
| 			count: followingCount2 - 1
 | |
| 		});
 | |
| 
 | |
| 		const followersCount2 = await Following.count({
 | |
| 			followeeId: following.followeeId,
 | |
| 			createdAt: { $lt: following.deletedAt },
 | |
| 			$or: [
 | |
| 				{ deletedAt: { $exists: false } },
 | |
| 				{ deletedAt: { $gt: following.createdAt } }
 | |
| 			]
 | |
| 		});
 | |
| 		await FollowedLog.insert({
 | |
| 			createdAt: following.deletedAt,
 | |
| 			userId: following.followeeId,
 | |
| 			count: followersCount2 - 1
 | |
| 		});
 | |
| 	}
 | |
| 
 | |
| 	return true;
 | |
| }
 | |
| 
 | |
| async function main() {
 | |
| 	const count = await Following.count({});
 | |
| 
 | |
| 	const dop = Number.parseInt(process.argv[2]) || 5
 | |
| 	const idop = ((count - (count % dop)) / dop) + 1
 | |
| 
 | |
| 	return zip(
 | |
| 		1,
 | |
| 		async (time) => {
 | |
| 			console.log(`${time} / ${idop}`)
 | |
| 			const doc = await Following.find({}, {
 | |
| 				limit: dop, skip: time * dop, sort: { _id: 1 }
 | |
| 			})
 | |
| 			return Promise.all(doc.map(migrate))
 | |
| 		},
 | |
| 		idop
 | |
| 	).then(a => {
 | |
| 		const rv = []
 | |
| 		a.forEach(e => rv.push(...e))
 | |
| 		return rv
 | |
| 	})
 | |
| }
 | |
| 
 | |
| main().then(console.dir).catch(console.error)
 | 
