1
0
mirror of https://github.com/hotomoe/hotomoe synced 2025-01-08 02:42:55 +09:00
hotomoe/src/server/api/endpoints/users.ts

52 lines
1.1 KiB
TypeScript
Raw Normal View History

2017-03-09 03:50:09 +09:00
import $ from 'cafy';
2018-06-18 09:54:53 +09:00
import User, { pack, ILocalUser } from '../../../models/user';
2016-12-29 07:49:51 +09:00
/**
* Lists all users
*/
2018-06-18 09:54:53 +09:00
module.exports = (params: any, me: ILocalUser) => new Promise(async (res, rej) => {
2017-03-04 04:28:38 +09:00
// Get 'limit' parameter
2018-05-02 18:06:16 +09:00
const [limit = 10, limitErr] = $.num.optional().range(1, 100).get(params.limit);
2017-03-04 04:28:38 +09:00
if (limitErr) return rej('invalid limit param');
2018-03-17 23:01:17 +09:00
// Get 'offset' parameter
2018-05-02 18:06:16 +09:00
const [offset = 0, offsetErr] = $.num.optional().min(0).get(params.offset);
2018-03-17 23:01:17 +09:00
if (offsetErr) return rej('invalid offset param');
2017-03-04 04:28:38 +09:00
2018-03-17 23:01:17 +09:00
// Get 'sort' parameter
2018-05-02 18:06:16 +09:00
const [sort, sortError] = $.str.optional().or('+follower|-follower').get(params.sort);
2018-03-17 23:01:17 +09:00
if (sortError) return rej('invalid sort param');
2017-03-04 04:28:38 +09:00
// Construct query
2018-03-17 23:01:17 +09:00
let _sort;
if (sort) {
if (sort == '+follower') {
_sort = {
2018-03-29 14:48:47 +09:00
followersCount: -1
2018-03-17 23:01:17 +09:00
};
} else if (sort == '-follower') {
_sort = {
2018-03-29 14:48:47 +09:00
followersCount: 1
2018-03-17 23:01:17 +09:00
};
}
} else {
_sort = {
_id: -1
2017-03-04 04:28:38 +09:00
};
}
// Issue query
const users = await User
2018-04-16 15:42:34 +09:00
.find({
host: null
}, {
2017-03-04 04:28:38 +09:00
limit: limit,
2018-03-17 23:01:17 +09:00
sort: _sort,
skip: offset
2017-03-04 04:28:38 +09:00
});
// Serialize
res(await Promise.all(users.map(async user =>
2018-02-02 08:21:30 +09:00
await pack(user, me))));
2017-03-04 04:28:38 +09:00
});