2024-01-25 18:09:33 -06:00
|
|
|
import { PrismaClient } from '@prisma/client'
|
|
|
|
|
2024-01-19 15:19:26 -06:00
|
|
|
const viewPrefixes = ['reg_growth', 'spender_growth', 'item_growth', 'spending_growth',
|
2024-02-14 15:27:00 -05:00
|
|
|
'stackers_growth', 'stacking_growth', 'user_stats', 'sub_stats']
|
2024-01-19 15:19:26 -06:00
|
|
|
|
2023-05-19 17:33:54 -05:00
|
|
|
// this is intended to be run everyday after midnight CT
|
2024-01-25 18:09:33 -06:00
|
|
|
export async function views ({ data: { period } = { period: 'days' } }) {
|
|
|
|
// grab a greedy connection
|
|
|
|
const models = new PrismaClient()
|
|
|
|
|
|
|
|
try {
|
2024-03-01 10:28:55 -06:00
|
|
|
// these views are bespoke so we can't use the loop
|
|
|
|
if (period === 'days') {
|
|
|
|
await models.$queryRawUnsafe('REFRESH MATERIALIZED VIEW CONCURRENTLY user_values_days')
|
|
|
|
await models.$queryRawUnsafe('REFRESH MATERIALIZED VIEW CONCURRENTLY rewards_days')
|
|
|
|
}
|
|
|
|
if (period === 'hours') {
|
|
|
|
await models.$queryRawUnsafe('REFRESH MATERIALIZED VIEW CONCURRENTLY user_values_today')
|
|
|
|
await models.$queryRawUnsafe('REFRESH MATERIALIZED VIEW CONCURRENTLY rewards_today')
|
|
|
|
}
|
2024-01-25 18:09:33 -06:00
|
|
|
for (const view of viewPrefixes) {
|
|
|
|
await models.$queryRawUnsafe(`REFRESH MATERIALIZED VIEW CONCURRENTLY ${view}_${period}`)
|
|
|
|
}
|
|
|
|
} finally {
|
|
|
|
await models.$disconnect()
|
2023-05-18 18:41:56 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-09-14 10:46:59 -05:00
|
|
|
// this should be run regularly ... like, every 5 minutes
|
2024-01-25 18:09:33 -06:00
|
|
|
export async function rankViews () {
|
|
|
|
// grab a greedy connection
|
|
|
|
const models = new PrismaClient()
|
|
|
|
|
|
|
|
try {
|
|
|
|
for (const view of ['zap_rank_personal_view']) {
|
|
|
|
await models.$queryRawUnsafe(`REFRESH MATERIALIZED VIEW CONCURRENTLY ${view}`)
|
|
|
|
}
|
|
|
|
} finally {
|
|
|
|
await models.$disconnect()
|
2023-05-23 09:21:04 -05:00
|
|
|
}
|
|
|
|
}
|