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

90 lines
2.1 KiB
TypeScript
Raw Normal View History

2017-03-03 08:06:34 +09:00
/**
* Module dependencies
*/
2017-03-09 03:50:09 +09:00
import $ from 'cafy';
2017-03-03 08:06:34 +09:00
import Post from '../models/post';
import serialize from '../serializers/post';
/**
* Lists all posts
*
* @param {any} params
* @return {Promise<any>}
*/
2017-03-04 04:28:38 +09:00
module.exports = (params) => new Promise(async (res, rej) => {
// Get 'reply' parameter
const [reply, replyErr] = $(params.reply).optional.boolean().$;
if (replyErr) return rej('invalid reply param');
2017-03-03 08:06:34 +09:00
// Get 'repost' parameter
const [repost, repostErr] = $(params.repost).optional.boolean().$;
if (repostErr) return rej('invalid repost param');
// Get 'media' parameter
const [media, mediaErr] = $(params.media).optional.boolean().$;
if (mediaErr) return rej('invalid media param');
// Get 'poll' parameter
const [poll, pollErr] = $(params.poll).optional.boolean().$;
if (pollErr) return rej('invalid poll param');
2017-03-03 08:06:34 +09:00
2017-03-04 04:28:38 +09:00
// 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');
2017-03-03 08:06:34 +09:00
2017-03-04 04:28:38 +09:00
// Get 'since_id' parameter
2017-03-09 03:50:09 +09:00
const [sinceId, sinceIdErr] = $(params.since_id).optional.id().$;
2017-03-04 04:28:38 +09:00
if (sinceIdErr) return rej('invalid since_id param');
2017-03-03 08:06:34 +09:00
2017-03-04 04:28:38 +09:00
// Get 'max_id' parameter
2017-03-09 03:50:09 +09:00
const [maxId, maxIdErr] = $(params.max_id).optional.id().$;
2017-03-04 04:28:38 +09:00
if (maxIdErr) return rej('invalid max_id param');
2017-03-03 08:06:34 +09:00
2017-03-04 04:28:38 +09:00
// Check if both of since_id and max_id is specified
if (sinceId && maxId) {
return rej('cannot set since_id and max_id');
}
2017-03-03 08:06:34 +09:00
2017-03-04 04:28:38 +09:00
// Construct query
const sort = {
_id: -1
};
const query = {} as any;
if (sinceId) {
sort._id = 1;
query._id = {
$gt: sinceId
};
} else if (maxId) {
query._id = {
$lt: maxId
2017-03-03 08:06:34 +09:00
};
2017-03-04 04:28:38 +09:00
}
2017-03-03 08:06:34 +09:00
if (reply != undefined) {
2017-11-01 10:22:40 +09:00
query.reply_id = reply ? { $exists: true, $ne: null } : null;
}
if (repost != undefined) {
query.repost_id = repost ? { $exists: true, $ne: null } : null;
}
if (media != undefined) {
query.media_ids = media ? { $exists: true, $ne: null } : null;
2017-03-04 04:28:38 +09:00
}
2017-03-03 08:06:34 +09:00
if (poll != undefined) {
query.poll = poll ? { $exists: true, $ne: null } : null;
2017-03-04 04:28:38 +09:00
}
2017-03-03 08:06:34 +09:00
2017-03-04 04:28:38 +09:00
// Issue query
const posts = await Post
.find(query, {
limit: limit,
sort: sort
});
2017-03-03 08:06:34 +09:00
2017-03-04 04:28:38 +09:00
// Serialize
res(await Promise.all(posts.map(async post => await serialize(post))));
});