policy

package
v0.0.0-...-e9f4c3e Latest Latest
Warning

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

Go to latest
Published: Dec 26, 2024 License: Apache-2.0 Imports: 28 Imported by: 0

Documentation

Index

Constants

View Source
const (
	SecurityPolicyPrefix             = "tower.sp-"
	IsolationPolicyPrefix            = "tower.ip-"
	IsolationPolicyIngressPrefix     = "tower.ip.ingress-"
	IsolationPolicyEgressPrefix      = "tower.ip.egress-"
	SecurityPolicyCommunicablePrefix = "tower.sp.communicable-"

	SystemEndpointsPolicyName = "tower.sp.internal-system.endpoints"
	ControllerPolicyName      = "tower.sp.internal-controller"
	GlobalWhitelistPolicyName = "tower.sp.global-user.whitelist"

	FTPPortRange  = "21"
	TFTPPortRange = "69"

	InternalAllowlistPriority int32 = 90
	BlocklistPriority         int32 = 50
	AllowlistPriority         int32 = 30

	K8sNsNameLabel = "kubernetes.io/metadata.name"
)

Variables

This section is empty.

Functions

func NewLoggingOptionsFrom

func NewLoggingOptionsFrom(obj schema.Object, vmLister informer.Lister) *v1alpha1.Logging

Types

type Controller

type Controller struct {
	// contains filtered or unexported fields
}

Controller sync SecurityPolicy and IsolationPolicy as v1alpha1.SecurityPolicy from tower. For v1alpha1.SecurityPolicy, has the following naming rules:

  1. If origin policy is SecurityPolicy, policy.name = {{SecurityPolicyPrefix}}{{SecurityPolicy.ID}}
  2. If origin policy is IsolationPolicy, policy.name = {{IsolationPolicyPrefix}}{{IsolationPolicy.ID}}
  3. If policy was generated to make intragroup communicable, policy.name = {{SecurityPolicyCommunicablePrefix}}{{SelectorHash}}-{{SecurityPolicy.ID}}
  4. If origin policy is SystemEndpointsPolicy, policy.name = {{SystemEndpointsPolicyName}}
  5. If origin policy is ControllerPolicy, policy.name = {{ControllerPolicyName}}

func New

func New(
	towerFactory informer.SharedInformerFactory,
	crdFactory crd.SharedInformerFactory,
	crdClient clientset.Interface,
	resyncPeriod time.Duration,
	namespace string,
	podNamespace string,
	everouteCluster string,
) *Controller

New creates a new instance of controller.

func (*Controller) Run

func (c *Controller) Run(workers uint, stopCh <-chan struct{})

Run begins processing items, and will continue until a value is sent down stopCh, or stopCh closed.

Jump to

Keyboard shortcuts

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