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

103 lines
2.1 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';
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 = {
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
}
}
};
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
'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-15 15:50:58 -06:00
2019-02-17 06:40:53 -06:00
const origin: any = { // < https://github.com/Microsoft/TypeScript/issues/1863
'local': { host: null },
'remote': { host: nonnull },
[fallback]: {}
};
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 }
};
2019-02-17 06:40:53 -06:00
export default define(meta, (ps, me) => new Promise(async (res, rej) => {
2017-03-03 13:28:38 -06:00
const users = await User
2019-02-17 06:40:53 -06:00
.find({
$and: [
state[ps.state] || state[fallback],
origin[ps.origin] || origin[fallback]
]
}, {
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
});
res(await Promise.all(users.map(user => pack(user, me, { detail: true }))));
2018-11-01 23:47:44 -05:00
}));