2015-07-21 00:35:58 -04:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
|
|
/**
|
2016-01-07 22:18:36 +01:00
|
|
|
* Module dependencies
|
2015-07-21 00:35:58 -04:00
|
|
|
*/
|
|
|
|
|
var path = require('path'),
|
2017-06-24 12:36:28 +08:00
|
|
|
config = require(path.resolve('./config/config')),
|
2018-05-07 16:30:52 +08:00
|
|
|
dataLog = require(path.resolve('./config/lib/data-log')),
|
2015-07-25 16:53:11 -04:00
|
|
|
mongoose = require('mongoose'),
|
2018-05-04 11:58:15 +08:00
|
|
|
objectId = require('mongodb').ObjectId,
|
2015-07-25 16:53:11 -04:00
|
|
|
User = mongoose.model('User'),
|
2017-09-11 18:15:46 +08:00
|
|
|
Peer = mongoose.model('Peer'),
|
2017-09-12 10:53:42 +08:00
|
|
|
Torrent = mongoose.model('Torrent'),
|
2017-09-11 18:15:46 +08:00
|
|
|
Complete = mongoose.model('Complete'),
|
2018-05-26 12:58:22 +08:00
|
|
|
Invitation = mongoose.model('Invitation'),
|
2017-10-17 16:32:56 +08:00
|
|
|
moment = require('moment'),
|
2017-10-14 23:15:53 +08:00
|
|
|
async = require('async'),
|
2018-05-24 15:51:51 +08:00
|
|
|
ScoreLog = mongoose.model('ScoreLog'),
|
2018-05-07 16:30:52 +08:00
|
|
|
scoreUpdate = require(path.resolve('./config/lib/score')).update,
|
2017-06-24 12:36:28 +08:00
|
|
|
errorHandler = require(path.resolve('./modules/core/server/controllers/errors.server.controller')),
|
2018-05-25 17:56:14 +08:00
|
|
|
traceLogCreate = require(path.resolve('./config/lib/tracelog')).create,
|
2018-05-29 15:50:18 +08:00
|
|
|
history = require(path.resolve('./config/lib/history')),
|
2018-05-25 17:56:14 +08:00
|
|
|
populateStrings = require(path.resolve('./config/lib/populateStrings'));
|
2015-07-21 00:35:58 -04:00
|
|
|
|
2017-09-11 18:15:46 +08:00
|
|
|
const PEERSTATE_SEEDER = 'seeder';
|
|
|
|
|
const PEERSTATE_LEECHER = 'leecher';
|
|
|
|
|
|
2017-06-24 12:36:28 +08:00
|
|
|
var traceConfig = config.meanTorrentConfig.trace;
|
2018-05-29 15:50:18 +08:00
|
|
|
var historyConfig = config.meanTorrentConfig.history;
|
2017-10-14 23:15:53 +08:00
|
|
|
var mtDebug = require(path.resolve('./config/lib/debug'));
|
2017-12-17 22:39:01 +08:00
|
|
|
var appConfig = config.meanTorrentConfig.app;
|
2017-12-15 17:51:31 +08:00
|
|
|
var serverMessage = require(path.resolve('./config/lib/server-message'));
|
2017-12-16 16:17:18 +08:00
|
|
|
var serverNoticeConfig = config.meanTorrentConfig.serverNotice;
|
2017-12-21 21:26:16 +08:00
|
|
|
var announceConfig = config.meanTorrentConfig.announce;
|
2018-05-07 16:30:52 +08:00
|
|
|
var scoreConfig = config.meanTorrentConfig.score;
|
2018-06-10 00:59:20 +08:00
|
|
|
var inviteConfig = config.meanTorrentConfig.invite;
|
2017-12-17 22:39:01 +08:00
|
|
|
|
2015-07-21 00:35:58 -04:00
|
|
|
/**
|
|
|
|
|
* Show the current user
|
|
|
|
|
*/
|
|
|
|
|
exports.read = function (req, res) {
|
2015-07-25 16:53:11 -04:00
|
|
|
res.json(req.model);
|
2015-07-21 00:35:58 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Update a User
|
|
|
|
|
*/
|
|
|
|
|
exports.update = function (req, res) {
|
2015-07-25 16:53:11 -04:00
|
|
|
var user = req.model;
|
2017-12-17 22:39:01 +08:00
|
|
|
var accessChanged = false;
|
2015-07-21 00:35:58 -04:00
|
|
|
|
2017-12-17 22:39:01 +08:00
|
|
|
accessChanged = (user.upload_access !== req.body.upload_access);
|
2015-12-10 20:31:51 +01:00
|
|
|
// For security purposes only merge these parameters
|
2015-07-25 16:53:11 -04:00
|
|
|
user.firstName = req.body.firstName;
|
|
|
|
|
user.lastName = req.body.lastName;
|
|
|
|
|
user.displayName = user.firstName + ' ' + user.lastName;
|
|
|
|
|
user.roles = req.body.roles;
|
2017-12-08 15:32:46 +08:00
|
|
|
user.upload_access = req.body.upload_access;
|
2018-05-26 20:16:45 +08:00
|
|
|
user.remarks = req.body.remarks;
|
2015-07-21 00:35:58 -04:00
|
|
|
|
2015-07-25 16:53:11 -04:00
|
|
|
user.save(function (err) {
|
|
|
|
|
if (err) {
|
2016-10-10 16:00:24 -07:00
|
|
|
return res.status(422).send({
|
2015-07-25 16:53:11 -04:00
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
}
|
2015-07-21 00:35:58 -04:00
|
|
|
|
2015-07-25 16:53:11 -04:00
|
|
|
res.json(user);
|
2017-06-24 12:36:28 +08:00
|
|
|
|
2017-12-17 22:39:01 +08:00
|
|
|
//add server message
|
|
|
|
|
if (serverNoticeConfig.action.userUploadAccessChanged.enable && accessChanged) {
|
|
|
|
|
serverMessage.addMessage(user._id, serverNoticeConfig.action.userUploadAccessChanged.title, serverNoticeConfig.action.userUploadAccessChanged.content, {
|
|
|
|
|
upload_access: user.upload_access === 'review' ? 'UPLOADER.FIELDS_REVIEW' : 'UPLOADER.FIELDS_PASS',
|
|
|
|
|
by_name: req.user.displayName,
|
|
|
|
|
by_id: req.user._id,
|
|
|
|
|
site_name: appConfig.name
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2017-06-24 12:36:28 +08:00
|
|
|
//create trace log
|
2018-05-29 15:50:18 +08:00
|
|
|
traceLogCreate(req, traceConfig.action.adminUserEdit, {
|
2017-06-24 13:53:32 +08:00
|
|
|
user: user._id,
|
2017-06-24 12:36:28 +08:00
|
|
|
firstName: req.body.firstName,
|
|
|
|
|
lastName: req.body.lastName,
|
2018-06-11 15:19:52 +08:00
|
|
|
roles: req.body.roles,
|
|
|
|
|
upload_access: req.body.upload_access,
|
|
|
|
|
remarks: req.body.remarks
|
2017-06-24 12:36:28 +08:00
|
|
|
});
|
2015-07-25 16:53:11 -04:00
|
|
|
});
|
2015-07-21 00:35:58 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Delete a user
|
|
|
|
|
*/
|
|
|
|
|
exports.delete = function (req, res) {
|
2015-07-25 16:53:11 -04:00
|
|
|
var user = req.model;
|
2015-07-21 00:35:58 -04:00
|
|
|
|
2015-07-25 16:53:11 -04:00
|
|
|
user.remove(function (err) {
|
|
|
|
|
if (err) {
|
2016-10-10 16:00:24 -07:00
|
|
|
return res.status(422).send({
|
2015-07-25 16:53:11 -04:00
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
}
|
2015-07-21 00:35:58 -04:00
|
|
|
|
2015-07-25 16:53:11 -04:00
|
|
|
res.json(user);
|
2017-06-24 12:36:28 +08:00
|
|
|
|
|
|
|
|
//create trace log
|
2018-05-29 15:50:18 +08:00
|
|
|
traceLogCreate(req, traceConfig.action.adminUserDelete, {
|
2017-06-24 13:53:32 +08:00
|
|
|
user: user._id
|
2017-06-24 12:36:28 +08:00
|
|
|
});
|
2015-07-25 16:53:11 -04:00
|
|
|
});
|
2015-07-21 00:35:58 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* List of Users
|
|
|
|
|
*/
|
|
|
|
|
exports.list = function (req, res) {
|
2017-10-14 23:15:53 +08:00
|
|
|
var condition = {};
|
|
|
|
|
var keysA = [];
|
|
|
|
|
var skip = 0;
|
|
|
|
|
var limit = 0;
|
|
|
|
|
var isVip = false;
|
|
|
|
|
var isOper = false;
|
|
|
|
|
var isAdmin = false;
|
2017-11-06 15:47:38 +08:00
|
|
|
var status = undefined;
|
2017-10-14 23:15:53 +08:00
|
|
|
|
|
|
|
|
if (req.query.skip !== undefined) {
|
|
|
|
|
skip = parseInt(req.query.skip, 10);
|
|
|
|
|
}
|
|
|
|
|
if (req.query.limit !== undefined) {
|
|
|
|
|
limit = parseInt(req.query.limit, 10);
|
|
|
|
|
}
|
|
|
|
|
if (req.query.isVip !== undefined) {
|
|
|
|
|
isVip = req.query.isVip;
|
|
|
|
|
}
|
|
|
|
|
if (req.query.isOper !== undefined) {
|
|
|
|
|
isOper = req.query.isOper;
|
|
|
|
|
}
|
|
|
|
|
if (req.query.isAdmin !== undefined) {
|
|
|
|
|
isAdmin = req.query.isAdmin;
|
|
|
|
|
}
|
2017-12-03 16:47:57 +08:00
|
|
|
if (req.query.status !== undefined && req.query.status !== 'all') {
|
2017-11-06 15:47:38 +08:00
|
|
|
status = req.query.status;
|
|
|
|
|
}
|
2017-10-14 23:15:53 +08:00
|
|
|
|
|
|
|
|
if (req.query.keys && req.query.keys.length > 0) {
|
|
|
|
|
var keysS = req.query.keys + '';
|
|
|
|
|
var keysT = keysS.split(' ');
|
|
|
|
|
|
2018-05-04 11:58:15 +08:00
|
|
|
if (keysT.length === 1 && mongoose.Types.ObjectId.isValid(keysT[0])) {
|
|
|
|
|
keysA = objectId(keysT[0]);
|
|
|
|
|
} else {
|
|
|
|
|
keysT.forEach(function (it) {
|
|
|
|
|
var ti = new RegExp(it, 'i');
|
|
|
|
|
keysA.push(ti);
|
|
|
|
|
});
|
|
|
|
|
}
|
2017-10-14 23:15:53 +08:00
|
|
|
}
|
|
|
|
|
if (isVip === 'true') {
|
|
|
|
|
condition.isVip = true;
|
|
|
|
|
}
|
|
|
|
|
if (isOper === 'true') {
|
|
|
|
|
condition.roles = {$in: ['oper']};
|
|
|
|
|
}
|
|
|
|
|
if (isAdmin === 'true') {
|
|
|
|
|
condition.roles = {$in: ['admin']};
|
|
|
|
|
}
|
|
|
|
|
if (isOper === 'true' && isAdmin === 'true') {
|
|
|
|
|
condition.roles = {$in: ['oper', 'admin']};
|
|
|
|
|
}
|
2017-11-06 15:47:38 +08:00
|
|
|
if (status !== undefined) {
|
|
|
|
|
condition.status = status;
|
|
|
|
|
}
|
2017-10-14 23:15:53 +08:00
|
|
|
|
2018-05-04 11:58:15 +08:00
|
|
|
if (mongoose.Types.ObjectId.isValid(keysA)) {
|
|
|
|
|
condition._id = keysA;
|
|
|
|
|
} else {
|
|
|
|
|
if (keysA.length > 0) {
|
|
|
|
|
condition.$or = [
|
|
|
|
|
{displayName: {'$all': keysA}},
|
|
|
|
|
{email: {'$all': keysA}},
|
|
|
|
|
{passkey: {'$all': keysA}},
|
|
|
|
|
{username: {'$all': keysA}}
|
|
|
|
|
];
|
|
|
|
|
}
|
2017-10-14 23:15:53 +08:00
|
|
|
}
|
|
|
|
|
|
2017-12-24 08:57:17 +08:00
|
|
|
mtDebug.debugBlue(condition, 'ADMIN_USERS_LIST');
|
2017-10-14 23:15:53 +08:00
|
|
|
|
|
|
|
|
var countQuery = function (callback) {
|
|
|
|
|
User.count(condition, function (err, count) {
|
|
|
|
|
if (err) {
|
|
|
|
|
callback(err, null);
|
|
|
|
|
} else {
|
|
|
|
|
callback(null, count);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
var findQuery = function (callback) {
|
|
|
|
|
User.find(condition, '-salt -password -providerData')
|
|
|
|
|
.sort('-created')
|
2018-05-13 16:48:15 +08:00
|
|
|
.populate('invited_by', 'username displayName profileImageURL isVip score uploaded downloaded')
|
2017-10-19 18:44:22 +08:00
|
|
|
.populate('makers', 'name')
|
2017-10-14 23:15:53 +08:00
|
|
|
.skip(skip)
|
|
|
|
|
.limit(limit)
|
|
|
|
|
.exec(function (err, users) {
|
|
|
|
|
if (err) {
|
|
|
|
|
callback(err, null);
|
|
|
|
|
} else {
|
|
|
|
|
callback(null, users);
|
|
|
|
|
}
|
2015-07-25 16:53:11 -04:00
|
|
|
});
|
2017-10-14 23:15:53 +08:00
|
|
|
};
|
2015-07-21 00:35:58 -04:00
|
|
|
|
2017-10-14 23:15:53 +08:00
|
|
|
async.parallel([countQuery, findQuery], function (err, results) {
|
|
|
|
|
if (err) {
|
|
|
|
|
mtDebug.debugRed(err);
|
|
|
|
|
return res.status(422).send(err);
|
|
|
|
|
} else {
|
|
|
|
|
res.json({rows: results[1], total: results[0]});
|
|
|
|
|
}
|
2015-07-25 16:53:11 -04:00
|
|
|
});
|
2015-07-21 00:35:58 -04:00
|
|
|
};
|
|
|
|
|
|
2017-06-06 17:29:23 +08:00
|
|
|
/**
|
|
|
|
|
* updateUserRole
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
2017-06-06 16:33:59 +08:00
|
|
|
exports.updateUserRole = function (req, res) {
|
|
|
|
|
var user = req.model;
|
|
|
|
|
|
|
|
|
|
user.update({
|
|
|
|
|
$set: {roles: req.body.userRole}
|
|
|
|
|
}).exec(function (err, result) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
user.roles = req.body.userRole;
|
|
|
|
|
res.json(user);
|
2017-06-24 12:36:28 +08:00
|
|
|
|
2017-12-17 22:39:01 +08:00
|
|
|
//add server message
|
|
|
|
|
if (serverNoticeConfig.action.userRoleChanged.enable) {
|
|
|
|
|
serverMessage.addMessage(user._id, serverNoticeConfig.action.userRoleChanged.title, serverNoticeConfig.action.userRoleChanged.content, {
|
|
|
|
|
by_name: req.user.displayName,
|
|
|
|
|
by_id: req.user._id,
|
|
|
|
|
user_role: req.body.userRole[0],
|
|
|
|
|
site_name: appConfig.name
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2017-06-24 12:36:28 +08:00
|
|
|
//create trace log
|
2018-05-29 15:50:18 +08:00
|
|
|
traceLogCreate(req, traceConfig.action.adminUpdateUserRole, {
|
2017-06-24 13:53:32 +08:00
|
|
|
user: user._id,
|
2018-05-29 15:50:18 +08:00
|
|
|
role: req.body.userRole[0]
|
|
|
|
|
});
|
|
|
|
|
//write history
|
|
|
|
|
history.insert(user._id, historyConfig.action.adminUpdateUserRole, {
|
|
|
|
|
role: req.body.userRole[0],
|
|
|
|
|
by: req.user._id
|
2017-06-24 12:36:28 +08:00
|
|
|
});
|
2017-06-06 16:33:59 +08:00
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2017-06-06 17:29:23 +08:00
|
|
|
/**
|
|
|
|
|
* updateUserStatus
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.updateUserStatus = function (req, res) {
|
|
|
|
|
var user = req.model;
|
2018-06-09 21:37:10 +08:00
|
|
|
var tp = {
|
|
|
|
|
status: req.body.userStatus,
|
2018-06-10 00:59:20 +08:00
|
|
|
banReason: {
|
|
|
|
|
reason: req.body.banReason,
|
|
|
|
|
params: undefined
|
|
|
|
|
}
|
2018-06-09 21:37:10 +08:00
|
|
|
};
|
2017-12-20 17:37:22 +08:00
|
|
|
|
|
|
|
|
if (user.status === 'idle' && req.body.userStatus === 'normal') {
|
|
|
|
|
tp.last_signed = Date.now();
|
|
|
|
|
}
|
2017-06-06 17:29:23 +08:00
|
|
|
|
|
|
|
|
user.update({
|
2017-12-20 17:37:22 +08:00
|
|
|
$set: tp
|
2017-06-06 17:29:23 +08:00
|
|
|
}).exec(function (err, result) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
user.status = req.body.userStatus;
|
|
|
|
|
res.json(user);
|
2017-06-24 12:36:28 +08:00
|
|
|
|
|
|
|
|
//create trace log
|
2018-05-29 15:50:18 +08:00
|
|
|
traceLogCreate(req, traceConfig.action.adminUpdateUserStatus, {
|
2017-06-24 13:53:32 +08:00
|
|
|
user: user._id,
|
2018-06-09 21:37:10 +08:00
|
|
|
status: req.body.userStatus,
|
|
|
|
|
reason: req.body.banReason === '' ? 'VALUE_NULL' : req.body.banReason
|
2017-06-24 12:36:28 +08:00
|
|
|
});
|
2018-06-10 00:59:20 +08:00
|
|
|
|
2018-05-29 18:05:10 +08:00
|
|
|
// write history
|
|
|
|
|
history.insert(user._id, historyConfig.action.adminUpdateUserStatus, {
|
|
|
|
|
status: req.body.userStatus,
|
2018-06-09 21:37:10 +08:00
|
|
|
reason: req.body.banReason === '' ? 'VALUE_NULL' : req.body.banReason,
|
2018-05-29 18:05:10 +08:00
|
|
|
by: req.user._id
|
|
|
|
|
});
|
2018-06-10 00:59:20 +08:00
|
|
|
|
|
|
|
|
//ban inviter
|
|
|
|
|
if (req.body.userStatus === 'banned' && inviteConfig.banUserInviter && user.invited_by) {
|
|
|
|
|
if (!user.invited_by.isOper) {
|
|
|
|
|
if (!user.invited_by.isVip || (user.invited_by.isVip && inviteConfig.banUserInviterVip)) {
|
|
|
|
|
user.invited_by.update({
|
|
|
|
|
$set: {
|
|
|
|
|
status: req.body.userStatus,
|
|
|
|
|
banReason: {
|
|
|
|
|
reason: 'BANNED.YOU_ARE_BANNED_FROM_INVITED_USER',
|
|
|
|
|
params: {
|
|
|
|
|
uname: user.displayName,
|
|
|
|
|
uReason: req.body.banReason
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}).exec(function (err, result) {
|
|
|
|
|
if (!err) {
|
|
|
|
|
//create trace log
|
|
|
|
|
traceLogCreate(req, traceConfig.action.adminBanUserInviter, {
|
|
|
|
|
user: user.invited_by._id,
|
|
|
|
|
status: req.body.userStatus,
|
|
|
|
|
invited_user: user._id,
|
|
|
|
|
reason: req.body.banReason
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// write history
|
|
|
|
|
history.insert(user.invited_by._id, historyConfig.action.adminBanUserInviter, {
|
|
|
|
|
status: req.body.userStatus,
|
|
|
|
|
uname: user.displayName,
|
|
|
|
|
reason: req.body.banReason === '' ? 'VALUE_NULL' : req.body.banReason,
|
|
|
|
|
by: req.user._id
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2017-06-06 17:29:23 +08:00
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2017-06-07 15:54:16 +08:00
|
|
|
/**
|
|
|
|
|
* updateUserScore
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.updateUserScore = function (req, res) {
|
|
|
|
|
var user = req.model;
|
2018-05-07 16:30:52 +08:00
|
|
|
var sv = parseFloat(req.body.userScore.toFixed(2));
|
2017-06-07 15:54:16 +08:00
|
|
|
|
2018-05-08 12:13:54 +08:00
|
|
|
user.score = Math.max(user.score + sv, 0);
|
|
|
|
|
|
2017-06-07 16:34:22 +08:00
|
|
|
user.save(function (err) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
res.json(user);
|
2017-06-24 12:36:28 +08:00
|
|
|
|
2018-05-24 15:51:51 +08:00
|
|
|
//write score detail log
|
|
|
|
|
var sl = new ScoreLog({
|
|
|
|
|
user: user,
|
|
|
|
|
score: sv,
|
|
|
|
|
reason: {
|
|
|
|
|
event: scoreConfig.action.adminModify.name,
|
2018-06-06 00:48:30 +08:00
|
|
|
event_str: scoreConfig.action.adminModify.content,
|
|
|
|
|
params: {
|
|
|
|
|
uid: req.user._id,
|
|
|
|
|
uname: req.user.displayName
|
|
|
|
|
}
|
2018-05-24 15:51:51 +08:00
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
sl.save(function (err) {
|
|
|
|
|
if (err) {
|
|
|
|
|
mtDebug.debugError(err);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
//write score days/months log
|
2018-05-07 16:30:52 +08:00
|
|
|
dataLog.scoreLog(user, sv);
|
2017-06-24 12:36:28 +08:00
|
|
|
//create trace log
|
2018-05-29 15:50:18 +08:00
|
|
|
traceLogCreate(req, traceConfig.action.adminUpdateUserScore, {
|
2017-06-24 13:53:32 +08:00
|
|
|
user: user._id,
|
2018-05-24 15:51:51 +08:00
|
|
|
score: sv
|
2017-06-24 12:36:28 +08:00
|
|
|
});
|
2018-05-29 15:50:18 +08:00
|
|
|
//write history
|
|
|
|
|
history.insert(user._id, historyConfig.action.adminUpdateUserScore, {
|
|
|
|
|
score: sv,
|
|
|
|
|
by: req.user._id
|
|
|
|
|
});
|
2017-06-07 16:34:22 +08:00
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* updateUserUploaded
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.updateUserUploaded = function (req, res) {
|
|
|
|
|
var user = req.model;
|
|
|
|
|
|
|
|
|
|
user.uploaded = user.uploaded + parseInt(req.body.userUploaded, 10);
|
|
|
|
|
if (user.uploaded < 0) {
|
|
|
|
|
user.uploaded = 0;
|
|
|
|
|
}
|
|
|
|
|
user.save(function (err) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
res.json(user);
|
2017-06-24 12:36:28 +08:00
|
|
|
|
|
|
|
|
//create trace log
|
2018-05-29 15:50:18 +08:00
|
|
|
traceLogCreate(req, traceConfig.action.adminUpdateUserUploaded, {
|
2017-06-24 13:53:32 +08:00
|
|
|
user: user._id,
|
2017-06-24 12:36:28 +08:00
|
|
|
uploaded: req.body.userUploaded
|
|
|
|
|
});
|
2018-05-29 15:50:18 +08:00
|
|
|
//write history
|
|
|
|
|
history.insert(user._id, historyConfig.action.adminUpdateUserUploaded, {
|
|
|
|
|
uploaded: req.body.userUploaded,
|
|
|
|
|
by: req.user._id
|
|
|
|
|
});
|
2017-06-07 16:34:22 +08:00
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* updateUserDownloaded
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.updateUserDownloaded = function (req, res) {
|
|
|
|
|
var user = req.model;
|
|
|
|
|
|
|
|
|
|
user.downloaded = user.downloaded + parseInt(req.body.userDownloaded, 10);
|
|
|
|
|
if (user.downloaded < 0) {
|
|
|
|
|
user.downloaded = 0;
|
|
|
|
|
}
|
2017-06-07 15:54:16 +08:00
|
|
|
user.save(function (err) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
res.json(user);
|
2017-06-24 12:36:28 +08:00
|
|
|
|
|
|
|
|
//create trace log
|
2018-05-29 15:50:18 +08:00
|
|
|
traceLogCreate(req, traceConfig.action.adminUpdateUserDownloaded, {
|
2017-06-24 13:53:32 +08:00
|
|
|
user: user._id,
|
2017-06-24 12:36:28 +08:00
|
|
|
downloaded: req.body.userDownloaded
|
|
|
|
|
});
|
2018-05-29 15:50:18 +08:00
|
|
|
//write history
|
|
|
|
|
history.insert(user._id, historyConfig.action.adminUpdateUserDownloaded, {
|
|
|
|
|
downloaded: req.body.userDownloaded,
|
|
|
|
|
by: req.user._id
|
|
|
|
|
});
|
2017-06-07 15:54:16 +08:00
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2017-10-17 16:32:56 +08:00
|
|
|
/**
|
|
|
|
|
* addVIPMonths
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.addVIPMonths = function (req, res) {
|
|
|
|
|
var user = req.model;
|
|
|
|
|
var months = parseInt(req.params.months, 10);
|
|
|
|
|
|
|
|
|
|
if (months > 0) {
|
2018-04-29 15:05:18 +08:00
|
|
|
mtDebug.debugBlue(user.vip_start_at, 'VIP_START_AT');
|
|
|
|
|
mtDebug.debugBlue(user.vip_end_at, 'VIP_END_AT');
|
2017-10-17 16:32:56 +08:00
|
|
|
|
|
|
|
|
var now = moment(Date.now());
|
|
|
|
|
var start = moment(user.vip_start_at);
|
|
|
|
|
var end = moment(user.vip_end_at);
|
|
|
|
|
|
|
|
|
|
if (!user.vip_end_at) {
|
|
|
|
|
start = now;
|
|
|
|
|
end = moment(start).add(months, 'M');
|
|
|
|
|
} else if (now > end) {
|
|
|
|
|
start = now;
|
|
|
|
|
end = moment(start).add(months, 'M');
|
|
|
|
|
} else {
|
|
|
|
|
end = moment(end).add(months, 'M');
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-29 15:05:18 +08:00
|
|
|
mtDebug.debugBlue(start, 'VIP_NEW_START_AT');
|
|
|
|
|
mtDebug.debugBlue(end, 'VIP_NEW_END_AT');
|
2017-10-17 16:32:56 +08:00
|
|
|
|
|
|
|
|
user.vip_start_at = start;
|
|
|
|
|
user.vip_end_at = end;
|
2017-12-03 13:39:52 +08:00
|
|
|
user.status = 'normal';
|
2017-12-25 07:40:45 +08:00
|
|
|
user.hnr_warning = 0;
|
2017-10-17 16:32:56 +08:00
|
|
|
|
|
|
|
|
user.save(function (err) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
res.json(user);
|
|
|
|
|
|
2017-12-25 07:40:45 +08:00
|
|
|
//clean all H&R record
|
|
|
|
|
Complete.remove({
|
|
|
|
|
user: user._id
|
|
|
|
|
}).exec();
|
|
|
|
|
|
2017-12-15 17:51:31 +08:00
|
|
|
//add server message
|
2017-12-17 22:39:01 +08:00
|
|
|
if (serverNoticeConfig.action.userVipStatusChanged.enable) {
|
|
|
|
|
serverMessage.addMessage(user._id, serverNoticeConfig.action.userVipStatusChanged.title, serverNoticeConfig.action.userVipStatusChanged.content, {
|
|
|
|
|
vip_end_at: user.vip_end_at
|
|
|
|
|
});
|
2017-12-16 16:17:18 +08:00
|
|
|
}
|
2017-12-15 17:51:31 +08:00
|
|
|
|
2017-10-17 16:32:56 +08:00
|
|
|
//create trace log
|
2018-05-29 15:50:18 +08:00
|
|
|
traceLogCreate(req, traceConfig.action.adminUpdateUserVIPData, {
|
2017-10-17 16:32:56 +08:00
|
|
|
user: user._id,
|
2017-11-16 18:06:59 +08:00
|
|
|
reset: false,
|
2017-10-17 16:32:56 +08:00
|
|
|
months: months
|
|
|
|
|
});
|
2018-05-29 15:50:18 +08:00
|
|
|
//write history
|
|
|
|
|
history.insert(user._id, historyConfig.action.adminUpdateUserVIPData, {
|
|
|
|
|
months: months,
|
|
|
|
|
by: req.user._id
|
|
|
|
|
});
|
2017-10-17 16:32:56 +08:00
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: 'PARAMS_MONTH_ERROR'
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
};
|
2017-09-11 18:15:46 +08:00
|
|
|
|
2017-12-08 15:32:46 +08:00
|
|
|
/**
|
|
|
|
|
* uploaderList
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.uploaderList = function (req, res) {
|
|
|
|
|
var skip = 0;
|
|
|
|
|
var limit = 0;
|
|
|
|
|
|
|
|
|
|
if (req.query.skip !== undefined) {
|
|
|
|
|
skip = parseInt(req.query.skip, 10);
|
|
|
|
|
}
|
|
|
|
|
if (req.query.limit !== undefined) {
|
|
|
|
|
limit = parseInt(req.query.limit, 10);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var countQuery = function (callback) {
|
|
|
|
|
User.count({
|
|
|
|
|
uptotal: {$gt: 0}
|
|
|
|
|
}, function (err, count) {
|
|
|
|
|
if (err) {
|
|
|
|
|
callback(err, null);
|
|
|
|
|
} else {
|
|
|
|
|
callback(null, count);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
var findQuery = function (callback) {
|
|
|
|
|
User.find({
|
|
|
|
|
uptotal: {$gt: 0}
|
|
|
|
|
}, '-salt -password -providerData')
|
|
|
|
|
.sort('-uptotal')
|
|
|
|
|
.populate('makers', 'name')
|
|
|
|
|
.skip(skip)
|
|
|
|
|
.limit(limit)
|
|
|
|
|
.exec(function (err, users) {
|
|
|
|
|
if (err) {
|
|
|
|
|
callback(err, null);
|
|
|
|
|
} else {
|
|
|
|
|
callback(null, users);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
async.parallel([countQuery, findQuery], function (err, results) {
|
|
|
|
|
if (err) {
|
|
|
|
|
mtDebug.debugRed(err);
|
|
|
|
|
return res.status(422).send(err);
|
|
|
|
|
} else {
|
|
|
|
|
res.json({rows: results[1], total: results[0]});
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2017-11-16 18:06:59 +08:00
|
|
|
/**
|
|
|
|
|
* resetVIPData
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.resetVIPData = function (req, res) {
|
|
|
|
|
var user = req.model;
|
|
|
|
|
|
|
|
|
|
user.vip_start_at = '';
|
|
|
|
|
user.vip_end_at = '';
|
|
|
|
|
|
|
|
|
|
user.save(function (err) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
res.json(user);
|
|
|
|
|
|
|
|
|
|
//create trace log
|
2018-05-29 15:50:18 +08:00
|
|
|
traceLogCreate(req, traceConfig.action.adminUpdateUserVIPData, {
|
2017-11-16 18:06:59 +08:00
|
|
|
user: user._id,
|
|
|
|
|
reset: true
|
|
|
|
|
});
|
2018-05-29 15:50:18 +08:00
|
|
|
//write history
|
|
|
|
|
history.insert(user._id, historyConfig.action.adminUpdateUserVIPData, {
|
|
|
|
|
months: 'reset',
|
|
|
|
|
by: req.user._id
|
|
|
|
|
});
|
2017-11-16 18:06:59 +08:00
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2018-05-26 12:58:22 +08:00
|
|
|
/**
|
|
|
|
|
* presentInvitations
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.presentInvitations = function (req, res) {
|
|
|
|
|
var user = req.model;
|
|
|
|
|
var numbers = req.body.numbers;
|
|
|
|
|
var days = req.body.days;
|
|
|
|
|
var invitations = [];
|
|
|
|
|
|
|
|
|
|
for (var i = 0; i < numbers; i++) {
|
|
|
|
|
var invitation = new Invitation();
|
|
|
|
|
invitation.expiresat = Date.now() + (60 * 60 * 1000 * 24 * days);
|
|
|
|
|
invitation.user = user;
|
|
|
|
|
invitation.type = 'present';
|
|
|
|
|
invitation.isOfficial = false;
|
|
|
|
|
invitation.token = user.randomAsciiString(32);
|
|
|
|
|
|
|
|
|
|
invitations.push(invitation);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Invitation.insertMany(invitations, function (err, docs) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
res.json(user);
|
|
|
|
|
//create trace log
|
2018-05-29 15:50:18 +08:00
|
|
|
traceLogCreate(req, traceConfig.action.adminPresentUserInvitations, {
|
2018-05-26 12:58:22 +08:00
|
|
|
user: user._id,
|
|
|
|
|
invitations: docs
|
|
|
|
|
});
|
2018-05-29 15:50:18 +08:00
|
|
|
//write history
|
|
|
|
|
history.insert(user._id, historyConfig.action.adminPresentUserInvitations, {
|
|
|
|
|
numbers: numbers,
|
|
|
|
|
days: days,
|
|
|
|
|
by: req.user._id
|
|
|
|
|
});
|
2018-05-26 12:58:22 +08:00
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2018-05-29 18:05:10 +08:00
|
|
|
/**
|
|
|
|
|
* getUserHistory
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.getUserHistory = function (req, res) {
|
|
|
|
|
var user = req.model;
|
|
|
|
|
|
|
|
|
|
User.findById(user._id, 'history')
|
|
|
|
|
.populate({
|
|
|
|
|
path: 'history.params.by',
|
|
|
|
|
model: 'User',
|
|
|
|
|
select: 'displayName'
|
|
|
|
|
})
|
|
|
|
|
.exec(function (err, his) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
res.json(his.history);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2017-09-11 18:15:46 +08:00
|
|
|
/**
|
|
|
|
|
* list user seeding torrents
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.getUserSeeding = function (req, res) {
|
|
|
|
|
Peer.find({
|
|
|
|
|
user: req.model._id,
|
2017-12-21 21:26:16 +08:00
|
|
|
peer_status: PEERSTATE_SEEDER,
|
2018-04-30 00:06:36 +08:00
|
|
|
last_announce_at: {$gt: Date.now() - announceConfig.announceInterval - announceConfig.announceIdleTime}
|
2017-09-11 18:15:46 +08:00
|
|
|
}).sort('-peer_uploaded')
|
|
|
|
|
.populate({
|
|
|
|
|
path: 'torrent',
|
2018-05-25 17:56:14 +08:00
|
|
|
select: populateStrings.populate_torrent_string,
|
2017-12-07 12:18:56 +08:00
|
|
|
populate: [
|
|
|
|
|
{path: 'user', select: 'displayName profileImageURL'},
|
|
|
|
|
{path: 'maker', select: 'name'}
|
|
|
|
|
]
|
2017-09-11 18:15:46 +08:00
|
|
|
})
|
|
|
|
|
.exec(function (err, torrents) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
res.json(torrents);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* list user getUserLeeching torrents
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.getUserLeeching = function (req, res) {
|
|
|
|
|
Peer.find({
|
|
|
|
|
user: req.model._id,
|
2017-12-21 21:26:16 +08:00
|
|
|
peer_status: PEERSTATE_LEECHER,
|
2018-04-30 00:06:36 +08:00
|
|
|
last_announce_at: {$gt: Date.now() - announceConfig.announceInterval - announceConfig.announceIdleTime}
|
2017-09-11 18:15:46 +08:00
|
|
|
}).sort('-peer_downloaded')
|
|
|
|
|
.populate({
|
|
|
|
|
path: 'torrent',
|
2018-05-25 17:56:14 +08:00
|
|
|
select: populateStrings.populate_torrent_string,
|
2017-12-07 12:18:56 +08:00
|
|
|
populate: [
|
|
|
|
|
{path: 'user', select: 'displayName profileImageURL'},
|
|
|
|
|
{path: 'maker', select: 'name'}
|
|
|
|
|
]
|
2017-09-11 18:15:46 +08:00
|
|
|
})
|
|
|
|
|
.exec(function (err, torrents) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
res.json(torrents);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* list user warning torrents
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.getUserWarning = function (req, res) {
|
|
|
|
|
Complete.find({
|
|
|
|
|
user: req.model._id,
|
|
|
|
|
hnr_warning: true
|
|
|
|
|
}).populate({
|
|
|
|
|
path: 'torrent',
|
2018-05-25 17:56:14 +08:00
|
|
|
select: populateStrings.populate_torrent_string,
|
2017-12-07 12:18:56 +08:00
|
|
|
populate: [
|
|
|
|
|
{path: 'user', select: 'displayName profileImageURL'},
|
|
|
|
|
{path: 'maker', select: 'name'}
|
|
|
|
|
]
|
2017-09-11 18:15:46 +08:00
|
|
|
}).exec(function (err, complets) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
res.json(complets);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2017-09-12 10:53:42 +08:00
|
|
|
/**
|
|
|
|
|
* getUserUploadedTotal
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.getUserUploadedTotal = function (req, res) {
|
|
|
|
|
Torrent.count({
|
|
|
|
|
user: req.user._id
|
|
|
|
|
}, function (err, count) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
res.json({
|
|
|
|
|
total: count
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2017-10-13 19:34:42 +08:00
|
|
|
/**
|
|
|
|
|
* resetUserProfileImage
|
|
|
|
|
* @param req
|
|
|
|
|
* @param res
|
|
|
|
|
*/
|
|
|
|
|
exports.resetUserProfileImage = function (req, res) {
|
|
|
|
|
var user = req.model;
|
|
|
|
|
|
|
|
|
|
user.profileImageURL = User.schema.path('profileImageURL').defaultValue;
|
|
|
|
|
user.save(function (err) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return res.status(422).send({
|
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
res.json(user);
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2015-07-21 00:35:58 -04:00
|
|
|
/**
|
|
|
|
|
* User middleware
|
|
|
|
|
*/
|
|
|
|
|
exports.userByID = function (req, res, next, id) {
|
2015-07-25 16:53:11 -04:00
|
|
|
if (!mongoose.Types.ObjectId.isValid(id)) {
|
|
|
|
|
return res.status(400).send({
|
2018-01-12 16:53:24 +08:00
|
|
|
message: 'SERVER.INVALID_OBJECTID'
|
2015-07-25 16:53:11 -04:00
|
|
|
});
|
|
|
|
|
}
|
2015-07-26 01:40:16 -04:00
|
|
|
|
2018-05-29 18:05:10 +08:00
|
|
|
User.findById(id, '-salt -password -providerData -history')
|
2018-06-10 00:59:20 +08:00
|
|
|
.populate('invited_by', 'username displayName profileImageURL isVip isOper score uploaded downloaded')
|
2017-12-13 16:14:58 +08:00
|
|
|
.populate('makers', 'user name')
|
2017-10-19 18:44:22 +08:00
|
|
|
.exec(function (err, user) {
|
|
|
|
|
if (err) {
|
|
|
|
|
return next(err);
|
|
|
|
|
} else if (!user) {
|
|
|
|
|
return next(new Error('Failed to load user ' + id));
|
|
|
|
|
}
|
2015-07-25 16:53:11 -04:00
|
|
|
|
2017-10-19 18:44:22 +08:00
|
|
|
req.model = user;
|
|
|
|
|
next();
|
|
|
|
|
});
|
2015-07-21 00:35:58 -04:00
|
|
|
};
|