mirror of
https://github.com/TeaOSLab/EdgeAPI.git
synced 2025-11-14 08:11:55 +08:00
增加统计服务某日、某月流量API
This commit is contained in:
@@ -1963,9 +1963,11 @@ func (this *ServerService) FindServerUserPlan(ctx context.Context, req *pb.FindS
|
|||||||
DayTo: userPlan.DayTo,
|
DayTo: userPlan.DayTo,
|
||||||
User: nil,
|
User: nil,
|
||||||
Plan: &pb.Plan{
|
Plan: &pb.Plan{
|
||||||
Id: int64(plan.Id),
|
Id: int64(plan.Id),
|
||||||
Name: plan.Name,
|
Name: plan.Name,
|
||||||
PriceType: plan.PriceType,
|
PriceType: plan.PriceType,
|
||||||
|
TrafficPriceJSON: plan.TrafficPrice,
|
||||||
|
TrafficLimitJSON: plan.TrafficLimit,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}, nil
|
}, nil
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ import (
|
|||||||
"github.com/iwind/TeaGo/dbs"
|
"github.com/iwind/TeaGo/dbs"
|
||||||
timeutil "github.com/iwind/TeaGo/utils/time"
|
timeutil "github.com/iwind/TeaGo/utils/time"
|
||||||
"math"
|
"math"
|
||||||
|
"regexp"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -224,12 +225,22 @@ func (this *ServerDailyStatService) FindLatestServerDailyStats(ctx context.Conte
|
|||||||
|
|
||||||
// SumCurrentServerDailyStats 查找单个服务当前统计数据
|
// SumCurrentServerDailyStats 查找单个服务当前统计数据
|
||||||
func (this *ServerDailyStatService) SumCurrentServerDailyStats(ctx context.Context, req *pb.SumCurrentServerDailyStatsRequest) (*pb.SumCurrentServerDailyStatsResponse, error) {
|
func (this *ServerDailyStatService) SumCurrentServerDailyStats(ctx context.Context, req *pb.SumCurrentServerDailyStatsRequest) (*pb.SumCurrentServerDailyStatsResponse, error) {
|
||||||
_, err := this.ValidateAdmin(ctx, 0)
|
_, userId, err := this.ValidateAdminAndUser(ctx, 0, 0)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var tx *dbs.Tx
|
var tx *dbs.Tx = this.NullTx()
|
||||||
|
|
||||||
|
// 检查用户
|
||||||
|
if userId > 0 {
|
||||||
|
err = models.SharedServerDAO.CheckUserServer(tx, userId, req.ServerId)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 按日
|
||||||
stat, err := models.SharedServerDailyStatDAO.SumCurrentDailyStat(tx, req.ServerId)
|
stat, err := models.SharedServerDailyStatDAO.SumCurrentDailyStat(tx, req.ServerId)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@@ -250,7 +261,97 @@ func (this *ServerDailyStatService) SumCurrentServerDailyStats(ctx context.Conte
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return &pb.SumCurrentServerDailyStatsResponse{
|
return &pb.SumCurrentServerDailyStatsResponse{ServerDailyStat: pbStat}, nil
|
||||||
ServerDailyStat: pbStat,
|
}
|
||||||
}, nil
|
|
||||||
|
// SumServerDailyStats 计算单个服务的日统计
|
||||||
|
func (this *ServerDailyStatService) SumServerDailyStats(ctx context.Context, req *pb.SumServerDailyStatsRequest) (*pb.SumServerDailyStatsResponse, error) {
|
||||||
|
_, userId, err := this.ValidateAdminAndUser(ctx, 0, 0)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
var tx = this.NullTx()
|
||||||
|
|
||||||
|
// 检查用户
|
||||||
|
if userId > 0 {
|
||||||
|
err = models.SharedServerDAO.CheckUserServer(tx, userId, req.ServerId)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 某日统计
|
||||||
|
var day = timeutil.Format("Ymd")
|
||||||
|
if regexp.MustCompile(`^\d{8}$`).MatchString(req.Day) {
|
||||||
|
day = req.Day
|
||||||
|
}
|
||||||
|
|
||||||
|
stat, err := models.SharedServerDailyStatDAO.SumDailyStat(tx, req.ServerId, day)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
var pbStat = &pb.ServerDailyStat{
|
||||||
|
ServerId: req.ServerId,
|
||||||
|
}
|
||||||
|
if stat != nil {
|
||||||
|
pbStat = &pb.ServerDailyStat{
|
||||||
|
ServerId: req.ServerId,
|
||||||
|
Bytes: stat.Bytes,
|
||||||
|
CachedBytes: stat.CachedBytes,
|
||||||
|
CountRequests: stat.CountRequests,
|
||||||
|
CountCachedRequests: stat.CountCachedRequests,
|
||||||
|
CountAttackRequests: stat.CountAttackRequests,
|
||||||
|
AttackBytes: stat.AttackBytes,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return &pb.SumServerDailyStatsResponse{ServerDailyStat: pbStat}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// SumServerMonthlyStats 计算单个服务的月统计
|
||||||
|
func (this *ServerDailyStatService) SumServerMonthlyStats(ctx context.Context, req *pb.SumServerMonthlyStatsRequest) (*pb.SumServerMonthlyStatsResponse, error) {
|
||||||
|
_, userId, err := this.ValidateAdminAndUser(ctx, 0, 0)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
var tx = this.NullTx()
|
||||||
|
|
||||||
|
// 检查用户
|
||||||
|
if userId > 0 {
|
||||||
|
err = models.SharedServerDAO.CheckUserServer(tx, userId, req.ServerId)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 某月统计
|
||||||
|
var month = timeutil.Format("Ym")
|
||||||
|
if regexp.MustCompile(`^\d{6}$`).MatchString(req.Month) {
|
||||||
|
month = req.Month
|
||||||
|
}
|
||||||
|
|
||||||
|
// 按月
|
||||||
|
stat, err := models.SharedServerDailyStatDAO.SumMonthlyStat(tx, req.ServerId, month)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
var pbStat = &pb.ServerDailyStat{
|
||||||
|
ServerId: req.ServerId,
|
||||||
|
}
|
||||||
|
if stat != nil {
|
||||||
|
pbStat = &pb.ServerDailyStat{
|
||||||
|
ServerId: req.ServerId,
|
||||||
|
Bytes: stat.Bytes,
|
||||||
|
CachedBytes: stat.CachedBytes,
|
||||||
|
CountRequests: stat.CountRequests,
|
||||||
|
CountCachedRequests: stat.CountCachedRequests,
|
||||||
|
CountAttackRequests: stat.CountAttackRequests,
|
||||||
|
AttackBytes: stat.AttackBytes,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return &pb.SumServerMonthlyStatsResponse{ServerMonthlyStat: pbStat}, nil
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user