-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathaggregate_logs_by_user_module_and_date.js
116 lines (97 loc) · 2.8 KB
/
aggregate_logs_by_user_module_and_date.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
var aggregate = {};
var async = require('async');
var mongo = require('./ktbs_mongo.js');
var aggregationType = 'countByUserModuleAndDate';
// good test subject
// 119fc8dcc7d2c7bdfff06d1446b714941429d6d9
aggregate.countByUserModuleAndDate = function(args, callback) {
console.log(aggregationType + ', user : ' + args.subject);
var timeCalculation, connection, obselModel;
var filter = {};
filter.student = true;
filter.subject = args.subject;
filter['course.category1.moodleId'] = args.category;
filter['begin'] = { $gt : args.fromDate };
filter['end'] = { $lt : args.toDate };
connection = mongo.createMongoConnection();
obselModel = mongo.getObselModel(connection);
obselModel.aggregate([
{
$match : filter
}, {
$project : {
day : { $subtract : ["$begin", { $mod : ["$begin", 86400000] } ] },
action : "$@type"
}
} , {
$group : {
_id : { day : "$day", action : "$action" },
number : { $sum : 1 }
}
}, {
$sort : { "_id.day" : 1, "_id.action" : 1 }
}
]).exec(function(err, results) {
if (err) return callback(err);
mongo.disconnectMongo(connection);
callback(null, results);
});
}
/*aggregate.groupLogsByDateAndCategoryThenStore = function(callback) {
async.series([
function groupDailyByCategory(callback) {
aggregate.countByUserModuleAndDate(
firstLevel,
function(err, results) {
if (err) return callback(err);
mongo.storeResults(aggregationType,
firstLevel,
results,
callback);
});
}
], function(err) {
if (err) callback(err);
callback();
});
}*/
/*aggregate.findSecondLevelResults = function(subject, callback) {
var args = {};
args.subject = subject;
mongo.findResults(aggregationType, args, callback);
}*/
aggregate.findOrComputeUserLogs = function(subject, category, fromDate, toDate, callback) {
var args = {};
var now = new Date();
if (fromDate === undefined || fromDate === null) {
fromDate = Date.UTC(now.getFullYear(), now.getMonth(), now.getDate() - 30);
}
if (toDate === undefined || toDate === null) {
toDate = Date.UTC(now.getFullYear(), now.getMonth(), now.getDate());
}
args.subject = subject;
args.category = category;
args.fromDate = fromDate;
args.toDate = toDate;
mongo.findResults(aggregationType, args, function(err, results) {
if (err) callback(err);
if (results.length === 0) {
aggregate.countByUserModuleAndDate(
args,
function(err, results) {
if (err) return callback(err);
mongo.storeResults(aggregationType,
args,
results,
function(err) {
if (err) return callback(err);
aggregate.findOrComputeUserLogs(subject, category, fromDate, toDate, callback);
});
}
)
} else {
callback(null, results);
}
});
}
module.exports = aggregate;