mirror of
https://github.com/harness/drone.git
synced 2025-05-05 05:51:56 +08:00

This change is a follow up on the effort to remove transactions and sync stores from the database layer, and move them in the application layer. It is addressing the repo + space store. The following changes are included: - Introduce PathStore storing resource paths (repo + space) - Add foreign key from path.repo_id/space_id to repo.id/space.id - Add foreign key from repo/space.parent_id to space.id - Remove repo_sync and space_sync - Move path creation logic to repo/space controller (for both creating primary paths for new repos/spaces, as well as creating alias spaces) - Reimplement repo/space moving on controller layer
65 lines
1.5 KiB
Go
65 lines
1.5 KiB
Go
// Copyright 2022 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 enum
|
|
|
|
import (
|
|
"golang.org/x/exp/constraints"
|
|
"golang.org/x/exp/slices"
|
|
)
|
|
|
|
func Sanitize[E constraints.Ordered](element E, all func() ([]E, E)) (E, bool) {
|
|
allValues, defValue := all()
|
|
var empty E
|
|
if element == empty && defValue != empty {
|
|
return defValue, true
|
|
}
|
|
idx, exists := slices.BinarySearch(allValues, element)
|
|
if exists {
|
|
return allValues[idx], true
|
|
}
|
|
return defValue, false
|
|
}
|
|
|
|
const (
|
|
id = "id"
|
|
uid = "uid"
|
|
path = "path"
|
|
name = "name"
|
|
email = "email"
|
|
admin = "admin"
|
|
number = "number"
|
|
created = "created"
|
|
createdAt = "created_at"
|
|
createdBy = "created_by"
|
|
updated = "updated"
|
|
updatedAt = "updated_at"
|
|
updatedBy = "updated_by"
|
|
displayName = "display_name"
|
|
date = "date"
|
|
defaultString = "default"
|
|
undefined = "undefined"
|
|
system = "system"
|
|
comment = "comment"
|
|
code = "code"
|
|
asc = "asc"
|
|
ascending = "ascending"
|
|
desc = "desc"
|
|
descending = "descending"
|
|
value = "value"
|
|
)
|
|
|
|
func toInterfaceSlice[T interface{}](vals []T) []interface{} {
|
|
res := make([]interface{}, len(vals))
|
|
for i := range vals {
|
|
res[i] = vals[i]
|
|
}
|
|
return res
|
|
}
|
|
|
|
func sortEnum[T constraints.Ordered](slice []T) []T {
|
|
slices.Sort(slice)
|
|
return slice
|
|
}
|