195 lines
5.6 KiB
JavaScript
195 lines
5.6 KiB
JavaScript
'use strict'
|
|
|
|
const knex = require('@/db/knex')
|
|
|
|
const { dispatchStreamEvent } = require('../../webhooks/services/webhooks')
|
|
const StreamActivity = () => knex('stream_activity')
|
|
const StreamAcl = () => knex('stream_acl')
|
|
|
|
module.exports = {
|
|
/**
|
|
* @param {Omit<import('@/modules/activitystream/helpers/types').StreamActivityRecord, "time">} param0
|
|
* @param {{trx?: import('knex').Knex.Transaction}} param1
|
|
*/
|
|
async saveActivity(
|
|
{ streamId, resourceType, resourceId, actionType, userId, info, message },
|
|
{ trx } = {}
|
|
) {
|
|
const dbObject = {
|
|
streamId, // abc
|
|
resourceType, // "commit"
|
|
resourceId, // commit id
|
|
actionType, // "commit_receive"
|
|
userId, // populated by the api
|
|
info: JSON.stringify(info), // can be anything with conventions! (TBD)
|
|
message // something human understandable for frontend purposes mostly
|
|
}
|
|
|
|
const q = StreamActivity().insert(dbObject)
|
|
if (trx) q.transacting(trx)
|
|
await q
|
|
|
|
if (streamId) {
|
|
const webhooksPayload = {
|
|
streamId,
|
|
userId,
|
|
activityMessage: message,
|
|
event: {
|
|
// eslint-disable-next-line camelcase
|
|
event_name: actionType,
|
|
data: info
|
|
}
|
|
}
|
|
|
|
await dispatchStreamEvent(
|
|
{
|
|
streamId,
|
|
event: actionType,
|
|
eventPayload: webhooksPayload
|
|
},
|
|
{ trx }
|
|
)
|
|
}
|
|
},
|
|
|
|
async getStreamActivity({ streamId, actionType, after, before, cursor, limit }) {
|
|
if (!limit) {
|
|
limit = 200
|
|
}
|
|
|
|
const dbQuery = StreamActivity().where({ streamId })
|
|
if (actionType) dbQuery.andWhere({ actionType })
|
|
if (after) dbQuery.andWhere('time', '>', after)
|
|
if (before) dbQuery.andWhere('time', '<', before)
|
|
if (cursor) dbQuery.andWhere('time', '<', cursor)
|
|
dbQuery.orderBy('time', 'desc').limit(limit)
|
|
|
|
const results = await dbQuery.select('*')
|
|
|
|
return {
|
|
items: results,
|
|
cursor: results.length > 0 ? results[results.length - 1].time.toISOString() : null
|
|
}
|
|
},
|
|
|
|
async getUserActivity({ userId, actionType, after, before, cursor, limit }) {
|
|
if (!limit) {
|
|
limit = 200
|
|
}
|
|
|
|
const dbQuery = StreamActivity().where({ userId })
|
|
if (actionType) dbQuery.andWhere({ actionType })
|
|
if (after) dbQuery.andWhere('time', '>', after)
|
|
if (before) dbQuery.andWhere('time', '<', before)
|
|
if (cursor) dbQuery.andWhere('time', '<', cursor)
|
|
dbQuery.orderBy('time', 'desc').limit(limit)
|
|
|
|
const results = await dbQuery.select('*')
|
|
return {
|
|
items: results,
|
|
cursor: results.length > 0 ? results[results.length - 1].time.toISOString() : null
|
|
}
|
|
},
|
|
|
|
async getResourceActivity({
|
|
resourceType,
|
|
resourceId,
|
|
actionType,
|
|
after,
|
|
before,
|
|
cursor,
|
|
limit
|
|
}) {
|
|
if (!limit) {
|
|
limit = 200
|
|
}
|
|
|
|
const dbQuery = StreamActivity().where({ resourceType, resourceId })
|
|
if (actionType) dbQuery.andWhere({ actionType })
|
|
if (after) dbQuery.andWhere('time', '>', after)
|
|
if (before) dbQuery.andWhere('time', '<', before)
|
|
if (cursor) dbQuery.andWhere('time', '<', cursor)
|
|
dbQuery.orderBy('time', 'desc').limit(limit)
|
|
|
|
const results = await dbQuery.select('*')
|
|
return {
|
|
items: results,
|
|
cursor: results.length > 0 ? results[results.length - 1].time.toISOString() : null
|
|
}
|
|
},
|
|
|
|
async getUserTimeline({ userId, after, before, cursor, limit }) {
|
|
if (!limit) {
|
|
limit = 200
|
|
}
|
|
|
|
let sqlFilters = ''
|
|
const sqlVariables = []
|
|
if (after) {
|
|
sqlFilters += ' AND time > ?'
|
|
sqlVariables.push(after)
|
|
}
|
|
if (before || cursor) {
|
|
sqlFilters += ' AND time < ?'
|
|
sqlVariables.push(before || cursor)
|
|
}
|
|
|
|
const dbRawQuery = `
|
|
SELECT act.*
|
|
FROM stream_acl acl
|
|
INNER JOIN stream_activity act ON acl."resourceId" = act."streamId"
|
|
WHERE acl."userId" = ? ${sqlFilters}
|
|
ORDER BY time DESC
|
|
LIMIT ?
|
|
`
|
|
|
|
sqlVariables.unshift(userId)
|
|
sqlVariables.push(limit)
|
|
const results = (await knex.raw(dbRawQuery, sqlVariables)).rows
|
|
return {
|
|
items: results,
|
|
cursor: results.length > 0 ? results[results.length - 1].time.toISOString() : null
|
|
}
|
|
},
|
|
|
|
async getActivityCountByResourceId({ resourceId, actionType, after, before }) {
|
|
const query = StreamActivity().count().where({ resourceId })
|
|
if (actionType) query.andWhere({ actionType })
|
|
if (after) query.andWhere('time', '>', after)
|
|
if (before) query.andWhere('time', '<', before)
|
|
const [res] = await query
|
|
return parseInt(res.count)
|
|
},
|
|
|
|
async getActivityCountByStreamId({ streamId, actionType, after, before }) {
|
|
const query = StreamActivity().count().where({ streamId })
|
|
if (actionType) query.andWhere({ actionType })
|
|
if (after) query.andWhere('time', '>', after)
|
|
if (before) query.andWhere('time', '<', before)
|
|
const [res] = await query
|
|
return parseInt(res.count)
|
|
},
|
|
|
|
async getActivityCountByUserId({ userId, actionType, after, before }) {
|
|
const query = StreamActivity().count().where({ userId })
|
|
if (actionType) query.andWhere({ actionType })
|
|
if (after) query.andWhere('time', '>', after)
|
|
if (before) query.andWhere('time', '<', before)
|
|
const [res] = await query
|
|
return parseInt(res.count)
|
|
},
|
|
|
|
async getTimelineCount({ userId, after, before }) {
|
|
const query = StreamAcl()
|
|
.count()
|
|
.innerJoin('stream_activity', {
|
|
'stream_acl.resourceId': 'stream_activity.streamId'
|
|
})
|
|
.where({ 'stream_acl.userId': userId })
|
|
if (after) query.andWhere('stream_activity.time', '>', after)
|
|
if (before) query.andWhere('stream_activity.time', '<', before)
|
|
const [res] = await query
|
|
return parseInt(res.count)
|
|
}
|
|
}
|