mirror of
https://github.com/taobataoma/meanTorrent.git
synced 2026-05-05 19:56:42 +02:00
feat(check in): new feather of check in daily
This commit is contained in:
110
modules/check/server/controllers/check.server.controller.js
Normal file
110
modules/check/server/controllers/check.server.controller.js
Normal file
@@ -0,0 +1,110 @@
|
||||
'use strict';
|
||||
|
||||
/**
|
||||
* Module dependencies
|
||||
*/
|
||||
var path = require('path'),
|
||||
config = require(path.resolve('./config/config')),
|
||||
mongoose = require('mongoose'),
|
||||
errorHandler = require(path.resolve('./modules/core/server/controllers/errors.server.controller')),
|
||||
moment = require('moment'),
|
||||
User = mongoose.model('User'),
|
||||
Check = mongoose.model('Check'),
|
||||
scoreUpdate = require(path.resolve('./config/lib/score')).update;
|
||||
|
||||
var mtDebug = require(path.resolve('./config/lib/debug'));
|
||||
var scoreConfig = config.meanTorrentConfig.score;
|
||||
|
||||
/**
|
||||
* Show the current collection
|
||||
*/
|
||||
exports.get = function (req, res) {
|
||||
if (!req.user) {
|
||||
return res.status(403).json({
|
||||
message: 'SERVER.USER_IS_NOT_AUTHORIZED'
|
||||
});
|
||||
} else {
|
||||
Check.findOne({user: req.user._id}, function (err, ck) {
|
||||
if (err) {
|
||||
return res.status(422).send({
|
||||
message: errorHandler.getErrorMessage(err)
|
||||
});
|
||||
} else {
|
||||
if (!ck) {
|
||||
return res.status(422).send({
|
||||
message: 'no check data founded'
|
||||
});
|
||||
} else {
|
||||
var oldCheckDate = moment(moment(ck.lastCheckedAt).format('YYYY-MM-DD'));
|
||||
var now = moment(moment().format('YYYY-MM-DD'));
|
||||
var diff = now.diff(oldCheckDate, 'days');
|
||||
|
||||
var nck = ck.toJSON();
|
||||
nck.todayIsDone = (diff === 0 ? true : false);
|
||||
res.json(nck);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
/**
|
||||
* Update an collection
|
||||
*/
|
||||
exports.check = function (req, res) {
|
||||
if (!req.user) {
|
||||
return res.status(403).json({
|
||||
message: 'SERVER.USER_IS_NOT_AUTHORIZED'
|
||||
});
|
||||
} else {
|
||||
var score = 0;
|
||||
Check.findOne({user: req.user._id}, function (err, ck) {
|
||||
if (!ck) {
|
||||
ck = new Check();
|
||||
ck.user = req.user._id;
|
||||
ck.keepDays = 1;
|
||||
ck.save();
|
||||
|
||||
score = scoreConfig.action.dailyCheckIn.dailyBasicScore + (ck.keepDays - 1) * scoreConfig.action.dailyCheckIn.dailyStepScore;
|
||||
scoreUpdate(req, req.user, scoreConfig.action.dailyCheckIn, score);
|
||||
|
||||
ck = ck.toJSON();
|
||||
ck.todayIsDone = true;
|
||||
res.json(ck);
|
||||
} else {
|
||||
var oldCheckDate = moment(moment(ck.lastCheckedAt).format('YYYY-MM-DD'));
|
||||
var now = moment(moment().format('YYYY-MM-DD'));
|
||||
var diff = now.diff(oldCheckDate, 'days');
|
||||
|
||||
if (diff === 0) {
|
||||
return res.status(422).json({
|
||||
message: 'SERVER.YOU_ALREADY_CHECK_IN'
|
||||
});
|
||||
} else if (diff === 1) {
|
||||
ck.keepDays += 1;
|
||||
ck.lastCheckedAt = Date.now();
|
||||
ck.save();
|
||||
|
||||
score = scoreConfig.action.dailyCheckIn.dailyBasicScore + (ck.keepDays - 1) * scoreConfig.action.dailyCheckIn.dailyStepScore;
|
||||
scoreUpdate(req, req.user, scoreConfig.action.dailyCheckIn, score);
|
||||
|
||||
ck = ck.toJSON();
|
||||
ck.todayIsDone = true;
|
||||
res.json(ck);
|
||||
} else {
|
||||
ck.keepDays = 1;
|
||||
ck.lastCheckedAt = Date.now();
|
||||
ck.save();
|
||||
|
||||
score = scoreConfig.action.dailyCheckIn.dailyBasicScore + (ck.keepDays - 1) * scoreConfig.action.dailyCheckIn.dailyStepScore;
|
||||
scoreUpdate(req, req.user, scoreConfig.action.dailyCheckIn, score);
|
||||
|
||||
ck = ck.toJSON();
|
||||
ck.todayIsDone = true;
|
||||
res.json(ck);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
};
|
||||
Reference in New Issue
Block a user