mirror of
https://github.com/harness/drone.git
synced 2025-05-05 19:53:13 +08:00

This change is adding the concept of Paths. A repository and space always have a Primary Path which always is represents the ancestry to the root space. All access history / resource visibility / child listings / UI traversal / etc. is done via that path. Additionally, repos and spaces can have Alias Paths, which as the name states are aliases. via the primary path. They sole impact is that a space or repo can be reached via different paths from the UI / rest apis / git apis. This fulfills two major purposes: - Customers can rename or move projects and spaces without breaking any existing references from CI pipeliens / code bases / local repos / ... - Customer can create shorter aliases for important repos when in harness embeded mode! (acc/org/proj/repo can be shortened to acc/repo, or acc/repo' Apart from the path changes, this PR adds: Improved User facing errors Improved internal error handling and wrapping update / rename operation for repo and space path list / delete / create operation for repo and space
26 lines
444 B
Go
26 lines
444 B
Go
package request
|
|
|
|
import (
|
|
"net/http"
|
|
"net/url"
|
|
"strings"
|
|
|
|
"github.com/go-chi/chi"
|
|
"github.com/harness/gitness/types/errs"
|
|
)
|
|
|
|
const (
|
|
RepoRefParamName = "rref"
|
|
)
|
|
|
|
func GetRepoRef(r *http.Request) (string, error) {
|
|
rawRef := chi.URLParam(r, RepoRefParamName)
|
|
if rawRef == "" {
|
|
return "", errs.RepoReferenceNotFoundInRequest
|
|
}
|
|
|
|
// paths are unescaped and lower
|
|
ref, err := url.PathUnescape(rawRef)
|
|
return strings.ToLower(ref), err
|
|
}
|