Documentation ¶
Index ¶
- Constants
- Variables
- func AnnotationHash(i interface{}) string
- func ElasticsearchContainerDecorate(c corev1.Container, cluster, secret string) corev1.Container
- func ElasticsearchContainerDecorateENVVars(c corev1.Container, cluster, esUsername string) corev1.Container
- func ElasticsearchContainerDecorateVolumeMounts(c corev1.Container) corev1.Container
- func ElasticsearchDefaultVolume() corev1.Volume
- func ElasticsearchDefaultVolumeMount() corev1.VolumeMount
- func ElasticsearchPodSpecDecorate(p corev1.PodSpec) corev1.PodSpec
- func KubeControllers(cr *operator.Installation) *kubeControllersComponent
- func OperatorNamespace() string
- func ParseEndpoint(endpoint string) (string, string, string, error)
- func ParseHostPort(hostport string) (string, string, error)
- func SetTestLogger(l logr.Logger)
- type Component
- func APIServer(registry string, tlsKeyPair *corev1.Secret, pullSecrets []*corev1.Secret, ...) (Component, error)
- func AWSSecurityGroupSetup(ps []corev1.LocalObjectReference, r string) (Component, error)
- func Compliance(esSecrets []*corev1.Secret, registry string, clusterName string, ...) Component
- func ConfigMaps(cms []*corev1.ConfigMap) Component
- func CustomResourceDefinitions(cr *operator.Installation) Component
- func ElasticCurator(logStorage operatorv1.LogStorage, esSecrets, pullSecrets []*corev1.Secret, ...) Component
- func Elasticsearch(logStorage *operatorv1.LogStorage, esCertSecret *corev1.Secret, ...) (Component, error)
- func ElasticsearchSecrets(updatedESUserSecrets []*corev1.Secret, esPublicCertSecret *corev1.Secret, ...) Component
- func Fluentd(lc *operatorv1.LogCollector, ls *operatorv1.LogStorage, ...) Component
- func IntrusionDetection(ls *operatorv1.LogStorage, esSecrets []*corev1.Secret, ...) Component
- func Manager(cr *operator.Manager, esSecrets []*corev1.Secret, clusterName string, ...) (Component, error)
- func Namespaces(cr *operator.Installation, openshift bool, pullSecrets []*corev1.Secret) Component
- func Node(cr *operator.Installation, p operator.Provider, nc NetworkConfig, ...) Component
- func PriorityClassDefinitions(cr *operator.Installation) Component
- func Secrets(secrets []*corev1.Secret) Component
- func Typha(cr *operator.Installation, p operator.Provider, tnTLS *TyphaNodeTLS) Component
- type EksCloudwatchLogConfig
- type FluentdFilters
- type NetworkConfig
- type Renderer
- type S3Credential
- type TyphaNodeTLS
Constants ¶
const ( APIServerNamespace = "tigera-system" APIServerTLSSecretName = "tigera-apiserver-certs" APIServerSecretKeyName = "apiserver.key" APIServerSecretCertName = "apiserver.crt" )
const ( ElasticsearchUserComplianceBenchmarker = "tigera-ee-compliance-benchmarker" ElasticsearchUserComplianceController = "tigera-ee-compliance-controller" ElasticsearchUserComplianceReporter = "tigera-ee-compliance-reporter" ElasticsearchUserComplianceSnapshotter = "tigera-ee-compliance-snapshotter" ElasticsearchUserComplianceServer = "tigera-ee-compliance-server" ElasticsearchUserCurator = "tigera-ee-curator" )
const ( CNICalico = "calico" CNINone = "none" )
const ( ECKOperatorName = "elastic-operator" ECKOperatorNamespace = "tigera-eck-operator" ECKWebhookSecretName = "webhook-server-secret" ElasticsearchStorageClass = "tigera-elasticsearch" ElasticsearchNamespace = "tigera-elasticsearch" ElasticsearchHTTPURL = "tigera-secure-es-http.tigera-elasticsearch.svc" ElasticsearchHTTPSEndpoint = "https://tigera-secure-es-http.tigera-elasticsearch.svc:9200" ElasticsearchName = "tigera-secure" KibanaHTTPURL = "tigera-secure-kb-http.tigera-kibana.svc" KibanaHTTPSEndpoint = "https://tigera-secure-kb-http.tigera-kibana.svc:5601" KibanaName = "tigera-secure" KibanaNamespace = "tigera-kibana" KibanaPublicCertSecret = "tigera-secure-kb-http-certs-public" TigeraKibanaCertSecret = "tigera-secure-kibana-cert" KibanaDefaultCertPath = "/etc/ssl/kibana/ca.pem" )
const ( ElasticsearchDefaultCertDir = "/etc/ssl/elastic/" ElasticsearchDefaultCertPath = ElasticsearchDefaultCertDir + "ca.pem" TigeraElasticsearchCertSecret = "tigera-secure-elasticsearch-cert" ElasticsearchPublicCertSecret = "tigera-secure-es-http-certs-public" )
const ( LogCollectorNamespace = "tigera-fluentd" FluentdFilterConfigMapName = "fluentd-filters" FluentdFilterFlowName = "flow" FluentdFilterDNSName = "dns" S3FluentdSecretName = "log-collector-s3-credentials" S3KeyIdName = "key-id" S3KeySecretName = "key-secret" ElasticsearchUserLogCollector = "tigera-fluentd" ElasticsearchUserEksLogForwarder = "tigera-eks-log-forwarder" EksLogForwarderSecret = "tigera-eks-log-forwarder-secret" EksLogForwarderAwsId = "aws-id" EksLogForwarderAwsKey = "aws-key" )
const ( CalicoRegistry = "docker.io/" TigeraRegistry = "quay.io/" K8sGcrRegistry = "gcr.io/" ECKRegistry = "docker.elastic.co/" )
Default registries for Calico and Tigera.
const ( NodeImageNameCalico = "calico/node:" + components.VersionCalicoNode CNIImageName = "calico/cni:" + components.VersionCalicoCNI TyphaImageNameCalico = "calico/typha:" + components.VersionCalicoTypha KubeControllersImageNameCalico = "calico/kube-controllers:" + components.VersionCalicoKubeControllers FlexVolumeImageName = "calico/pod2daemon-flexvol:" + components.VersionFlexVolume )
This section contains images used when installing open-source Calico.
const ( // Overrides for Calico. NodeImageNameTigera = "tigera/cnx-node:" + components.VersionTigeraNode TyphaImageNameTigera = "tigera/typha:" + components.VersionTigeraTypha KubeControllersImageNameTigera = "tigera/kube-controllers:" + components.VersionTigeraKubeControllers // API server images. APIServerImageName = "tigera/cnx-apiserver:" + components.VersionAPIServer QueryServerImageName = "tigera/cnx-queryserver:" + components.VersionQueryServer // Logging FluentdImageName = "tigera/fluentd:" + components.VersionFluentd // Compliance images. ComplianceControllerImage = "tigera/compliance-controller:" + components.VersionComplianceController ComplianceReporterImage = "tigera/compliance-reporter:" + components.VersionComplianceReporter ComplianceServerImage = "tigera/compliance-server:" + components.VersionComplianceServer ComplianceSnapshotterImage = "tigera/compliance-snapshotter:" + components.VersionComplianceSnapshotter ComplianceBenchmarkerImage = "tigera/compliance-benchmarker:" + components.VersionComplianceBenchmarker // Intrusion detection images. IntrusionDetectionControllerImageName = "tigera/intrusion-detection-controller:" + components.VersionIntrusionDetectionController IntrusionDetectionJobInstallerImageName = "tigera/intrusion-detection-job-installer:" + components.VersionIntrusionDetectionJobInstaller // Manager images. ManagerImageName = "tigera/cnx-manager:" + components.VersionManager ManagerProxyImageName = "tigera/voltron:" + components.VersionManagerProxy ManagerEsProxyImageName = "tigera/es-proxy:" + components.VersionManagerEsProxy KibanaImageName = "tigera/kibana:" + components.VersionKibana ECKOperatorImageName = "eck/eck-operator:" + components.VersionECKOperator ECKElasticsearchImageName = "elasticsearch/elasticsearch:" + components.VersionECKElasticsearch EsCuratorImageName = "tigera/es-curator:" + components.VersionEsCurator )
This section contains images used when installing Tigera Secure.
const ( IntrusionDetectionNamespace = "tigera-intrusion-detection" ElasticsearchUserIntrusionDetection = "tigera-ee-intrusion-detection" ElasticsearchUserIntrusionDetectionJob = "tigera-ee-installer" )
const ( ManagerNamespace = "tigera-manager" ManagerTLSSecretName = "manager-tls" ManagerSecretKeyName = "key" ManagerSecretCertName = "cert" ElasticsearchUserManager = "tigera-ee-manager" DefaultKibanaURL = "https://localhost:5601" )
const ( CalicoNamespace = "calico-system" TigeraPrometheusNamespace = "tigera-prometheus" )
const ( TyphaServiceName = "calico-typha" TyphaPortName = "calico-typha" TyphaK8sAppName = "calico-typha" TyphaServiceAccountName = "calico-typha" TyphaDeploymentName = "calico-typha" AppLabelName = "k8s-app" TyphaPort int32 = 5473 )
const (
BirdTemplatesConfigMapName = "bird-templates"
)
const (
ComplianceNamespace = "tigera-compliance"
)
const (
// The version is supplied by the renderer.
OperatorInitImageName = "tigera/operator-init:"
)
This section contains images used for utility operator functions.
const (
Optional = true
)
const TigeraAWSSGSetupName = "tigera-aws-security-group-setup"
Variables ¶
var ( TyphaCAConfigMapName = "typha-ca" TyphaCABundleName = "caBundle" TyphaTLSSecretName = "typha-certs" NodeTLSSecretName = "node-certs" TLSSecretCertName = "cert.crt" TLSSecretKeyName = "key.key" CommonName = "common-name" URISAN = "uri-san" )
var (
EsCuratorName = "elastic-curator"
)
Functions ¶
func AnnotationHash ¶ added in v1.0.0
func AnnotationHash(i interface{}) string
AnnotationHash is to generate a hash that can be included in a Deployment or DaemonSet to trigger a restart/rolling update when a ConfigMap or Secret is updated.
func ElasticsearchContainerDecorate ¶ added in v1.0.0
func ElasticsearchContainerDecorateENVVars ¶ added in v1.0.0
func ElasticsearchContainerDecorateVolumeMounts ¶ added in v1.0.0
func ElasticsearchDefaultVolume ¶ added in v1.0.0
func ElasticsearchDefaultVolumeMount ¶ added in v1.0.0
func ElasticsearchDefaultVolumeMount() corev1.VolumeMount
func ElasticsearchPodSpecDecorate ¶ added in v1.0.0
func KubeControllers ¶
func KubeControllers(cr *operator.Installation) *kubeControllersComponent
func OperatorNamespace ¶ added in v1.0.0
func OperatorNamespace() string
func ParseEndpoint ¶
ParseEndpoint parses an endpoint of the form scheme://host:port and returns the components.
func SetTestLogger ¶
Types ¶
type Component ¶
type Component interface { // Objects returns all objects this component contains. Objects() []runtime.Object // Ready returns true if the component is ready to be created. Ready() bool }
func AWSSecurityGroupSetup ¶ added in v1.0.0
func AWSSecurityGroupSetup(ps []corev1.LocalObjectReference, r string) (Component, error)
func Compliance ¶
func ConfigMaps ¶ added in v1.0.0
func CustomResourceDefinitions ¶
func CustomResourceDefinitions(cr *operator.Installation) Component
func ElasticCurator ¶ added in v1.0.0
func ElasticCurator(logStorage operatorv1.LogStorage, esSecrets, pullSecrets []*corev1.Secret, registry, clusterName string) Component
func Elasticsearch ¶ added in v1.0.0
func Elasticsearch( logStorage *operatorv1.LogStorage, esCertSecret *corev1.Secret, kibanaCertSecret *corev1.Secret, createWebhookSecret bool, pullSecrets []*corev1.Secret, provider operatorv1.Provider, registry string) (Component, error)
func ElasticsearchSecrets ¶ added in v1.0.0
func Fluentd ¶ added in v1.0.0
func Fluentd( lc *operatorv1.LogCollector, ls *operatorv1.LogStorage, esSecrets []*corev1.Secret, cluster string, s3C *S3Credential, f *FluentdFilters, eksConfig *EksCloudwatchLogConfig, pullSecrets []*corev1.Secret, installation *operatorv1.Installation, ) Component
func IntrusionDetection ¶
func Namespaces ¶
func Node ¶
func Node(cr *operator.Installation, p operator.Provider, nc NetworkConfig, bt map[string]string, tnTLS *TyphaNodeTLS) Component
Node creates the node daemonset and other resources for the daemonset to operate normally.
func PriorityClassDefinitions ¶
func PriorityClassDefinitions(cr *operator.Installation) Component
func Typha ¶ added in v1.0.0
func Typha(cr *operator.Installation, p operator.Provider, tnTLS *TyphaNodeTLS) Component
Typha creates the typha daemonset and other resources for the daemonset to operate normally.
type EksCloudwatchLogConfig ¶ added in v1.0.0
type FluentdFilters ¶ added in v1.0.0
type NetworkConfig ¶ added in v1.0.0
type NetworkConfig struct { CNI string NodenameFileOptional bool IPPools []operatorv1.IPPool }
type Renderer ¶
type Renderer interface {
Render() []Component
}
A Renderer is capable of generating components to be installed on the cluster.
func Calico ¶
func Calico( cr *operator.Installation, pullSecrets []*corev1.Secret, typhaNodeTLS *TyphaNodeTLS, bt map[string]string, p operator.Provider, nc NetworkConfig, ) (Renderer, error)
type S3Credential ¶ added in v1.0.0
Source Files ¶
- apiserver.go
- aws-securitygroup-setup.go
- common.go
- compliance.go
- config.go
- configmap.go
- crds.go
- elastic_curator.go
- elasticsearch.go
- elasticsearch_decorator.go
- elasticsearch_secrets.go
- fluentd.go
- images.go
- intrusion_detection.go
- kube-controllers.go
- manager.go
- namespaces.go
- node.go
- priority_class.go
- render.go
- secrets.go
- typha.go