Quaternions
db52b1dcd4
All checks were successful
continuous-integration/drone/push Build is passing
117 lines
2.7 KiB
Go
117 lines
2.7 KiB
Go
package service
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"git.itzana.me/strafesnet/maps-service/pkg/api"
|
|
"git.itzana.me/strafesnet/maps-service/pkg/datastore"
|
|
"git.itzana.me/strafesnet/maps-service/pkg/model"
|
|
"github.com/dchest/siphash"
|
|
)
|
|
|
|
// CreateScript implements createScript operation.
|
|
//
|
|
// Create a new script.
|
|
//
|
|
// POST /scripts
|
|
func (svc *Service) CreateScript(ctx context.Context, req *api.ScriptCreate) (*api.ID, error) {
|
|
userInfo, ok := ctx.Value("UserInfo").(UserInfo)
|
|
if !ok {
|
|
return nil, ErrUserInfo
|
|
}
|
|
|
|
if !userInfo.Roles.ScriptWrite {
|
|
return nil, ErrPermissionDenied
|
|
}
|
|
|
|
script, err := svc.DB.Scripts().Create(ctx, model.Script{
|
|
ID: 0,
|
|
Name: req.Name,
|
|
Hash: siphash.Hash(0, 0, []byte(req.Source)),
|
|
Source: req.Source,
|
|
SubmissionID: req.SubmissionID.Or(0),
|
|
})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &api.ID{
|
|
ID: script.ID,
|
|
}, nil
|
|
}
|
|
|
|
// DeleteScript implements deleteScript operation.
|
|
//
|
|
// Delete the specified script by ID.
|
|
//
|
|
// DELETE /scripts/{ScriptID}
|
|
func (svc *Service) DeleteScript(ctx context.Context, params api.DeleteScriptParams) error {
|
|
userInfo, ok := ctx.Value("UserInfo").(UserInfo)
|
|
if !ok {
|
|
return ErrUserInfo
|
|
}
|
|
|
|
if !userInfo.Roles.ScriptWrite {
|
|
return ErrPermissionDenied
|
|
}
|
|
|
|
return svc.DB.Scripts().Delete(ctx, params.ScriptID)
|
|
}
|
|
|
|
// GetScript implements getScript operation.
|
|
//
|
|
// Get the specified script by ID.
|
|
//
|
|
// GET /scripts/{ScriptID}
|
|
func (svc *Service) GetScript(ctx context.Context, params api.GetScriptParams) (*api.Script, error) {
|
|
_, ok := ctx.Value("UserInfo").(UserInfo)
|
|
if !ok {
|
|
return nil, ErrUserInfo
|
|
}
|
|
|
|
// Read permission for scripts only requires you to be logged in
|
|
|
|
script, err := svc.DB.Scripts().Get(ctx, params.ScriptID)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &api.Script{
|
|
ID: script.ID,
|
|
Name: script.Name,
|
|
Hash: fmt.Sprintf("%x", script.Hash),
|
|
Source: script.Source,
|
|
SubmissionID: script.SubmissionID,
|
|
}, nil
|
|
}
|
|
|
|
// UpdateScript implements updateScript operation.
|
|
//
|
|
// Update the specified script by ID.
|
|
//
|
|
// PATCH /scripts/{ScriptID}
|
|
func (svc *Service) UpdateScript(ctx context.Context, req *api.ScriptUpdate, params api.UpdateScriptParams) error {
|
|
userInfo, ok := ctx.Value("UserInfo").(UserInfo)
|
|
if !ok {
|
|
return ErrUserInfo
|
|
}
|
|
|
|
if !userInfo.Roles.ScriptWrite {
|
|
return ErrPermissionDenied
|
|
}
|
|
|
|
pmap := datastore.Optional()
|
|
if Name, ok := req.Name.Get(); ok {
|
|
pmap.Add("name", Name)
|
|
}
|
|
if source, ok := req.Source.Get(); ok {
|
|
pmap.Add("source", source)
|
|
pmap.Add("hash", siphash.Hash(0, 0, []byte(source)))
|
|
}
|
|
if SubmissionID, ok := req.SubmissionID.Get(); ok {
|
|
pmap.Add("submission_id", SubmissionID)
|
|
}
|
|
return svc.DB.Scripts().Update(ctx, req.ID, pmap)
|
|
}
|