良い感じに
This commit is contained in:
		
							parent
							
								
									560bb65384
								
							
						
					
					
						commit
						f7069dcd18
					
				
					 11 changed files with 225 additions and 164 deletions
				
			
		| 
						 | 
				
			
			@ -1,6 +1,7 @@
 | 
			
		|||
import $ from 'cafy'; import ID from '../../../../misc/cafy-id';
 | 
			
		||||
import Blocking from '../../../../models/blocking';
 | 
			
		||||
import { pack, ILocalUser } from '../../../../models/user';
 | 
			
		||||
import Blocking, { packMany } from '../../../../models/blocking';
 | 
			
		||||
import { ILocalUser } from '../../../../models/user';
 | 
			
		||||
import getParams from '../../get-params';
 | 
			
		||||
 | 
			
		||||
export const meta = {
 | 
			
		||||
	desc: {
 | 
			
		||||
| 
						 | 
				
			
			@ -10,50 +11,54 @@ export const meta = {
 | 
			
		|||
 | 
			
		||||
	requireCredential: true,
 | 
			
		||||
 | 
			
		||||
	kind: 'following-read'
 | 
			
		||||
	kind: 'following-read',
 | 
			
		||||
 | 
			
		||||
	params: {
 | 
			
		||||
		limit: $.num.optional.range(1, 100).note({
 | 
			
		||||
			default: 30
 | 
			
		||||
		}),
 | 
			
		||||
 | 
			
		||||
		sinceId: $.type(ID).optional.note({
 | 
			
		||||
		}),
 | 
			
		||||
 | 
			
		||||
		untilId: $.type(ID).optional.note({
 | 
			
		||||
		}),
 | 
			
		||||
	}
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
export default (params: any, me: ILocalUser) => new Promise(async (res, rej) => {
 | 
			
		||||
	// Get 'limit' parameter
 | 
			
		||||
	const [limit = 30, limitErr] = $.num.optional.range(1, 100).get(params.limit);
 | 
			
		||||
	if (limitErr) return rej('invalid limit param');
 | 
			
		||||
	const [ps, psErr] = getParams(meta, params);
 | 
			
		||||
	if (psErr) return rej(psErr);
 | 
			
		||||
 | 
			
		||||
	// Get 'cursor' parameter
 | 
			
		||||
	const [cursor = null, cursorErr] = $.type(ID).optional.get(params.cursor);
 | 
			
		||||
	if (cursorErr) return rej('invalid cursor param');
 | 
			
		||||
	// Check if both of sinceId and untilId is specified
 | 
			
		||||
	if (ps.sinceId && ps.untilId) {
 | 
			
		||||
		return rej('cannot set sinceId and untilId');
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Construct query
 | 
			
		||||
	const query = {
 | 
			
		||||
		blockerId: me._id
 | 
			
		||||
	} as any;
 | 
			
		||||
 | 
			
		||||
	// カーソルが指定されている場合
 | 
			
		||||
	if (cursor) {
 | 
			
		||||
	const sort = {
 | 
			
		||||
		_id: -1
 | 
			
		||||
	};
 | 
			
		||||
 | 
			
		||||
	if (ps.sinceId) {
 | 
			
		||||
		sort._id = 1;
 | 
			
		||||
		query._id = {
 | 
			
		||||
			$lt: cursor
 | 
			
		||||
			$gt: ps.sinceId
 | 
			
		||||
		};
 | 
			
		||||
	} else if (ps.untilId) {
 | 
			
		||||
		query._id = {
 | 
			
		||||
			$lt: ps.untilId
 | 
			
		||||
		};
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get blockings
 | 
			
		||||
	const blockings = await Blocking
 | 
			
		||||
		.find(query, {
 | 
			
		||||
			limit: limit + 1,
 | 
			
		||||
			sort: { _id: -1 }
 | 
			
		||||
			limit: ps.limit,
 | 
			
		||||
			sort: sort
 | 
			
		||||
		});
 | 
			
		||||
 | 
			
		||||
	// 「次のページ」があるかどうか
 | 
			
		||||
	const inStock = blockings.length === limit + 1;
 | 
			
		||||
	if (inStock) {
 | 
			
		||||
		blockings.pop();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Serialize
 | 
			
		||||
	const users = await Promise.all(blockings.map(async m =>
 | 
			
		||||
		await pack(m.blockeeId, me, { detail: true })));
 | 
			
		||||
 | 
			
		||||
	// Response
 | 
			
		||||
	res({
 | 
			
		||||
		users: users,
 | 
			
		||||
		next: inStock ? blockings[blockings.length - 1]._id : null,
 | 
			
		||||
	});
 | 
			
		||||
	res(await packMany(blockings, me));
 | 
			
		||||
});
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,7 +1,7 @@
 | 
			
		|||
import $ from 'cafy'; import ID from '../../../../misc/cafy-id';
 | 
			
		||||
import Mute from '../../../../models/mute';
 | 
			
		||||
import { pack, ILocalUser } from '../../../../models/user';
 | 
			
		||||
import { getFriendIds } from '../../common/get-friends';
 | 
			
		||||
import Mute, { packMany } from '../../../../models/mute';
 | 
			
		||||
import { ILocalUser } from '../../../../models/user';
 | 
			
		||||
import getParams from '../../get-params';
 | 
			
		||||
 | 
			
		||||
export const meta = {
 | 
			
		||||
	desc: {
 | 
			
		||||
| 
						 | 
				
			
			@ -11,64 +11,54 @@ export const meta = {
 | 
			
		|||
 | 
			
		||||
	requireCredential: true,
 | 
			
		||||
 | 
			
		||||
	kind: 'account/read'
 | 
			
		||||
	kind: 'account/read',
 | 
			
		||||
 | 
			
		||||
	params: {
 | 
			
		||||
		limit: $.num.optional.range(1, 100).note({
 | 
			
		||||
			default: 30
 | 
			
		||||
		}),
 | 
			
		||||
 | 
			
		||||
		sinceId: $.type(ID).optional.note({
 | 
			
		||||
		}),
 | 
			
		||||
 | 
			
		||||
		untilId: $.type(ID).optional.note({
 | 
			
		||||
		}),
 | 
			
		||||
	}
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
export default (params: any, me: ILocalUser) => new Promise(async (res, rej) => {
 | 
			
		||||
	// Get 'iknow' parameter
 | 
			
		||||
	const [iknow = false, iknowErr] = $.bool.optional.get(params.iknow);
 | 
			
		||||
	if (iknowErr) return rej('invalid iknow param');
 | 
			
		||||
	const [ps, psErr] = getParams(meta, params);
 | 
			
		||||
	if (psErr) return rej(psErr);
 | 
			
		||||
 | 
			
		||||
	// Get 'limit' parameter
 | 
			
		||||
	const [limit = 30, limitErr] = $.num.optional.range(1, 100).get(params.limit);
 | 
			
		||||
	if (limitErr) return rej('invalid limit param');
 | 
			
		||||
	// Check if both of sinceId and untilId is specified
 | 
			
		||||
	if (ps.sinceId && ps.untilId) {
 | 
			
		||||
		return rej('cannot set sinceId and untilId');
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get 'cursor' parameter
 | 
			
		||||
	const [cursor = null, cursorErr] = $.type(ID).optional.get(params.cursor);
 | 
			
		||||
	if (cursorErr) return rej('invalid cursor param');
 | 
			
		||||
 | 
			
		||||
	// Construct query
 | 
			
		||||
	const query = {
 | 
			
		||||
		muterId: me._id,
 | 
			
		||||
		deletedAt: { $exists: false }
 | 
			
		||||
		muterId: me._id
 | 
			
		||||
	} as any;
 | 
			
		||||
 | 
			
		||||
	if (iknow) {
 | 
			
		||||
		// Get my friends
 | 
			
		||||
		const myFriends = await getFriendIds(me._id);
 | 
			
		||||
	const sort = {
 | 
			
		||||
		_id: -1
 | 
			
		||||
	};
 | 
			
		||||
 | 
			
		||||
		query.muteeId = {
 | 
			
		||||
			$in: myFriends
 | 
			
		||||
		};
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// カーソルが指定されている場合
 | 
			
		||||
	if (cursor) {
 | 
			
		||||
	if (ps.sinceId) {
 | 
			
		||||
		sort._id = 1;
 | 
			
		||||
		query._id = {
 | 
			
		||||
			$lt: cursor
 | 
			
		||||
			$gt: ps.sinceId
 | 
			
		||||
		};
 | 
			
		||||
	} else if (ps.untilId) {
 | 
			
		||||
		query._id = {
 | 
			
		||||
			$lt: ps.untilId
 | 
			
		||||
		};
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get mutes
 | 
			
		||||
	const mutes = await Mute
 | 
			
		||||
		.find(query, {
 | 
			
		||||
			limit: limit + 1,
 | 
			
		||||
			sort: { _id: -1 }
 | 
			
		||||
			limit: ps.limit,
 | 
			
		||||
			sort: sort
 | 
			
		||||
		});
 | 
			
		||||
 | 
			
		||||
	// 「次のページ」があるかどうか
 | 
			
		||||
	const inStock = mutes.length === limit + 1;
 | 
			
		||||
	if (inStock) {
 | 
			
		||||
		mutes.pop();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Serialize
 | 
			
		||||
	const users = await Promise.all(mutes.map(async m =>
 | 
			
		||||
		await pack(m.muteeId, me, { detail: true })));
 | 
			
		||||
 | 
			
		||||
	// Response
 | 
			
		||||
	res({
 | 
			
		||||
		users: users,
 | 
			
		||||
		next: inStock ? mutes[mutes.length - 1]._id : null,
 | 
			
		||||
	});
 | 
			
		||||
	res(await packMany(mutes, me));
 | 
			
		||||
});
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue