yumechi-no-kuni/src/server/api/endpoints/users.ts

116 lines
2.3 KiB
TypeScript
Raw Normal View History

2017-03-08 12:50:09 -06:00
import $ from 'cafy';
2018-11-01 23:49:09 -05:00
import User, { pack } from '../../../models/user';
2018-11-01 23:47:44 -05:00
import define from '../define';
2019-02-17 06:40:53 -06:00
import { fallback } from '../../../prelude/symbol';
import { getHideUserIds } from '../common/get-hide-users';
2019-02-17 06:40:53 -06:00
2019-02-17 09:20:14 -06:00
const nonnull = { $ne: null as any };
2016-12-28 16:49:51 -06:00
2018-11-01 22:49:08 -05:00
export const meta = {
tags: ['users'],
2018-11-01 22:49:08 -05:00
requireCredential: false,
params: {
limit: {
2019-02-13 01:33:07 -06:00
validator: $.optional.num.range(1, 100),
2018-11-01 22:49:08 -05:00
default: 10
},
offset: {
2019-02-13 01:33:07 -06:00
validator: $.optional.num.min(0),
2018-11-01 22:49:08 -05:00
default: 0
},
2017-03-03 13:28:38 -06:00
2018-11-01 22:49:08 -05:00
sort: {
2019-02-13 01:33:07 -06:00
validator: $.optional.str.or([
'+follower',
'-follower',
'+createdAt',
'-createdAt',
'+updatedAt',
'-updatedAt',
]),
},
2019-02-15 15:50:58 -06:00
state: {
validator: $.optional.str.or([
'all',
'admin',
'moderator',
'adminOrModerator',
'verified',
'alive'
]),
default: 'all'
},
origin: {
2019-02-13 01:33:07 -06:00
validator: $.optional.str.or([
'combined',
'local',
'remote',
]),
default: 'local'
2018-11-01 22:49:08 -05:00
}
2019-02-24 04:42:26 -06:00
},
res: {
type: 'array',
items: {
type: 'User',
}
},
2018-11-01 22:49:08 -05:00
};
2017-03-03 13:28:38 -06:00
2019-02-17 06:40:53 -06:00
const state: any = { // < https://github.com/Microsoft/TypeScript/issues/1863
2019-02-20 07:33:13 -06:00
'admin': { isAdmin: true },
'moderator': { isModerator: true },
'adminOrModerator': {
$or: [
{ isAdmin: true },
{ isModerator: true }
]
},
'verified': { isVerified: true },
'alive': {
updatedAt: { $gt: new Date(Date.now() - 1000 * 60 * 60 * 24 * 5) }
},
[fallback]: {}
2019-02-17 06:40:53 -06:00
};
2019-02-15 15:50:58 -06:00
2019-02-17 06:40:53 -06:00
const origin: any = { // < https://github.com/Microsoft/TypeScript/issues/1863
2019-02-20 07:33:13 -06:00
'local': { host: null },
'remote': { host: nonnull },
[fallback]: {}
2019-02-17 06:40:53 -06:00
};
2019-02-15 15:50:58 -06:00
2019-02-17 06:40:53 -06:00
const sort: any = { // < https://github.com/Microsoft/TypeScript/issues/1863
'+follower': { followersCount: -1 },
'-follower': { followersCount: 1 },
'+createdAt': { createdAt: -1 },
'-createdAt': { createdAt: 1 },
'+updatedAt': { updatedAt: -1 },
'-updatedAt': { updatedAt: 1 },
[fallback]: { _id: -1 }
};
export default define(meta, async (ps, me) => {
const hideUserIds = await getHideUserIds(me);
2017-03-03 13:28:38 -06:00
const users = await User
2019-02-17 06:40:53 -06:00
.find({
2019-02-20 07:33:22 -06:00
$and: [
state[ps.state] || state[fallback],
origin[ps.origin] || origin[fallback]
],
...(hideUserIds && hideUserIds.length > 0 ? { _id: { $nin: hideUserIds } } : {})
2019-02-20 07:33:22 -06:00
}, {
2018-11-01 22:49:08 -05:00
limit: ps.limit,
2019-02-17 06:40:53 -06:00
sort: sort[ps.sort] || sort[fallback],
2018-11-01 22:49:08 -05:00
skip: ps.offset
2017-03-03 13:28:38 -06:00
});
return await Promise.all(users.map(user => pack(user, me, { detail: true })));
});