2024-11-26 13:36:40 -08:00
|
|
|
package gormstore
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2024-11-26 18:30:58 -05:00
|
|
|
"errors"
|
2024-11-27 18:57:42 -08:00
|
|
|
|
2024-11-26 18:30:58 -05:00
|
|
|
"git.itzana.me/strafesnet/maps-service/pkg/datastore"
|
|
|
|
"git.itzana.me/strafesnet/maps-service/pkg/model"
|
2024-11-26 13:36:40 -08:00
|
|
|
"gorm.io/gorm"
|
2024-12-10 19:55:14 -08:00
|
|
|
"gorm.io/gorm/clause"
|
2024-11-26 13:36:40 -08:00
|
|
|
)
|
|
|
|
|
2024-11-26 18:30:58 -05:00
|
|
|
type Submissions struct {
|
2024-11-26 13:36:40 -08:00
|
|
|
db *gorm.DB
|
|
|
|
}
|
|
|
|
|
2024-11-26 18:30:58 -05:00
|
|
|
func (env *Submissions) Get(ctx context.Context, id int64) (model.Submission, error) {
|
|
|
|
var submission model.Submission
|
|
|
|
if err := env.db.First(&submission, id).Error; err != nil {
|
|
|
|
if errors.Is(err, gorm.ErrRecordNotFound) {
|
|
|
|
return submission, datastore.ErrNotExist
|
2024-11-26 13:36:40 -08:00
|
|
|
}
|
2024-12-17 16:15:33 -08:00
|
|
|
return submission, err
|
2024-11-26 13:36:40 -08:00
|
|
|
}
|
2024-11-26 18:30:58 -05:00
|
|
|
return submission, nil
|
2024-11-26 13:36:40 -08:00
|
|
|
}
|
2024-11-27 15:14:50 -08:00
|
|
|
|
|
|
|
func (env *Submissions) GetList(ctx context.Context, id []int64) ([]model.Submission, error) {
|
|
|
|
var mapList []model.Submission
|
|
|
|
if err := env.db.Find(&mapList, "id IN ?", id).Error; err != nil {
|
|
|
|
return mapList, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return mapList, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (env *Submissions) Create(ctx context.Context, smap model.Submission) (model.Submission, error) {
|
|
|
|
if err := env.db.Create(&smap).Error; err != nil {
|
|
|
|
return smap, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return smap, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (env *Submissions) Update(ctx context.Context, id int64, values datastore.OptionalMap) error {
|
|
|
|
if err := env.db.Model(&model.Submission{}).Where("id = ?", id).Updates(values.Map()).Error; err != nil {
|
|
|
|
if err == gorm.ErrRecordNotFound {
|
|
|
|
return datastore.ErrNotExist
|
|
|
|
}
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2024-11-27 18:57:42 -08:00
|
|
|
// the update can only occur if the status matches one of the provided values.
|
|
|
|
func (env *Submissions) IfStatusThenUpdate(ctx context.Context, id int64, statuses []model.Status, values datastore.OptionalMap) error {
|
2024-12-12 17:29:20 -05:00
|
|
|
if err := env.db.Model(&model.Submission{}).Where("id = ?", id).Where("status_id IN ?", statuses).Updates(values.Map()).Error; err != nil {
|
2024-11-27 18:57:42 -08:00
|
|
|
if err == gorm.ErrRecordNotFound {
|
|
|
|
return datastore.ErrNotExist
|
|
|
|
}
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2024-11-29 15:52:44 -08:00
|
|
|
// the update can only occur if the status matches one of the provided values.
|
|
|
|
// returns the updated value
|
|
|
|
func (env *Submissions) IfStatusThenUpdateAndGet(ctx context.Context, id int64, statuses []model.Status, values datastore.OptionalMap) (model.Submission, error) {
|
|
|
|
var submission model.Submission
|
2024-12-10 21:38:12 -08:00
|
|
|
result := env.db.Model(&submission).
|
2024-12-10 19:55:14 -08:00
|
|
|
Clauses(clause.Returning{}).
|
|
|
|
Where("id = ?", id).
|
2024-12-12 17:29:20 -05:00
|
|
|
Where("status_id IN ?", statuses).
|
2024-12-10 21:38:12 -08:00
|
|
|
Updates(values.Map())
|
|
|
|
if result.Error != nil {
|
|
|
|
if result.Error == gorm.ErrRecordNotFound {
|
2024-11-29 15:52:44 -08:00
|
|
|
return submission, datastore.ErrNotExist
|
|
|
|
}
|
2024-12-10 21:38:12 -08:00
|
|
|
return submission, result.Error
|
|
|
|
}
|
|
|
|
|
|
|
|
if result.RowsAffected == 0 {
|
2024-12-11 15:38:26 -08:00
|
|
|
return submission, datastore.ErroNoRowsAffected
|
2024-11-29 15:52:44 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
return submission, nil
|
|
|
|
}
|
|
|
|
|
2024-11-27 15:14:50 -08:00
|
|
|
func (env *Submissions) Delete(ctx context.Context, id int64) error {
|
|
|
|
if err := env.db.Delete(&model.Submission{}, id).Error; err != nil {
|
|
|
|
if err == gorm.ErrRecordNotFound {
|
|
|
|
return datastore.ErrNotExist
|
|
|
|
}
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (env *Submissions) List(ctx context.Context, filters datastore.OptionalMap, page model.Page) ([]model.Submission, error) {
|
|
|
|
var maps []model.Submission
|
|
|
|
if err := env.db.Where(filters.Map()).Offset(int((page.Number - 1) * page.Size)).Limit(int(page.Size)).Find(&maps).Error; err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return maps, nil
|
|
|
|
}
|