k3s/vendor/github.com/rancher/wrangler/pkg/name/name.go

67 lines
1.4 KiB
Go

package name
import (
"crypto/md5"
"crypto/sha256"
"encoding/hex"
"fmt"
"strings"
)
func GuessPluralName(name string) string {
if name == "" {
return name
}
if strings.EqualFold(name, "Endpoints") {
return name
}
if suffix(name, "s") || suffix(name, "ch") || suffix(name, "x") || suffix(name, "sh") {
return name + "es"
}
if suffix(name, "f") || suffix(name, "fe") {
return name + "ves"
}
if suffix(name, "y") && len(name) > 2 && !strings.ContainsAny(name[len(name)-2:len(name)-1], "[aeiou]") {
return name[0:len(name)-1] + "ies"
}
return name + "s"
}
func suffix(str, end string) bool {
return strings.HasSuffix(str, end)
}
func Limit(s string, count int) string {
if len(s) < count {
return s
}
return fmt.Sprintf("%s-%s", s[:count-6], Hex(s, 5))
}
func Hex(s string, length int) string {
h := md5.Sum([]byte(s))
d := hex.EncodeToString(h[:])
return d[:length]
}
func SafeConcatName(name ...string) string {
fullPath := strings.Join(name, "-")
if len(fullPath) < 64 {
return fullPath
}
digest := sha256.Sum256([]byte(fullPath))
// since we cut the string in the middle, the last char may not be compatible with what is expected in k8s
// we are checking and if necessary removing the last char
c := fullPath[56]
if 'a' <= c && c <= 'z' || '0' <= c && c <= '9' {
return fullPath[0:57] + "-" + hex.EncodeToString(digest[0:])[0:5]
}
return fullPath[0:56] + "-" + hex.EncodeToString(digest[0:])[0:6]
}