spee.ch/server/models/views.js

68 lines
1.6 KiB
JavaScript
Raw Normal View History

2018-10-24 03:43:30 -05:00
module.exports = (sequelize, { BOOLEAN, DATE, STRING }) => {
const Views = sequelize.define(
'Views',
{
time: {
2018-11-10 19:11:12 -05:00
type : DATE(6),
2018-10-24 03:43:30 -05:00
defaultValue: sequelize.NOW,
},
isChannel: {
2018-11-10 19:11:12 -05:00
type : BOOLEAN,
2018-10-24 03:43:30 -05:00
defaultValue: false,
},
claimId: {
2018-11-10 19:11:12 -05:00
type : STRING,
2018-10-24 03:43:30 -05:00
defaultValue: null,
},
publisherId: {
2018-11-10 19:11:12 -05:00
type : STRING,
2018-10-24 03:43:30 -05:00
defaultValue: null,
},
ip: {
2018-11-10 19:11:12 -05:00
type : STRING,
2018-10-24 03:43:30 -05:00
defaultValue: null,
},
},
{
freezeTableName: true,
2018-11-10 19:11:12 -05:00
timestamps : false, // don't use default timestamps columns
indexes : [
2018-10-24 03:43:30 -05:00
{
fields: ['time', 'isChannel', 'claimId', 'publisherId', 'ip'],
},
],
}
);
Views.getUniqueViews = ({
hours = 0,
minutes = 30,
} = {}) => {
let time = new Date();
time.setHours(time.getHours() - hours);
time.setMinutes(time.getMinutes() - minutes);
const sqlTime = time.toISOString().slice(0, 19).replace('T', ' ');
const selectString = 'claimId, publisherId, isChannel, COUNT(DISTINCT ip) as views';
const groupString = 'claimId, publisherId, isChannel';
return sequelize.query(
2018-10-24 16:21:50 -05:00
`SELECT ${selectString} FROM Views WHERE time > '${sqlTime}' GROUP BY ${groupString}`,
2018-10-24 03:43:30 -05:00
{ type: sequelize.QueryTypes.SELECT }
);
};
Views.getGetUniqueViewsbByClaimId = (claimId) => {
return Views.count({
where: {
claimId,
},
distinct: true,
2018-11-10 19:11:12 -05:00
col : 'ip',
});
};
2018-10-24 03:43:30 -05:00
return Views;
};