hi-server/internal/logic/admin/user/getAdminUserInviteStatsLogic.go
shanshanzhong f792157d6e
All checks were successful
Build docker and publish / build (20.15.1) (push) Successful in 7m22s
邀请记录
2026-03-08 21:57:20 -07:00

73 lines
2.4 KiB
Go

package user
import (
"context"
"database/sql"
"github.com/perfect-panel/server/internal/svc"
"github.com/perfect-panel/server/internal/types"
"github.com/perfect-panel/server/pkg/logger"
"github.com/perfect-panel/server/pkg/xerr"
"github.com/pkg/errors"
)
type GetAdminUserInviteStatsLogic struct {
logger.Logger
ctx context.Context
svcCtx *svc.ServiceContext
}
func NewGetAdminUserInviteStatsLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetAdminUserInviteStatsLogic {
return &GetAdminUserInviteStatsLogic{
Logger: logger.WithContext(ctx),
ctx: ctx,
svcCtx: svcCtx,
}
}
func (l *GetAdminUserInviteStatsLogic) GetAdminUserInviteStats(req *types.GetAdminUserInviteStatsRequest) (resp *types.GetAdminUserInviteStatsResponse, err error) {
userId := req.UserId
// 邀请总人数
var inviteCount int64
if err = l.svcCtx.DB.WithContext(l.ctx).
Table("user").
Where("referer_id = ? AND deleted_at IS NULL", userId).
Count(&inviteCount).Error; err != nil {
return nil, errors.Wrapf(xerr.NewErrCode(xerr.DatabaseQueryError), "count invite users failed: %v", err)
}
// 历史累计佣金(来自 system_logs type=33 的佣金记录)
var totalCommission sql.NullInt64
if err = l.svcCtx.DB.WithContext(l.ctx).
Table("system_logs").
Select("COALESCE(SUM(JSON_EXTRACT(content, '$.amount')), 0) as total").
Where("type = ? AND object_id = ? AND JSON_EXTRACT(content, '$.type') IN (?, ?)", 33, userId, 331, 332).
Scan(&totalCommission).Error; err != nil {
return nil, errors.Wrapf(xerr.NewErrCode(xerr.DatabaseQueryError), "sum commission failed: %v", err)
}
// 当前佣金余额
type UserCommission struct {
Commission int64 `gorm:"column:commission"`
ReferralPercentage uint8 `gorm:"column:referral_percentage"`
OnlyFirstPurchase bool `gorm:"column:only_first_purchase"`
}
var userInfo UserCommission
if err = l.svcCtx.DB.WithContext(l.ctx).
Table("user").
Select("commission, referral_percentage, only_first_purchase").
Where("id = ?", userId).
Scan(&userInfo).Error; err != nil {
return nil, errors.Wrapf(xerr.NewErrCode(xerr.DatabaseQueryError), "get user commission failed: %v", err)
}
return &types.GetAdminUserInviteStatsResponse{
InviteCount: inviteCount,
TotalCommission: totalCommission.Int64,
CurrentCommission: userInfo.Commission,
ReferralPercentage: userInfo.ReferralPercentage,
OnlyFirstPurchase: userInfo.OnlyFirstPurchase,
}, nil
}