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

57 lines
1.2 KiB
TypeScript
Raw Normal View History

2016-12-29 07:49:51 +09:00
/**
* Module dependencies
*/
2017-03-09 03:50:09 +09:00
import $ from 'cafy';
2018-03-29 20:32:18 +09:00
import User, { pack } from '../../../models/user';
2016-12-29 07:49:51 +09:00
/**
* Lists all users
*
2017-03-01 17:37:01 +09:00
* @param {any} params
* @param {any} me
* @return {Promise<any>}
2016-12-29 07:49:51 +09:00
*/
2017-03-04 04:28:38 +09:00
module.exports = (params, me) => new Promise(async (res, rej) => {
// Get 'limit' parameter
2017-03-09 03:50:09 +09:00
const [limit = 10, limitErr] = $(params.limit).optional.number().range(1, 100).$;
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
const [offset = 0, offsetErr] = $(params.offset).optional.number().min(0).$;
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
const [sort, sortError] = $(params.sort).optional.string().or('+follower|-follower').$;
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-03-17 23:01:17 +09:00
.find({}, {
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
});