mizzkey/src/server/api/endpoints/notes/polls/recommendation.ts

68 lines
1.2 KiB
TypeScript
Raw Normal View History

2017-03-25 08:43:55 +01:00
import $ from 'cafy';
2018-03-29 13:32:18 +02:00
import Vote from '../../../../../models/poll-vote';
2018-04-07 19:30:37 +02:00
import Note, { pack } from '../../../../../models/note';
2018-06-18 02:54:53 +02:00
import { ILocalUser } from '../../../../../models/user';
2018-11-02 04:49:08 +01:00
import getParams from '../../../get-params';
2017-03-25 08:43:55 +01:00
2018-07-16 21:36:44 +02:00
export const meta = {
desc: {
2018-08-28 23:59:43 +02:00
'ja-JP': 'おすすめのアンケート一覧を取得します。',
'en-US': 'Get recommended polls.'
2018-07-16 21:36:44 +02:00
},
requireCredential: true,
2018-11-02 04:49:08 +01:00
params: {
limit: {
validator: $.num.optional.range(1, 100),
default: 10
},
offset: {
validator: $.num.optional.min(0),
default: 0
}
}
2018-07-16 21:36:44 +02:00
};
2018-07-05 19:58:29 +02:00
export default (params: any, user: ILocalUser) => new Promise(async (res, rej) => {
2018-11-02 04:49:08 +01:00
const [ps, psErr] = getParams(meta, params);
if (psErr) return rej(psErr);
2017-03-25 08:43:55 +01:00
// Get votes
const votes = await Vote.find({
2018-03-29 07:48:47 +02:00
userId: user._id
2017-03-25 08:43:55 +01:00
}, {
fields: {
_id: false,
2018-04-07 19:30:37 +02:00
noteId: true
2017-03-25 08:43:55 +01:00
}
});
2018-04-07 19:30:37 +02:00
const nin = votes && votes.length != 0 ? votes.map(v => v.noteId) : [];
2017-03-25 08:43:55 +01:00
2018-04-07 19:30:37 +02:00
const notes = await Note
2017-03-25 08:43:55 +01:00
.find({
_id: {
$nin: nin
},
2018-03-29 07:48:47 +02:00
userId: {
$ne: user._id
},
2017-03-25 08:43:55 +01:00
poll: {
$exists: true,
$ne: null
}
}, {
2018-11-02 04:49:08 +01:00
limit: ps.limit,
skip: ps.offset,
2017-03-25 08:43:55 +01:00
sort: {
_id: -1
}
});
2018-11-02 04:49:08 +01:00
res(await Promise.all(notes.map(note => pack(note, user, {
detail: true
}))));
2017-03-25 08:43:55 +01:00
});