mirror of
https://github.com/cupcakearmy/ora.git
synced 2024-07-01 09:44:47 +02:00
35 lines
933 B
JavaScript
35 lines
933 B
JavaScript
import { each, groupBy, orderBy } from 'lodash'
|
|
import dj from 'dayjs'
|
|
import RelativeTime from 'dayjs/plugin/relativeTime'
|
|
import Duration from 'dayjs/plugin/duration'
|
|
|
|
dj.extend(Duration)
|
|
dj.extend(RelativeTime)
|
|
|
|
import { Logs } from '../shared/db'
|
|
|
|
export async function data({ start, end }) {
|
|
const logs = await getLogsBetweenDates({ start, end })
|
|
console.log('Found', logs.length)
|
|
return groupBy(logs, 'host')
|
|
}
|
|
|
|
export async function getLogsBetweenDates({ start, end }) {
|
|
return await Logs.find({
|
|
$and: [{ timestamp: { $gt: start } }, { timestamp: { $lt: end } }],
|
|
})
|
|
}
|
|
|
|
export function countInGroup(grouped) {
|
|
const counted = Object.entries(grouped).map(([key, data]) => {
|
|
const total = data.reduce((acc, cur) => acc + cur.seconds, 0)
|
|
const human = dj.duration(total, 'seconds').humanize()
|
|
return {
|
|
host: key,
|
|
total,
|
|
human,
|
|
}
|
|
})
|
|
return orderBy(counted, 'total', 'desc')
|
|
}
|