mirror of https://gitgud.io/fatchan/jschan.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
110 lines
1.7 KiB
110 lines
1.7 KiB
'use strict';
|
|
|
|
const Mongo = require(__dirname+'/db.js')
|
|
, db = Mongo.client.db('jschan').collection('modlog');
|
|
|
|
module.exports = {
|
|
|
|
db,
|
|
|
|
getDates: (board) => {
|
|
return db.aggregate([
|
|
{
|
|
'$match': {
|
|
'board': board._id
|
|
}
|
|
},
|
|
{
|
|
'$project': {
|
|
'year': {
|
|
'$year': '$date'
|
|
},
|
|
'month': {
|
|
'$month': '$date'
|
|
},
|
|
'day': {
|
|
'$dayOfMonth': '$date'
|
|
}
|
|
}
|
|
},
|
|
{
|
|
'$group': {
|
|
'_id': {
|
|
'year': '$year',
|
|
'month': '$month',
|
|
'day': '$day',
|
|
},
|
|
'count': {
|
|
'$sum': 1
|
|
}
|
|
}
|
|
},
|
|
{
|
|
'$project': {
|
|
'_id': 0,
|
|
'date': '$_id',
|
|
'count': '$count'
|
|
}
|
|
},
|
|
{
|
|
'$sort': {
|
|
'date.year': -1,
|
|
'date.month': -1,
|
|
'date.day': -1
|
|
}
|
|
},
|
|
]).toArray();
|
|
},
|
|
|
|
find: (filter, offset, limit) => {
|
|
return db.find(filter)
|
|
.skip(offset)
|
|
.limit(limit)
|
|
.sort({
|
|
'_id': -1
|
|
})
|
|
.toArray();
|
|
},
|
|
|
|
count: (filter) => {
|
|
return db.countDocuments(filter);
|
|
},
|
|
|
|
findBetweenDate: (board, start, end) => {
|
|
const startDate = Mongo.ObjectId.createFromTime(Math.floor(start.getTime()/1000));
|
|
const endDate = Mongo.ObjectId.createFromTime(Math.floor(end.getTime()/1000));
|
|
return db.find({
|
|
'_id': {
|
|
'$gte': startDate,
|
|
'$lte': endDate
|
|
},
|
|
'board': board._id
|
|
}).sort({
|
|
'_id': -1
|
|
}).toArray();
|
|
},
|
|
|
|
deleteOld: (board, date) => {
|
|
const monthOld = Mongo.ObjectId.createFromTime(Math.floor(date.getTime()/1000));
|
|
return db.deleteMany({
|
|
'_id': {
|
|
'$lt': monthOld
|
|
}
|
|
});
|
|
},
|
|
|
|
insertMany: (events) => {
|
|
return db.insertMany(events);
|
|
},
|
|
|
|
deleteBoard: (board) => {
|
|
return db.deleteMany({
|
|
'board': board
|
|
});
|
|
},
|
|
|
|
deleteAll: () => {
|
|
return db.deleteMany({});
|
|
},
|
|
|
|
}
|
|
|