diff options
| author | syuilo <syuilotan@yahoo.co.jp> | 2017-03-03 08:00:10 +0900 |
|---|---|---|
| committer | syuilo <syuilotan@yahoo.co.jp> | 2017-03-03 08:00:10 +0900 |
| commit | 583b64331b4d3d36f642801c847109b8634df1d9 (patch) | |
| tree | 1bccc089c3feae69e2690b22093ee9b2155b53db /src/api/endpoints/posts/favorites/create.ts | |
| parent | wip (diff) | |
| download | misskey-583b64331b4d3d36f642801c847109b8634df1d9.tar.gz misskey-583b64331b4d3d36f642801c847109b8634df1d9.tar.bz2 misskey-583b64331b4d3d36f642801c847109b8634df1d9.zip | |
wip
Diffstat (limited to 'src/api/endpoints/posts/favorites/create.ts')
| -rw-r--r-- | src/api/endpoints/posts/favorites/create.ts | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/src/api/endpoints/posts/favorites/create.ts b/src/api/endpoints/posts/favorites/create.ts new file mode 100644 index 0000000000..5be338593c --- /dev/null +++ b/src/api/endpoints/posts/favorites/create.ts @@ -0,0 +1,51 @@ +'use strict'; + +/** + * Module dependencies + */ +import it from '../../../it'; +import Favorite from '../../../models/favorite'; +import Post from '../../../models/post'; + +/** + * Favorite a post + * + * @param {any} params + * @param {any} user + * @return {Promise<any>} + */ +module.exports = (params, user) => + new Promise(async (res, rej) => { + // Get 'post_id' parameter + const [postId, postIdErr] = it(params.post_id, 'id', true); + if (postIdErr) return rej('invalid post_id param'); + + // Get favoritee + const post = await Post.findOne({ + _id: new mongo.ObjectID(postId) + }); + + if (post === null) { + return rej('post not found'); + } + + // if already favorited + const exist = await Favorite.findOne({ + post_id: post._id, + user_id: user._id + }); + + if (exist !== null) { + return rej('already favorited'); + } + + // Create favorite + await Favorite.insert({ + created_at: new Date(), + post_id: post._id, + user_id: user._id + }); + + // Send response + res(); + }); |