2022-10-22 17:38:39 +08:00
|
|
|
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"
|
2022-10-22 17:38:39 +08:00
|
|
|
"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) {
|
2022-10-22 17:38:39 +08:00
|
|
|
|
|
|
|
status := &model.Status{
|
|
|
|
SubmissionID: sid,
|
|
|
|
IsEnabled: true,
|
|
|
|
}
|
|
|
|
|
2023-07-15 16:19:49 +08:00
|
|
|
query := s.db.Get()
|
2022-10-22 17:38:39 +08:00
|
|
|
if associations {
|
|
|
|
query = query.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-07-15 16:19:49 +08:00
|
|
|
func (s *service) QueryByVersion(pvid uint, offset int, limit int) ([]*model.Status, e.Status) {
|
2022-10-22 17:38:39 +08:00
|
|
|
var statuses []*model.Status
|
|
|
|
status := &model.Status{
|
|
|
|
ProblemVersionID: pvid,
|
|
|
|
IsEnabled: true,
|
|
|
|
}
|
|
|
|
|
2023-07-15 16:19:49 +08:00
|
|
|
err := s.db.Get().Preload(clause.Associations).
|
2022-10-22 17:38:39 +08:00
|
|
|
Where(status).
|
|
|
|
Limit(limit).
|
|
|
|
Offset(offset).
|
|
|
|
Find(&statuses).Error
|
|
|
|
if err != nil {
|
|
|
|
s.log.Warn("DatabaseError", zap.Error(err), zap.Any("status", status))
|
|
|
|
return nil, e.DatabaseError
|
|
|
|
}
|
|
|
|
return statuses, e.Success
|
|
|
|
}
|