2024-12-06 00:47:40 +00:00
|
|
|
package service
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2024-12-06 02:52:57 +00:00
|
|
|
|
2024-12-06 00:47:40 +00:00
|
|
|
"git.itzana.me/strafesnet/maps-service/pkg/api"
|
2024-12-06 02:52:57 +00:00
|
|
|
"git.itzana.me/strafesnet/maps-service/pkg/datastore"
|
|
|
|
"git.itzana.me/strafesnet/maps-service/pkg/model"
|
2024-12-06 00:47:40 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// CreateScript implements createScript operation.
|
|
|
|
//
|
|
|
|
// Create a new script.
|
|
|
|
//
|
|
|
|
// POST /scripts
|
2024-12-12 22:29:20 +00:00
|
|
|
func (svc *Service) CreateScript(ctx context.Context, req *api.ScriptCreate) (*api.ID, error) {
|
2024-12-10 05:19:38 +00:00
|
|
|
userInfo, ok := ctx.Value("UserInfo").(UserInfo)
|
2024-12-12 22:29:20 +00:00
|
|
|
if !ok {
|
2024-12-06 02:52:57 +00:00
|
|
|
return nil, ErrUserInfo
|
|
|
|
}
|
|
|
|
|
2024-12-28 01:24:09 +00:00
|
|
|
has_role, err := userInfo.HasRoleScriptWrite()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if !has_role {
|
2024-12-06 02:52:57 +00:00
|
|
|
return nil, ErrPermissionDenied
|
|
|
|
}
|
|
|
|
|
|
|
|
script, err := svc.DB.Scripts().Create(ctx, model.Script{
|
|
|
|
ID: 0,
|
2024-12-14 20:31:31 +00:00
|
|
|
Name: req.Name,
|
2024-12-20 00:49:22 +00:00
|
|
|
Hash: int64(model.HashSource(req.Source)),
|
2024-12-06 02:52:57 +00:00
|
|
|
Source: req.Source,
|
|
|
|
SubmissionID: req.SubmissionID.Or(0),
|
|
|
|
})
|
2024-12-12 22:29:20 +00:00
|
|
|
if err != nil {
|
2024-12-06 02:52:57 +00:00
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &api.ID{
|
2024-12-12 22:29:20 +00:00
|
|
|
ID: script.ID,
|
2024-12-06 02:52:57 +00:00
|
|
|
}, nil
|
2024-12-06 00:47:40 +00:00
|
|
|
}
|
2024-12-12 22:29:20 +00:00
|
|
|
|
2024-12-18 23:22:23 +00:00
|
|
|
// ListScripts implements listScripts operation.
|
|
|
|
//
|
|
|
|
// Get list of scripts.
|
|
|
|
//
|
|
|
|
// GET /scripts
|
|
|
|
func (svc *Service) ListScripts(ctx context.Context, params api.ListScriptsParams) ([]api.Script, error) {
|
|
|
|
filter := datastore.Optional()
|
|
|
|
|
|
|
|
if params.Hash.IsSet(){
|
|
|
|
hash, err := model.HashParse(params.Hash.Value)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2024-12-20 00:49:22 +00:00
|
|
|
filter.AddNotNil("hash", int64(hash)) // No type safety!
|
2024-12-18 23:22:23 +00:00
|
|
|
}
|
|
|
|
if params.Name.IsSet(){
|
|
|
|
filter.AddNotNil("name", params.Name.Value)
|
|
|
|
}
|
|
|
|
if params.Source.IsSet(){
|
|
|
|
filter.AddNotNil("source", params.Source.Value)
|
|
|
|
}
|
|
|
|
if params.SubmissionID.IsSet(){
|
|
|
|
filter.AddNotNil("submission_id", params.SubmissionID.Value)
|
|
|
|
}
|
|
|
|
|
|
|
|
items, err := svc.DB.Scripts().List(ctx, filter, model.Page{
|
|
|
|
Number: params.Page,
|
|
|
|
Size: params.Limit,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var resp []api.Script
|
|
|
|
for i := 0; i < len(items); i++ {
|
|
|
|
resp = append(resp, api.Script{
|
|
|
|
ID: items[i].ID,
|
2024-12-20 00:49:22 +00:00
|
|
|
Hash: model.HashFormat(uint64(items[i].Hash)),
|
2024-12-18 23:22:23 +00:00
|
|
|
Source: items[i].Source,
|
|
|
|
SubmissionID: items[i].SubmissionID,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return resp, nil
|
|
|
|
}
|
|
|
|
|
2024-12-06 00:47:40 +00:00
|
|
|
// DeleteScript implements deleteScript operation.
|
|
|
|
//
|
|
|
|
// Delete the specified script by ID.
|
|
|
|
//
|
|
|
|
// DELETE /scripts/{ScriptID}
|
2024-12-12 22:29:20 +00:00
|
|
|
func (svc *Service) DeleteScript(ctx context.Context, params api.DeleteScriptParams) error {
|
2024-12-10 05:19:38 +00:00
|
|
|
userInfo, ok := ctx.Value("UserInfo").(UserInfo)
|
2024-12-12 22:29:20 +00:00
|
|
|
if !ok {
|
2024-12-06 02:52:57 +00:00
|
|
|
return ErrUserInfo
|
|
|
|
}
|
|
|
|
|
2024-12-28 01:24:09 +00:00
|
|
|
has_role, err := userInfo.HasRoleScriptWrite()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if !has_role {
|
2024-12-06 02:52:57 +00:00
|
|
|
return ErrPermissionDenied
|
|
|
|
}
|
|
|
|
|
|
|
|
return svc.DB.Scripts().Delete(ctx, params.ScriptID)
|
2024-12-06 00:47:40 +00:00
|
|
|
}
|
2024-12-12 22:29:20 +00:00
|
|
|
|
2024-12-06 00:47:40 +00:00
|
|
|
// GetScript implements getScript operation.
|
|
|
|
//
|
|
|
|
// Get the specified script by ID.
|
|
|
|
//
|
|
|
|
// GET /scripts/{ScriptID}
|
2024-12-12 22:29:20 +00:00
|
|
|
func (svc *Service) GetScript(ctx context.Context, params api.GetScriptParams) (*api.Script, error) {
|
2024-12-10 05:19:38 +00:00
|
|
|
_, ok := ctx.Value("UserInfo").(UserInfo)
|
2024-12-12 22:29:20 +00:00
|
|
|
if !ok {
|
2024-12-06 02:52:57 +00:00
|
|
|
return nil, ErrUserInfo
|
|
|
|
}
|
|
|
|
|
|
|
|
// Read permission for scripts only requires you to be logged in
|
|
|
|
|
|
|
|
script, err := svc.DB.Scripts().Get(ctx, params.ScriptID)
|
2024-12-12 22:29:20 +00:00
|
|
|
if err != nil {
|
2024-12-06 02:52:57 +00:00
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &api.Script{
|
|
|
|
ID: script.ID,
|
2024-12-14 20:31:31 +00:00
|
|
|
Name: script.Name,
|
2024-12-20 00:49:22 +00:00
|
|
|
Hash: model.HashFormat(uint64(script.Hash)),
|
2024-12-06 02:52:57 +00:00
|
|
|
Source: script.Source,
|
|
|
|
SubmissionID: script.SubmissionID,
|
|
|
|
}, nil
|
2024-12-06 00:47:40 +00:00
|
|
|
}
|
2024-12-12 22:29:20 +00:00
|
|
|
|
2024-12-06 00:47:40 +00:00
|
|
|
// UpdateScript implements updateScript operation.
|
|
|
|
//
|
|
|
|
// Update the specified script by ID.
|
|
|
|
//
|
|
|
|
// PATCH /scripts/{ScriptID}
|
2024-12-12 22:29:20 +00:00
|
|
|
func (svc *Service) UpdateScript(ctx context.Context, req *api.ScriptUpdate, params api.UpdateScriptParams) error {
|
2024-12-10 05:19:38 +00:00
|
|
|
userInfo, ok := ctx.Value("UserInfo").(UserInfo)
|
2024-12-12 22:29:20 +00:00
|
|
|
if !ok {
|
2024-12-06 02:52:57 +00:00
|
|
|
return ErrUserInfo
|
|
|
|
}
|
|
|
|
|
2024-12-28 01:24:09 +00:00
|
|
|
has_role, err := userInfo.HasRoleScriptWrite()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if !has_role {
|
2024-12-06 02:52:57 +00:00
|
|
|
return ErrPermissionDenied
|
|
|
|
}
|
|
|
|
|
|
|
|
pmap := datastore.Optional()
|
2024-12-14 20:31:31 +00:00
|
|
|
if Name, ok := req.Name.Get(); ok {
|
|
|
|
pmap.Add("name", Name)
|
|
|
|
}
|
2024-12-12 22:29:20 +00:00
|
|
|
if source, ok := req.Source.Get(); ok {
|
|
|
|
pmap.Add("source", source)
|
2024-12-20 00:49:22 +00:00
|
|
|
pmap.Add("hash", int64(model.HashSource(source))) // No type safety!
|
2024-12-06 02:52:57 +00:00
|
|
|
}
|
2024-12-12 22:29:20 +00:00
|
|
|
if SubmissionID, ok := req.SubmissionID.Get(); ok {
|
|
|
|
pmap.Add("submission_id", SubmissionID)
|
2024-12-06 02:52:57 +00:00
|
|
|
}
|
|
|
|
return svc.DB.Scripts().Update(ctx, req.ID, pmap)
|
2024-12-06 00:47:40 +00:00
|
|
|
}
|