mirror of
https://github.com/projectcapsule/capsule.git
synced 2026-03-04 18:50:31 +00:00
Disabled by default to avoid breaking changes for upcoming release, although minor will be enabled by default. Using the new `--allow-ingress-hostname-collision` flag Capsule can ignore the Ingress hostnames collision allowing the Cluster Administrator to put in place a non-opinionated hostnames allocation.
102 lines
2.9 KiB
Go
102 lines
2.9 KiB
Go
/*
|
|
Copyright 2020 Clastix Labs.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package ingress
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
|
|
"github.com/clastix/capsule/api/v1alpha1"
|
|
)
|
|
|
|
type ingressClassForbidden struct {
|
|
className string
|
|
spec v1alpha1.AllowedListSpec
|
|
}
|
|
|
|
func NewIngressClassForbidden(className string, spec v1alpha1.AllowedListSpec) error {
|
|
return &ingressClassForbidden{
|
|
className: className,
|
|
spec: spec,
|
|
}
|
|
}
|
|
|
|
func (i ingressClassForbidden) Error() string {
|
|
return fmt.Sprintf("Ingress Class %s is forbidden for the current Tenant%s", i.className, appendClassError(i.spec))
|
|
}
|
|
|
|
type ingressHostnameNotValid struct {
|
|
invalidHostnames []string
|
|
notMatchingHostnames []string
|
|
spec v1alpha1.AllowedListSpec
|
|
}
|
|
|
|
type ingressHostnameCollision struct {
|
|
hostname string
|
|
}
|
|
|
|
func (i ingressHostnameCollision) Error() string {
|
|
return fmt.Sprintf("hostname %s is already used across the cluster: please, reach out to the system administrators", i.hostname)
|
|
}
|
|
|
|
func NewIngressHostnameCollision(hostname string) error {
|
|
return ingressHostnameCollision{hostname: hostname}
|
|
}
|
|
|
|
func NewIngressHostnamesNotValid(invalidHostnames []string, notMatchingHostnames []string, spec v1alpha1.AllowedListSpec) error {
|
|
return &ingressHostnameNotValid{invalidHostnames: invalidHostnames, notMatchingHostnames: notMatchingHostnames, spec: spec}
|
|
}
|
|
|
|
func (i ingressHostnameNotValid) Error() string {
|
|
return fmt.Sprintf("Hostnames %s are not valid for the current Tenant. Hostnames %s not matching for the current Tenant%s",
|
|
i.invalidHostnames, i.notMatchingHostnames, appendHostnameError(i.spec))
|
|
}
|
|
|
|
type ingressClassNotValid struct {
|
|
spec v1alpha1.AllowedListSpec
|
|
}
|
|
|
|
func NewIngressClassNotValid(spec v1alpha1.AllowedListSpec) error {
|
|
return &ingressClassNotValid{
|
|
spec: spec,
|
|
}
|
|
}
|
|
|
|
func (i ingressClassNotValid) Error() string {
|
|
return "A valid Ingress Class must be used" + appendClassError(i.spec)
|
|
}
|
|
|
|
func appendClassError(spec v1alpha1.AllowedListSpec) (append string) {
|
|
if len(spec.Exact) > 0 {
|
|
append += fmt.Sprintf(", one of the following (%s)", strings.Join(spec.Exact, ", "))
|
|
}
|
|
if len(spec.Regex) > 0 {
|
|
append += fmt.Sprintf(", or matching the regex %s", spec.Regex)
|
|
}
|
|
return
|
|
}
|
|
|
|
func appendHostnameError(spec v1alpha1.AllowedListSpec) (append string) {
|
|
if len(spec.Exact) > 0 {
|
|
append += fmt.Sprintf(", specify one of the following (%s)", strings.Join(spec.Exact, ", "))
|
|
}
|
|
if len(spec.Regex) > 0 {
|
|
append += fmt.Sprintf(", or matching the regex %s", spec.Regex)
|
|
}
|
|
return
|
|
}
|