2017-03-11 23:31:19 +01:00
|
|
|
const ms = require('ms');
|
2017-03-08 19:50:09 +01:00
|
|
|
import $ from 'cafy';
|
2018-11-02 05:47:44 +01:00
|
|
|
import User, { pack } from '../../../../models/user';
|
2018-04-19 05:43:25 +02:00
|
|
|
import { getFriendIds } from '../../common/get-friends';
|
2018-04-18 11:46:38 +02:00
|
|
|
import Mute from '../../../../models/mute';
|
2018-10-09 19:08:26 +02:00
|
|
|
import * as request from 'request';
|
|
|
|
import config from '../../../../config';
|
2018-11-02 05:47:44 +01:00
|
|
|
import define from '../../define';
|
2018-11-21 15:44:59 +01:00
|
|
|
import fetchMeta from '../../../../misc/fetch-meta';
|
|
|
|
|
2018-07-16 21:36:44 +02:00
|
|
|
export const meta = {
|
|
|
|
desc: {
|
2018-08-28 23:59:43 +02:00
|
|
|
'ja-JP': 'おすすめのユーザー一覧を取得します。'
|
2018-07-16 21:36:44 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
requireCredential: true,
|
|
|
|
|
2018-11-02 04:49:08 +01:00
|
|
|
kind: 'account-read',
|
|
|
|
|
|
|
|
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-11-02 05:47:44 +01:00
|
|
|
export default define(meta, (ps, me) => new Promise(async (res, rej) => {
|
2018-11-21 15:44:59 +01:00
|
|
|
const instance = await fetchMeta();
|
|
|
|
|
|
|
|
if (instance.enableExternalUserRecommendation) {
|
2018-10-09 19:08:26 +02:00
|
|
|
const userName = me.username;
|
|
|
|
const hostName = config.hostname;
|
2018-11-02 05:47:44 +01:00
|
|
|
const limit = ps.limit;
|
|
|
|
const offset = ps.offset;
|
2018-11-21 15:44:59 +01:00
|
|
|
const timeout = instance.externalUserRecommendationTimeout;
|
|
|
|
const engine = instance.externalUserRecommendationEngine;
|
2018-10-06 10:21:27 +02:00
|
|
|
const url = engine
|
|
|
|
.replace('{{host}}', hostName)
|
|
|
|
.replace('{{user}}', userName)
|
2018-11-02 05:47:44 +01:00
|
|
|
.replace('{{limit}}', limit.toString())
|
|
|
|
.replace('{{offset}}', offset.toString());
|
2018-10-09 19:08:26 +02:00
|
|
|
|
2018-10-13 06:13:15 +02:00
|
|
|
request({
|
|
|
|
url: url,
|
|
|
|
proxy: config.proxy,
|
|
|
|
timeout: timeout,
|
|
|
|
json: true,
|
|
|
|
followRedirect: true,
|
|
|
|
followAllRedirects: true
|
|
|
|
}, (error: any, response: any, body: any) => {
|
|
|
|
if (!error && response.statusCode == 200) {
|
|
|
|
res(body);
|
|
|
|
} else {
|
|
|
|
res([]);
|
2016-12-28 23:49:51 +01:00
|
|
|
}
|
2018-10-13 06:13:15 +02:00
|
|
|
});
|
2018-10-06 09:03:18 +02:00
|
|
|
} else {
|
|
|
|
// 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)
|
|
|
|
},
|
2018-10-09 19:04:16 +02:00
|
|
|
isLocked: { $ne: true },
|
2018-11-23 23:04:29 +01:00
|
|
|
updatedAt: {
|
2018-10-12 06:48:26 +02:00
|
|
|
$gte: new Date(Date.now() - ms('7days'))
|
|
|
|
},
|
|
|
|
host: null
|
2018-10-06 09:03:18 +02:00
|
|
|
}, {
|
2018-11-02 04:49:08 +01:00
|
|
|
limit: ps.limit,
|
|
|
|
skip: ps.offset,
|
2018-10-06 09:03:18 +02:00
|
|
|
sort: {
|
|
|
|
followersCount: -1
|
|
|
|
}
|
|
|
|
});
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2018-11-02 04:49:08 +01:00
|
|
|
res(await Promise.all(users.map(user => pack(user, me, { detail: true }))));
|
2018-10-06 09:03:18 +02:00
|
|
|
}
|
2018-11-02 05:47:44 +01:00
|
|
|
}));
|