宝箱助力列表增加返回给邀请者的额外积分

This commit is contained in:
CounterFire2023 2024-04-12 16:14:28 +08:00
parent b84f69e987
commit e1d85b1c3f
3 changed files with 15 additions and 0 deletions

View File

@ -42,6 +42,10 @@
2. 社交任务活动信息(3) 增加返回基础任务id列表
3. 获取任务奖励(7)增加返回ticket
#### 20240412
1. 宝箱助力列表(17) 增加返回给邀请者的额外积分
### 1. 钱包预登录
#### Request
@ -492,6 +496,7 @@ body:
level: 1, // 段位
nickname: '用户昵称',
score: 100, // 获得的积分
scoreInvite: 1 // 该用户上缴给你的积分
}]
```

View File

@ -87,17 +87,21 @@ export default class ActivityController extends BaseController {
async inviteUserList(req) {
let user = req.user
const totalKey = rankKey(user.activity)
const keyInvite = `${user.activity}:invite`
let users = await ActivityUser.find({ inviteUser: user.id })
let results = []
for (let u of users) {
const totalScore = await new ZRedisClient().zscore(totalKey, u.id)
const inviteScore = await new ZRedisClient().zscore(keyInvite, `${user.id}_${u.id}`)
const score = totalScore ? parseInt(totalScore + '') : 0
const scoreInvite = inviteScore ? parseInt(inviteScore + '') / 100 : 0
results.push({
// user: u.id,
level: rankLevel(score),
nickname: u.twitterName || u.discordName || formatAddress(u.address),
avatar: u.twitterAvatar || '',
score,
scoreInvite,
})
}
return results

View File

@ -48,6 +48,8 @@ export const updateRankScore = async ({
if (userMod?.inviteUser) {
const score1 = scoreParams.score * INVITE_REBATE
let scoreParams1 = Object.assign({ fromUser: user }, scoreParams)
const keyInvite = `${activity}:invite`
await updateRankInvite(keyInvite, parseInt(score1 * 100 + ''), `${userMod.inviteUser}_${user}`)
await updateRankScore({
user: userMod.inviteUser,
score: score1,
@ -77,6 +79,10 @@ const updateRank = async (key: string, score: number, member: string) => {
await new ZRedisClient().zadd(key, scoreToSave, member)
}
const updateRankInvite = async (key: string, score: number, member: string) => {
await new ZRedisClient().zincrby(key, score, member)
}
export const rankKey = (activity: string, date?: Date) => {
if (!date) {
return `${activity}:score`