2017-03-11 15:31:19 -07:00
|
|
|
const ms = require('ms');
|
2017-03-08 11:50:09 -07:00
|
|
|
import $ from 'cafy';
|
2018-06-17 18:54:53 -06:00
|
|
|
import User, { pack, ILocalUser } from '../../../../models/user';
|
2018-04-18 21:43:25 -06:00
|
|
|
import { getFriendIds } from '../../common/get-friends';
|
2018-04-18 03:46:38 -06:00
|
|
|
import Mute from '../../../../models/mute';
|
2018-10-06 01:03:18 -06:00
|
|
|
import * as request from 'request'
|
|
|
|
import config from '../../../../config'
|
2016-12-28 15:49:51 -07:00
|
|
|
|
2018-07-16 13:36:44 -06:00
|
|
|
export const meta = {
|
|
|
|
desc: {
|
2018-08-28 15:59:43 -06:00
|
|
|
'ja-JP': 'おすすめのユーザー一覧を取得します。'
|
2018-07-16 13:36:44 -06:00
|
|
|
},
|
|
|
|
|
|
|
|
requireCredential: true,
|
|
|
|
|
|
|
|
kind: 'account-read'
|
|
|
|
};
|
|
|
|
|
2018-07-05 11:58:29 -06:00
|
|
|
export default (params: any, me: ILocalUser) => new Promise(async (res, rej) => {
|
2018-10-06 02:19:41 -06:00
|
|
|
if (config.user_recommendation && config.user_recommendation.external) {
|
2018-10-06 01:03:18 -06:00
|
|
|
var userName = me.username
|
|
|
|
var hostName = config.hostname
|
|
|
|
var limit = params.limit
|
|
|
|
var offset = params.offset
|
|
|
|
var timeout = config.user_recommendation.timeout
|
|
|
|
var engine = config.user_recommendation.engine
|
|
|
|
var url
|
|
|
|
url = engine
|
|
|
|
url = url.replace('{{host}}', hostName)
|
|
|
|
url = url.replace('{{user}}', userName)
|
|
|
|
url = url.replace('{{limit}}', limit)
|
|
|
|
url = url.replace('{{offset}}', offset)
|
|
|
|
request(
|
|
|
|
{
|
|
|
|
url: url,
|
|
|
|
timeout: timeout,
|
|
|
|
json: true,
|
|
|
|
followRedirect: true,
|
|
|
|
followAllRedirects: true
|
2017-03-11 15:31:19 -07:00
|
|
|
},
|
2018-10-06 01:03:18 -06:00
|
|
|
function (error: any, response: any, body: any) {
|
|
|
|
if (!error && response.statusCode == 200) {
|
|
|
|
res(body)
|
|
|
|
} else {
|
|
|
|
res([])
|
2018-03-27 01:51:12 -06:00
|
|
|
}
|
2016-12-28 15:49:51 -07:00
|
|
|
}
|
2018-10-06 01:03:18 -06:00
|
|
|
)
|
|
|
|
} else {
|
|
|
|
// Get 'limit' parameter
|
|
|
|
const [limit = 10, limitErr] = $.num.optional.range(1, 100).get(params.limit);
|
|
|
|
if (limitErr) return rej('invalid limit param');
|
|
|
|
|
|
|
|
// Get 'offset' parameter
|
|
|
|
const [offset = 0, offsetErr] = $.num.optional.min(0).get(params.offset);
|
|
|
|
if (offsetErr) return rej('invalid offset param');
|
|
|
|
|
|
|
|
// ID list of the user itself and other users who the user follows
|
|
|
|
const followingIds = await getFriendIds(me._id);
|
|
|
|
|
|
|
|
// ミュートしているユーザーを取得
|
|
|
|
const mutedUserIds = (await Mute.find({
|
|
|
|
muterId: me._id
|
|
|
|
})).map(m => m.muteeId);
|
|
|
|
|
|
|
|
const users = await User
|
|
|
|
.find({
|
|
|
|
_id: {
|
|
|
|
$nin: followingIds.concat(mutedUserIds)
|
|
|
|
},
|
|
|
|
isLocked: false,
|
|
|
|
$or: [{
|
|
|
|
lastUsedAt: {
|
|
|
|
$gte: new Date(Date.now() - ms('7days'))
|
|
|
|
}
|
|
|
|
}, {
|
|
|
|
host: null
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
limit: limit,
|
|
|
|
skip: offset,
|
|
|
|
sort: {
|
|
|
|
followersCount: -1
|
|
|
|
}
|
|
|
|
});
|
2016-12-28 15:49:51 -07:00
|
|
|
|
2018-10-06 01:03:18 -06:00
|
|
|
// Serialize
|
|
|
|
res(await Promise.all(users.map(async user =>
|
|
|
|
await pack(user, me, { detail: true }))));
|
|
|
|
}
|
2016-12-28 15:49:51 -07:00
|
|
|
});
|