forked from worknenjoy/gitpay
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreports.js
107 lines (100 loc) · 3.35 KB
/
reports.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
const models = require('./models')
const moment = require('moment')
const i18n = require('i18n')
const DeadlineMail = require('./modules/mail/deadline')
i18n.configure({
directory: process.env.NODE_ENV !== 'production' ? `${__dirname}/locales` : `${__dirname}/locales/result`,
locales: process.env.NODE_ENV !== 'production' ? ['en'] : ['en', 'br'],
defaultLocale: 'en',
updateFiles: false
})
i18n.init()
const Report = {
montlyBounties: async () => {
const tasks = await models.Task.findAll({ where: {
value: {
$gt: 0
}
},
include: [ models.User ]
})
// eslint-disable-next-line no-console
// console.log('tasks from cron job weekly bounties', tasks)
if (tasks[0]) {
const taskSort = tasks.sort((ta, tb) => {
return Math.abs(new Date(ta.created_at) - new Date(tb.created_at))
})
let currentObj = {}
let total = 0
taskSort.forEach((t) => {
const currentDate = t.createdAt.toLocaleString('en-GB', { month: 'long', year: 'numeric' })
currentObj[currentDate] = 0
})
taskSort.forEach((t) => {
const currentDate = t.createdAt.toLocaleString('en-GB', { month: 'long', year: 'numeric' })
currentObj[currentDate] += parseInt(t.value)
total += parseInt(t.value)
})
currentObj.total = total
// eslint-disable-next-line no-console
console.log('tasks', currentObj)
}
return new Error('no issues found')
},
montlyUsers: async () => {
const users = await models.User.findAll({
where: {},
order: [['id', 'DESC']]
})
if (users[0]) {
const usersSort = users.sort((ua, ub) => {
return Math.abs(new Date(ua.created_at) - new Date(ub.created_at))
})
let currentObj = {}
let total = 0
usersSort.forEach((t) => {
const currentDate = t.createdAt.toLocaleString('en-GB', { month: 'long', year: 'numeric' })
currentObj[currentDate] = 0
})
usersSort.forEach((t) => {
const currentDate = t.createdAt.toLocaleString('en-GB', { month: 'long', year: 'numeric' })
currentObj[currentDate] += 1
total += 1
})
currentObj.total = total
// eslint-disable-next-line no-console
console.log('users', currentObj)
}
return new Error('no issues found')
},
rememberDeadline: async () => {
const tasks = await models.Task.findAll({ where: {
status: 'in_progress',
deadline: {
$lt: moment(new Date()).format(),
$gt: moment(new Date()).subtract(2, 'days').format()
}
},
include: [ models.User ]
})
// eslint-disable-next-line no-console
console.log('tasks from cron job to remember deadline', tasks)
if (tasks[0]) {
tasks.map(async t => {
if (t.assigned) {
if (t.dataValues && t.assigned) {
const userAssigned = await models.Assign.findAll({ where: { id: t.assigned }, include: [models.User] })
if (userAssigned[0].dataValues) {
DeadlineMail.deadlineEndOwner(t.User.dataValues, t.dataValues, t.User.name || t.User.username)
DeadlineMail.deadlineEndAssigned(userAssigned[0].dataValues.User, t.dataValues, userAssigned[0].dataValues.User.dataValues.name)
}
}
}
})
}
return tasks
}
}
Report.montlyBounties()
Report.montlyUsers()
// module.exports = { Report }