package service import ( "encoding/json" "s-ui/database" "s-ui/database/model" "time" "gorm.io/gorm" ) type onlines struct { Inbound []string `json:"inbound,omitempty"` User []string `json:"user,omitempty"` Outbound []string `json:"outbound,omitempty"` } var onlineResources = &onlines{} type StatsService struct { } func (s *StatsService) SaveStats(stats []*model.Stats) error { var err error // Reset onlines onlineResources.Inbound = nil onlineResources.Outbound = nil onlineResources.User = nil if len(stats) == 0 { return nil } db := database.GetDB() tx := db.Begin() defer func() { if err == nil { tx.Commit() } else { tx.Rollback() } }() for _, stat := range stats { if stat.Resource == "user" { if stat.Direction { err = tx.Model(model.Client{}).Where("name = ?", stat.Tag). UpdateColumn("up", gorm.Expr("up + ?", stat.Traffic)).Error } else { err = tx.Model(model.Client{}).Where("name = ?", stat.Tag). UpdateColumn("down", gorm.Expr("down + ?", stat.Traffic)).Error } if err != nil { return err } } if stat.Direction { switch stat.Resource { case "inbound": onlineResources.Inbound = append(onlineResources.Inbound, stat.Tag) case "outbound": onlineResources.Outbound = append(onlineResources.Outbound, stat.Tag) case "user": onlineResources.User = append(onlineResources.User, stat.Tag) } } } err = tx.Create(&stats).Error return err } func (s *StatsService) GetStats(resorce string, tag string, limit int) ([]model.Stats, error) { var err error var result []model.Stats currentTime := time.Now().Unix() timeDiff := currentTime - (int64(limit) * 3600) db := database.GetDB() err = db.Model(model.Stats{}).Where("resource = ? AND tag = ? AND date_time > ?", resorce, tag, timeDiff).Scan(&result).Error if err != nil { return nil, err } return result, nil } func (s *StatsService) GetOnlines() (string, error) { onlines, err := json.Marshal(onlineResources) if err != nil { return "", err } return string(onlines), nil } func (s *StatsService) DelOldStats(days int) error { oldTime := time.Now().AddDate(0, 0, -(days)).Unix() db := database.GetDB() return db.Where("date_time < ?", oldTime).Delete(model.Stats{}).Error }