drone/types/check/space.go
Johannes Batzill b7b9f53b0d Improve error handling to match go standards - don't wrap and rethrow, but log and return. Also adds some more validations for path creation and resource moving. Add accesslogging for git and api router (#14)
This commit contains the following:
- Improve and simplify error handling (remove unnecessary wrappers, make it feel like go)
- Add extra validation for path creation and resource moving (path has to be within same top space, no top space alias allowed)
- Add access logging for rest api and git api
2022-09-09 22:08:46 -07:00

48 lines
1.1 KiB
Go

// Copyright 2021 Harness Inc. All rights reserved.
// Use of this source code is governed by the Polyform Free Trial License
// that can be found in the LICENSE.md file for this repository.
package check
import (
"fmt"
"strings"
"github.com/harness/gitness/types"
)
var (
illegalRootSpaceNames = []string{"api"}
ErrRootSpaceNameNotAllowed = &CheckError{fmt.Sprintf("The following names are not allowed for a root space: %v", illegalRootSpaceNames)}
ErrInvalidParentSpaceId = &CheckError{"Parent space ID has to be either zero for a root space or greater than zero for a child space."}
)
// Repo checks the provided space and returns an error in it isn't valid.
func Space(space *types.Space) error {
// validate name
if err := Name(space.Name); err != nil {
return err
}
// validate display name
if err := DisplayName(space.DisplayName); err != nil {
return err
}
if space.ParentId < 0 {
return ErrInvalidParentSpaceId
}
// root space specific validations
if space.ParentId == 0 {
for _, p := range illegalRootSpaceNames {
if strings.HasPrefix(space.Name, p) {
return ErrRootSpaceNameNotAllowed
}
}
}
return nil
}