Source
The source settings contains:
- Resource list you want to watch,
- Namespaces you want to filter,
- The type of events you want to get notifications about,
- Settings to monitor updates for the specific resource fields,
- Ability to turn on/off specific recommendations per a given source.
Sources are bound to specific channels in the communications configuration. To learn more, read the Source and Executor Bindings section.
Kubernetes resource events​
A source essentially notifies a channel about events for configured resources filtered by specified namespaces.
Merging strategy​
When a channel binds to more than one source, the resource notifications are merged across all sources.
Let's say you have a resource defined in more than one source but wired with different events and namespaces.
sources:
  "k8s-events":
    kubernetes:
      resources:
        - name: v1/configmaps
          namespaces:
            include:
              - (botk.*|default)
          events:
            - create
            - update
            - delete
  "k8s-updates":
    kubernetes:
      resources:
        - name: v1/configmaps
          namespaces:
            include:
              - botkube
          events:
            - update
The bound channel monitor-config (below) will notify on the merged events and namespaces across all resource/source definitions.
communications:
  "default-group":
    slack:
      # ... trimmed ...
      channels:
        "monitor-config":
          name: "monitor-config"
          # ... trimmed ...
          bindings:
            # ... trimmed ...
            sources:
              - k8s-events
              - k8s-updates
Meaning, channel monitor-config will receive notifications for v1/configmaps events matching,
- the botk.*|defaultandbotkubenamespaces.
- the create,deleteandupdateevent types.
Recommendations​
For every source, you can configure recommendations related to Kubernetes resources.
Merging Strategy​
Recommendations take a different approach from the Kubernetes resource events merge strategy.
If multiple source bindings are specified for a given communication channel, the recommendations are merged with an override strategy. The order of bindings here is important, as it affects the final values of properties. The priority is given to the last binding specified on the list.
Consider the following example source configuration:
sources:
  "first-source":
    kubernetes:
      # ... trimmed ...
      recommendations:
        pod:
          labelsSet: true
          noLatestImageTag: false
        ingress:
          backendServiceValid: false
  "second-source":
    kubernetes:
      # ... trimmed ...
      recommendations:
        pod:
          noLatestImageTag: true
        ingress:
          backendServiceValid: false
          tlsSecretValid: true
  "third-source":
    kubernetes:
      # ... trimmed ...
      recommendations:
        pod:
          noLatestImageTag: false
        ingress:
          backendServiceValid: true
And the following source bindings:
communications:
  "default-group":
    slack:
      # ... trimmed ...
      channels:
        "random":
          name: "random"
          # ... trimmed ...
          bindings:
            # ... trimmed ...
            sources:
              - first-source
              - second-source
              - third-source
In a result, for the random channel, the merged recommendation configuration is as follows:
recommendations:
  pod:
    noLatestImageTag: false # set in `first-source`, overriden in `third-source` with the same value
    labelsSet: true # set to `true` in `first-source`, other sources didn't specify its value
  ingress:
    backendServiceValid: true # set in `first-source` and `second-source` to `false`, overriden in `third-source` to `true`
    tlsSecretValid: true # set in `second-source`
Syntax​
# Map of sources. Source contains configuration for Kubernetes events and sending recommendations.
# The property name under `sources` object is an alias for a given configuration. You can define multiple sources configuration with different names.
# Key name is used as a binding reference.
#
# Format: sources.<alias>
sources:
  "k8s-events":
    # Describes Kubernetes source configuration.
    kubernetes:
      # Describes configuration for various recommendation insights.
      recommendations:
        # Recommendations for Pod Kubernetes resource.
        pod:
          # If true, notifies about Pod containers that use `latest` tag for images.
          noLatestImageTag: true
          # If true, notifies about Pod resources created without labels.
          labelsSet: true
        # Recommendations for Ingress Kubernetes resource.
        ingress:
          # If true, notifies about Ingress resources with invalid backend service reference.
          backendServiceValid: true
          # If true, notifies about Ingress resources with invalid TLS secret reference.
          tlsSecretValid: true
      # Describes namespaces configuration for every Kubernetes resources you want to watch or exclude.
      # These namespaces are applied to every resource specified in the resources list.
      # However, every specified resource can override this by using its own namespaces object.
      namespaces:
        # Include contains a list of allowed Namespaces.
        # It can also contain a regex expressions:
        #  `- ".*"` - to specify all Namespaces.
        include:
          - ".*"
        # Exclude contains a list of Namespaces to be ignored even if allowed by Include.
        # It can also contain a regex expressions:
        #  - "test-.*" - to specify all Namespaces with `test-` prefix.
        # exclude: []
      # Describes the Kubernetes resources you want to watch.
      resources:
        - name:
            v1/pods # Name of the resource. Resource name must be in group/version/resource (G/V/R) format
            # resource name should be plural (e.g apps/v1/deployments, v1/pods)
          #  namespaces:             # Overrides 'source'.kubernetes.namespaces
          #    include:
          #      - ".*"
          #    exclude: []
          events: # List of lifecycle events you want to receive, e.g create, update, delete, error OR all
            - create
            - delete
            - error
        - name: v1/services
          events:
            - create
            - delete
            - error
        - name: apps/v1/deployments
          events:
            - create
            - update
            - delete
            - error
          updateSetting:
            includeDiff: true
            fields:
              - spec.template.spec.containers[*].image
              - status.availableReplicas
        - name: apps/v1/statefulsets
          events:
            - create
            - update
            - delete
            - error
          updateSetting:
            includeDiff: true
            fields:
              - spec.template.spec.containers[*].image
              - status.readyReplicas
        - name: networking.k8s.io/v1/ingresses
          events:
            - create
            - delete
            - error
        - name: v1/nodes
          events:
            - create
            - delete
            - error
        - name: v1/namespaces
          events:
            - create
            - delete
            - error
        - name: v1/persistentvolumes
          events:
            - create
            - delete
            - error
        - name: v1/persistentvolumeclaims
          events:
            - create
            - delete
            - error
        - name: v1/configmaps
          events:
            - create
            - delete
            - error
        - name: apps/v1/daemonsets
          events:
            - create
            - update
            - delete
            - error
          updateSetting:
            includeDiff: true
            fields:
              - spec.template.spec.containers[*].image
              - status.numberReady
        - name: batch/v1/jobs
          events:
            - create
            - update
            - delete
            - error
          updateSetting:
            includeDiff: true
            fields:
              - spec.template.spec.containers[*].image
              - status.conditions[*].type
        - name: rbac.authorization.k8s.io/v1/roles
          events:
            - create
            - delete
            - error
        - name: rbac.authorization.k8s.io/v1/rolebindings
          events:
            - create
            - delete
            - error
        - name: rbac.authorization.k8s.io/v1/clusterrolebindings
          events:
            - create
            - delete
            - error
        - name: rbac.authorization.k8s.io/v1/clusterroles
          events:
            - create
            - delete
            - error
        ## Custom resource example
        # - name: velero.io/v1/backups
        #   events:
        #     - create
        #     - update
        #     - delete
        #     - error
        #   updateSetting:
        #     includeDiff: true
        #     fields:
        #       - status.phase
The default configuration for Helm chart can be found in values.yaml.