互換性のためのコードを追加 & #2623
This commit is contained in:
@@ -1,51 +1,65 @@
|
||||
/**
|
||||
* Module dependencies
|
||||
*/
|
||||
import $ from 'cafy'; import ID from '../../../misc/cafy-id';
|
||||
import Note, { pack } from '../../../models/note';
|
||||
import getParams from '../get-params';
|
||||
|
||||
export const meta = {
|
||||
desc: {
|
||||
'ja-JP': '投稿を取得します。'
|
||||
},
|
||||
|
||||
params: {
|
||||
local: $.bool.optional.note({
|
||||
desc: {
|
||||
'ja-JP': 'ローカルの投稿に限定するか否か'
|
||||
}
|
||||
}),
|
||||
|
||||
reply: $.bool.optional.note({
|
||||
desc: {
|
||||
'ja-JP': '返信に限定するか否か'
|
||||
}
|
||||
}),
|
||||
|
||||
renote: $.bool.optional.note({
|
||||
desc: {
|
||||
'ja-JP': 'Renoteに限定するか否か'
|
||||
}
|
||||
}),
|
||||
|
||||
withFiles: $.bool.optional.note({
|
||||
desc: {
|
||||
'ja-JP': 'ファイルが添付された投稿に限定するか否か'
|
||||
}
|
||||
}),
|
||||
|
||||
media: $.bool.optional.note({
|
||||
desc: {
|
||||
'ja-JP': 'ファイルが添付された投稿に限定するか否か (このパラメータは廃止予定です。代わりに withFiles を使ってください。)'
|
||||
}
|
||||
}),
|
||||
|
||||
poll: $.bool.optional.note({
|
||||
desc: {
|
||||
'ja-JP': 'アンケートが添付された投稿に限定するか否か'
|
||||
}
|
||||
}),
|
||||
|
||||
limit: $.num.optional.range(1, 100).note({
|
||||
default: 10
|
||||
}),
|
||||
|
||||
sinceId: $.type(ID).optional.note({}),
|
||||
|
||||
untilId: $.type(ID).optional.note({}),
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* Get all notes
|
||||
*/
|
||||
export default (params: any) => new Promise(async (res, rej) => {
|
||||
// Get 'local' parameter
|
||||
const [local, localErr] = $.bool.optional.get(params.local);
|
||||
if (localErr) return rej('invalid local param');
|
||||
|
||||
// Get 'reply' parameter
|
||||
const [reply, replyErr] = $.bool.optional.get(params.reply);
|
||||
if (replyErr) return rej('invalid reply param');
|
||||
|
||||
// Get 'renote' parameter
|
||||
const [renote, renoteErr] = $.bool.optional.get(params.renote);
|
||||
if (renoteErr) return rej('invalid renote param');
|
||||
|
||||
// Get 'files' parameter
|
||||
const [files, filesErr] = $.bool.optional.get(params.files);
|
||||
if (filesErr) return rej('invalid files param');
|
||||
|
||||
// Get 'poll' parameter
|
||||
const [poll, pollErr] = $.bool.optional.get(params.poll);
|
||||
if (pollErr) return rej('invalid poll param');
|
||||
|
||||
// Get 'bot' parameter
|
||||
//const [bot, botErr] = $.bool.optional.get(params.bot);
|
||||
//if (botErr) return rej('invalid bot param');
|
||||
|
||||
// Get 'limit' parameter
|
||||
const [limit = 10, limitErr] = $.num.optional.range(1, 100).get(params.limit);
|
||||
if (limitErr) return rej('invalid limit param');
|
||||
|
||||
// Get 'sinceId' parameter
|
||||
const [sinceId, sinceIdErr] = $.type(ID).optional.get(params.sinceId);
|
||||
if (sinceIdErr) return rej('invalid sinceId param');
|
||||
|
||||
// Get 'untilId' parameter
|
||||
const [untilId, untilIdErr] = $.type(ID).optional.get(params.untilId);
|
||||
if (untilIdErr) return rej('invalid untilId param');
|
||||
const [ps, psErr] = getParams(meta, params);
|
||||
if (psErr) throw psErr;
|
||||
|
||||
// Check if both of sinceId and untilId is specified
|
||||
if (sinceId && untilId) {
|
||||
if (ps.sinceId && ps.untilId) {
|
||||
return rej('cannot set sinceId and untilId');
|
||||
}
|
||||
|
||||
@@ -56,35 +70,37 @@ export default (params: any) => new Promise(async (res, rej) => {
|
||||
const query = {
|
||||
visibility: 'public'
|
||||
} as any;
|
||||
if (sinceId) {
|
||||
if (ps.sinceId) {
|
||||
sort._id = 1;
|
||||
query._id = {
|
||||
$gt: sinceId
|
||||
$gt: ps.sinceId
|
||||
};
|
||||
} else if (untilId) {
|
||||
} else if (ps.untilId) {
|
||||
query._id = {
|
||||
$lt: untilId
|
||||
$lt: ps.untilId
|
||||
};
|
||||
}
|
||||
|
||||
if (local) {
|
||||
if (ps.local) {
|
||||
query['_user.host'] = null;
|
||||
}
|
||||
|
||||
if (reply != undefined) {
|
||||
query.replyId = reply ? { $exists: true, $ne: null } : null;
|
||||
if (ps.reply != undefined) {
|
||||
query.replyId = ps.reply ? { $exists: true, $ne: null } : null;
|
||||
}
|
||||
|
||||
if (renote != undefined) {
|
||||
query.renoteId = renote ? { $exists: true, $ne: null } : null;
|
||||
if (ps.renote != undefined) {
|
||||
query.renoteId = ps.renote ? { $exists: true, $ne: null } : null;
|
||||
}
|
||||
|
||||
if (files != undefined) {
|
||||
query.fileIds = files ? { $exists: true, $ne: null } : [];
|
||||
const withFiles = ps.withFiles != undefined ? ps.withFiles : ps.media;
|
||||
|
||||
if (withFiles) {
|
||||
query.fileIds = withFiles ? { $exists: true, $ne: null } : [];
|
||||
}
|
||||
|
||||
if (poll != undefined) {
|
||||
query.poll = poll ? { $exists: true, $ne: null } : null;
|
||||
if (ps.poll != undefined) {
|
||||
query.poll = ps.poll ? { $exists: true, $ne: null } : null;
|
||||
}
|
||||
|
||||
// TODO
|
||||
@@ -95,7 +111,7 @@ export default (params: any) => new Promise(async (res, rej) => {
|
||||
// Issue query
|
||||
const notes = await Note
|
||||
.find(query, {
|
||||
limit: limit,
|
||||
limit: ps.limit,
|
||||
sort: sort
|
||||
});
|
||||
|
||||
|
Reference in New Issue
Block a user