| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- /*
- 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 v1alpha1
- import (
- metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
- )
- // WebhookSpec controls the behavior of the external generator. Any body parameters should be passed to the server through the parameters field.
- type WebhookSpec struct {
- // Webhook Method
- // +optional, default GET
- Method string `json:"method,omitempty"`
- // Webhook url to call
- URL string `json:"url"`
- // Headers
- // +optional
- Headers map[string]string `json:"headers,omitempty"`
- // Body
- // +optional
- Body string `json:"body,omitempty"`
- // Timeout
- // +optional
- Timeout *metav1.Duration `json:"timeout,omitempty"`
- // Result formatting
- Result WebhookResult `json:"result"`
- // Secrets to fill in templates
- // These secrets will be passed to the templating function as key value pairs under the given name
- // +optional
- Secrets []WebhookSecret `json:"secrets,omitempty"`
- // PEM encoded CA bundle used to validate webhook server certificate. Only used
- // if the Server URL is using HTTPS protocol. This parameter is ignored for
- // plain HTTP protocol connection. If not set the system root certificates
- // are used to validate the TLS connection.
- // +optional
- CABundle []byte `json:"caBundle,omitempty"`
- // The provider for the CA bundle to use to validate webhook server certificate.
- // +optional
- CAProvider *WebhookCAProvider `json:"caProvider,omitempty"`
- }
- type WebhookCAProviderType string
- const (
- WebhookCAProviderTypeSecret WebhookCAProviderType = "Secret"
- WebhookCAProviderTypeConfigMap WebhookCAProviderType = "ConfigMap"
- )
- // Defines a location to fetch the cert for the webhook provider from.
- type WebhookCAProvider struct {
- // The type of provider to use such as "Secret", or "ConfigMap".
- // +kubebuilder:validation:Enum="Secret";"ConfigMap"
- Type WebhookCAProviderType `json:"type"`
- // The name of the object located at the provider type.
- Name string `json:"name"`
- // The key the value inside of the provider type to use, only used with "Secret" type
- // +kubebuilder:validation:Optional
- Key string `json:"key,omitempty"`
- // The namespace the Provider type is in.
- // +optional
- Namespace *string `json:"namespace,omitempty"`
- }
- type WebhookResult struct {
- // Json path of return value
- // +optional
- JSONPath string `json:"jsonPath,omitempty"`
- }
- type WebhookSecret struct {
- // Name of this secret in templates
- Name string `json:"name"`
- // Secret ref to fill in credentials
- SecretRef SecretKeySelector `json:"secretRef"`
- }
- type SecretKeySelector struct {
- // The name of the Secret resource being referred to.
- Name string `json:"name,omitempty"`
- // The key where the token is found.
- Key string `json:"key,omitempty"`
- }
- // Webhook connects to a third party API server to handle the secrets generation
- // configuration parameters in spec.
- // You can specify the server, the token, and additional body parameters.
- // See documentation for the full API specification for requests and responses.
- // +kubebuilder:object:root=true
- // +kubebuilder:storageversion
- // +kubebuilder:subresource:status
- // +kubebuilder:metadata:labels="external-secrets.io/component=controller"
- // +kubebuilder:resource:scope=Namespaced,categories={external-secrets, external-secrets-generators},shortName=webhookl
- type Webhook struct {
- metav1.TypeMeta `json:",inline"`
- metav1.ObjectMeta `json:"metadata,omitempty"`
- Spec WebhookSpec `json:"spec,omitempty"`
- }
- // +kubebuilder:object:root=true
- // ExternalList contains a list of Webhook Generator resources.
- type WebhookList struct {
- metav1.TypeMeta `json:",inline"`
- metav1.ListMeta `json:"metadata,omitempty"`
- Items []Webhook `json:"items"`
- }
|