mizzkey/src/server/api/endpoints/users/recommendation.ts

93 lines
2.2 KiB
TypeScript
Raw Normal View History

const ms = require('ms');
2017-03-08 19:50:09 +01:00
import $ from 'cafy';
2018-06-18 02:54:53 +02:00
import User, { pack, ILocalUser } 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 04:49:08 +01:00
import getParams from '../../get-params';
2016-12-28 23:49:51 +01:00
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-07-05 19:58:29 +02:00
export default (params: any, me: 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);
2018-10-06 10:19:41 +02:00
if (config.user_recommendation && config.user_recommendation.external) {
2018-10-09 19:08:26 +02:00
const userName = me.username;
const hostName = config.hostname;
const limit = params.limit;
const offset = params.offset;
const timeout = config.user_recommendation.timeout;
const engine = config.user_recommendation.engine;
2018-10-06 10:21:27 +02:00
const url = engine
.replace('{{host}}', hostName)
.replace('{{user}}', userName)
.replace('{{limit}}', limit)
2018-10-09 19:08:26 +02:00
.replace('{{offset}}', offset);
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 },
lastUsedAt: {
$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
}
2016-12-28 23:49:51 +01:00
});