woj-server/internal/service/status/query.go

62 lines
1.4 KiB
Go
Raw Normal View History

package status
import (
"errors"
2023-07-14 21:47:11 +08:00
"git.0x7f.app/WOJ/woj-server/internal/e"
"git.0x7f.app/WOJ/woj-server/internal/model"
"go.uber.org/zap"
"gorm.io/gorm"
"gorm.io/gorm/clause"
)
2023-07-15 16:19:49 +08:00
func (s *service) Query(sid uint, associations bool) (*model.Status, e.Status) {
status := &model.Status{
SubmissionID: sid,
IsEnabled: true,
}
2023-07-15 16:19:49 +08:00
query := s.db.Get()
if associations {
2023-12-23 15:37:46 +08:00
query = query.
Preload("Submission.Problem").
Preload("Submission.User").
Preload(clause.Associations)
}
err := query.
Where(status).
Last(&status).Error
if errors.Is(err, gorm.ErrRecordNotFound) {
return nil, e.StatusNotFound
}
if err != nil {
s.log.Warn("DatabaseError", zap.Error(err), zap.Any("status", status))
return nil, e.DatabaseError
}
return status, e.Success
}
2023-12-23 15:36:42 +08:00
func (s *service) QueryByVersion(pvid uint, offset int, limit int, count *int64) ([]*model.Status, e.Status) {
var ret []*model.Status
status := &model.Status{
ProblemVersionID: pvid,
IsEnabled: true,
}
2023-12-23 15:37:46 +08:00
err := s.db.Get().
Preload("Submission.Problem").Preload("Submission.User").Preload(clause.Associations).
Where(status).
2023-12-23 15:36:42 +08:00
Order("created_at DESC").
Offset(offset).Limit(limit).Find(&ret).
Offset(-1).Limit(-1).Count(count).
Error
if err != nil {
s.log.Warn("DatabaseError", zap.Error(err), zap.Any("status", status))
return nil, e.DatabaseError
}
2023-12-23 15:36:42 +08:00
return ret, e.Success
}