71 lines
3.1 KiB
Go
71 lines
3.1 KiB
Go
package service_internal
|
|
|
|
import (
|
|
"context"
|
|
|
|
internal "git.itzana.me/strafesnet/maps-service/pkg/internal"
|
|
"git.itzana.me/strafesnet/maps-service/pkg/datastore"
|
|
"git.itzana.me/strafesnet/maps-service/pkg/model"
|
|
)
|
|
|
|
// UpdateSubmissionValidatedModel implements patchSubmissionModel operation.
|
|
//
|
|
// Update model following role restrictions.
|
|
//
|
|
// POST /submissions/{SubmissionID}/validated-model
|
|
func (svc *Service) UpdateSubmissionValidatedModel(ctx context.Context, params internal.UpdateSubmissionValidatedModelParams) error {
|
|
// check if Status is ChangesRequested|Submitted|UnderConstruction
|
|
pmap := datastore.Optional()
|
|
pmap.AddNotNil("validated_asset_id", params.ValidatedModelID)
|
|
pmap.AddNotNil("validated_asset_version", params.ValidatedModelVersion)
|
|
// DO NOT reset completed when validated model is updated
|
|
// pmap.Add("completed", false)
|
|
return svc.DB.Submissions().IfStatusThenUpdate(ctx, params.SubmissionID, []model.SubmissionStatus{model.SubmissionStatusValidating}, pmap)
|
|
}
|
|
|
|
// ActionSubmissionValidate invokes actionSubmissionValidate operation.
|
|
//
|
|
// Role Validator changes status from Validating -> Validated.
|
|
//
|
|
// POST /submissions/{SubmissionID}/status/validator-validated
|
|
func (svc *Service) ActionSubmissionValidated(ctx context.Context, params internal.ActionSubmissionValidatedParams) error {
|
|
println("[ActionSubmissionValidated] Implicit Validator permission granted!")
|
|
|
|
// transaction
|
|
smap := datastore.Optional()
|
|
smap.Add("status_id", model.SubmissionStatusValidated)
|
|
return svc.DB.Submissions().IfStatusThenUpdate(ctx, params.SubmissionID, []model.SubmissionStatus{model.SubmissionStatusValidating}, smap)
|
|
}
|
|
|
|
// ActionSubmissionAccepted implements actionSubmissionAccepted operation.
|
|
//
|
|
// (Internal endpoint) Role Validator changes status from Validating -> Accepted.
|
|
//
|
|
// POST /submissions/{SubmissionID}/status/validator-failed
|
|
func (svc *Service) ActionSubmissionAccepted(ctx context.Context, params internal.ActionSubmissionAcceptedParams) error {
|
|
println("[ActionSubmissionAccepted] Implicit Validator permission granted!")
|
|
|
|
// transaction
|
|
smap := datastore.Optional()
|
|
smap.Add("status_id", model.SubmissionStatusAccepted)
|
|
smap.Add("status_message", params.StatusMessage)
|
|
return svc.DB.Submissions().IfStatusThenUpdate(ctx, params.SubmissionID, []model.SubmissionStatus{model.SubmissionStatusValidating}, smap)
|
|
}
|
|
|
|
// ActionSubmissionUploaded implements actionSubmissionUploaded operation.
|
|
//
|
|
// (Internal endpoint) Role Validator changes status from Uploading -> Uploaded.
|
|
//
|
|
// POST /submissions/{SubmissionID}/status/validator-uploaded
|
|
func (svc *Service) ActionSubmissionUploaded(ctx context.Context, params internal.ActionSubmissionUploadedParams) error {
|
|
println("[ActionSubmissionUploaded] Implicit Validator permission granted!")
|
|
|
|
// transaction
|
|
smap := datastore.Optional()
|
|
smap.Add("status_id", model.SubmissionStatusUploaded)
|
|
if params.TargetAssetID.IsSet() {
|
|
smap.AddNotNil("target_asset_id", params.TargetAssetID.Value)
|
|
}
|
|
return svc.DB.Submissions().IfStatusThenUpdate(ctx, params.SubmissionID, []model.SubmissionStatus{model.SubmissionStatusUploading}, smap)
|
|
}
|