checkers

package
v1.42.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 22, 2021 License: Apache-2.0 Imports: 15 Imported by: 11

Documentation

Index

Constants

View Source
const AuthorizationPolicyCheckerType = "authorizationpolicy"
View Source
const DestinationRuleCheckerType = "destinationrule"
View Source
const GatewayCheckerType = "gateway"
View Source
const PeerAuthenticationCheckerType = "peerauthentication"
View Source
const RequestAuthenticationCheckerType = "requestauthentication"
View Source
const ServiceCheckerType = "service"
View Source
const ServiceEntryCheckerType = "serviceentry"
View Source
const ServiceRoleCheckerType = "servicerole"
View Source
const SidecarCheckerType = "sidecar"
View Source
const VirtualCheckerType = "virtualservice"

Variables

This section is empty.

Functions

func EmptyValidValidation added in v0.17.0

func EmptyValidValidation(name, namespace, objectType string) (models.IstioValidationKey, *models.IstioValidation)

func EmptyValidValidations added in v0.17.0

func EmptyValidValidations(name, namespace, objectType string) models.IstioValidations

EmptyValidValidation returns a stub validation object which can be used by checkers

Types

type AuthorizationPolicyChecker added in v1.14.0

type AuthorizationPolicyChecker struct {
	AuthorizationPolicies   []security_v1beta.AuthorizationPolicy
	Namespace               string
	Namespaces              models.Namespaces
	ServiceEntries          []networking_v1alpha3.ServiceEntry
	ExportedServiceEntries  []networking_v1alpha3.ServiceEntry
	Services                []core_v1.Service
	WorkloadList            models.WorkloadList
	MtlsDetails             kubernetes.MTLSDetails
	VirtualServices         []networking_v1alpha3.VirtualService
	ExportedVirtualServices []networking_v1alpha3.VirtualService
	RegistryStatus          []*kubernetes.RegistryStatus
}

func (AuthorizationPolicyChecker) Check added in v1.14.0

type Checker

type Checker interface {
	Check() ([]*models.IstioCheck, bool)
}

type DestinationRulesChecker

type DestinationRulesChecker struct {
	DestinationRules         []networking_v1alpha3.DestinationRule
	ExportedDestinationRules []networking_v1alpha3.DestinationRule
	MTLSDetails              kubernetes.MTLSDetails
	ServiceEntries           []networking_v1alpha3.ServiceEntry
	ExportedServiceEntries   []networking_v1alpha3.ServiceEntry
	Namespaces               []models.Namespace
}

func (DestinationRulesChecker) Check

type GatewayChecker added in v0.11.0

type GatewayChecker struct {
	GatewaysPerNamespace  [][]networking_v1alpha3.Gateway
	Namespace             string
	WorkloadsPerNamespace map[string]models.WorkloadList
}

func (GatewayChecker) Check added in v0.11.0

Check runs checks for the all namespaces actions as well as for the single namespace validations

type GroupChecker

type GroupChecker interface {
	Check() models.IstioValidations
}

type NoServiceChecker

type NoServiceChecker struct {
	Namespace            string
	Namespaces           models.Namespaces
	IstioConfigList      models.IstioConfigList
	ExportedResources    *kubernetes.ExportedResources
	Services             []core_v1.Service
	WorkloadList         models.WorkloadList
	GatewaysPerNamespace [][]networking_v1alpha3.Gateway
	AuthorizationDetails *kubernetes.RBACDetails
	RegistryStatus       []*kubernetes.RegistryStatus
}

func (NoServiceChecker) Check

type PeerAuthenticationChecker added in v1.18.1

type PeerAuthenticationChecker struct {
	PeerAuthentications []security_v1beta.PeerAuthentication
	MTLSDetails         kubernetes.MTLSDetails
	WorkloadList        models.WorkloadList
}

func (PeerAuthenticationChecker) Check added in v1.18.1

type RequestAuthenticationChecker added in v1.22.1

type RequestAuthenticationChecker struct {
	RequestAuthentications []security_v1beta.RequestAuthentication
	WorkloadList           models.WorkloadList
}

func (RequestAuthenticationChecker) Check added in v1.22.1

type ServiceChecker added in v0.19.0

type ServiceChecker struct {
	Services    []v1.Service
	Deployments []apps_v1.Deployment
	Pods        []core_v1.Pod
}

func (ServiceChecker) Check added in v0.19.0

type ServiceEntryChecker added in v0.16.0

type ServiceEntryChecker struct {
	ServiceEntries         []networking_v1alpha3.ServiceEntry
	ExportedServiceEntries []networking_v1alpha3.ServiceEntry
	Namespaces             models.Namespaces
}

func (ServiceEntryChecker) Check added in v0.16.0

type SidecarChecker added in v1.15.0

type SidecarChecker struct {
	Sidecars               []networking_v1alpha3.Sidecar
	ServiceEntries         []networking_v1alpha3.ServiceEntry
	ExportedServiceEntries []networking_v1alpha3.ServiceEntry
	Services               []core_v1.Service
	Namespaces             models.Namespaces
	WorkloadList           models.WorkloadList
}

func (SidecarChecker) Check added in v1.15.0

type VirtualServiceChecker

type VirtualServiceChecker struct {
	Namespace                string
	Namespaces               models.Namespaces
	DestinationRules         []networking_v1alpha3.DestinationRule
	VirtualServices          []networking_v1alpha3.VirtualService
	ExportedVirtualServices  []networking_v1alpha3.VirtualService
	ExportedDestinationRules []networking_v1alpha3.DestinationRule
}

func (VirtualServiceChecker) Check

An Object Checker runs all checkers for an specific object type (i.e.: pod, route rule,...) It run two kinds of checkers: 1. Individual checks: validating individual objects. 2. Group checks: validating behaviour between configurations.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL