From 1e3a836fbcb963bc930ec14fff099daea418d4ec Mon Sep 17 00:00:00 2001 From: keyan Date: Fri, 29 Mar 2024 20:53:07 -0500 Subject: [PATCH] update reward notification for msm --- api/resolvers/rewards.js | 22 +++++++++++++++++++++- components/notifications.js | 2 +- pages/rewards/[...when].js | 3 +-- worker/earn.js | 2 +- 4 files changed, 24 insertions(+), 5 deletions(-) diff --git a/api/resolvers/rewards.js b/api/resolvers/rewards.js index 646c5195..9f833eb9 100644 --- a/api/resolvers/rewards.js +++ b/api/resolvers/rewards.js @@ -49,9 +49,25 @@ async function getActiveRewards (models) { ) u` } +async function getMonthlyRewards (when, models) { + return await models.$queryRaw` + SELECT + (sum(total) / 1000)::INT as total, + date_trunc('month', ${when?.[0]}::text::timestamp) AT TIME ZONE 'America/Chicago' as time, + json_build_array( + json_build_object('name', 'donations', 'value', (sum(donations) / 1000)::INT), + json_build_object('name', 'fees', 'value', (sum(fees) / 1000)::INT), + json_build_object('name', 'boost', 'value', (sum(boost) / 1000)::INT), + json_build_object('name', 'jobs', 'value', (sum(jobs) / 1000)::INT), + json_build_object('name', 'anon''s stack', 'value', (sum(anons_stack) / 1000)::INT) + ) AS sources + FROM rewards_days + WHERE date_trunc('month', rewards_days.t) = date_trunc('month', ${when?.[0]}::text::timestamp - interval '1 month')` +} + async function getRewards (when, models) { if (when) { - if (when.length > 2) { + if (when.length > 1) { throw new GraphQLError('too many dates', { extensions: { code: 'BAD_USER_INPUT' } }) } when.forEach(w => { @@ -62,6 +78,10 @@ async function getRewards (when, models) { if (new Date(when[0]) > new Date(when[when.length - 1])) { throw new GraphQLError('bad date range', { extensions: { code: 'BAD_USER_INPUT' } }) } + + if (new Date(when[0]).getTime() >= new Date('2024-03-01').getTime()) { + return await getMonthlyRewards(when, models) + } } const results = await models.$queryRaw` diff --git a/components/notifications.js b/components/notifications.js index 529d4bcf..01f50408 100644 --- a/components/notifications.js +++ b/components/notifications.js @@ -165,7 +165,7 @@ function EarnNotification ({ n }) { {n.sources.tipComments > 0 && {(n.sources.comments > 0 || n.sources.posts > 0 || n.sources.tipPosts > 0) && ' \\ '}{numWithUnits(n.sources.tipComments, { abbreviate: false })} for zapping top comments early} }
- SN distributes the sats it earns back to its best stackers daily. These sats come from jobs, boosts, posting fees, and donations. You can see the daily rewards pool and make a donation here. + SN distributes the sats it earns back to its best stackers. These sats come from jobs, boosts, posting fees, and donations. You can see the rewards pool and make a donation here.
click for details diff --git a/pages/rewards/[...when].js b/pages/rewards/[...when].js index 43ce3468..bb75a559 100644 --- a/pages/rewards/[...when].js +++ b/pages/rewards/[...when].js @@ -16,8 +16,7 @@ const GrowthPieChart = dynamic(() => import('@/components/charts').then(mod => m }) export const getServerSideProps = getGetServerSideProps({ - query: ME_REWARDS, - notFound: (data, params) => data.rewards.reduce((a, r) => a || new Date(r.time) > new Date(), false) + query: ME_REWARDS }) export default function Rewards ({ ssrData }) { diff --git a/worker/earn.js b/worker/earn.js index 12259f17..b2d90706 100644 --- a/worker/earn.js +++ b/worker/earn.js @@ -52,7 +52,7 @@ export async function earn ({ name }) { // get earners { userId, id, type, rank, proportion } const earners = await models.$queryRaw` - SELECT id AS "userId", sum(proportion) as proportion + SELECT id AS "userId", sum(proportion) as proportion, ROW_NUMBER() OVER (ORDER BY sum(proportion) DESC) as rank FROM user_values_days WHERE date_trunc('month', user_values_days.t) = date_trunc('month', (now() - interval '1 month') AT TIME ZONE 'America/Chicago') AND NOT (id = ANY (${SN_USER_IDS}))