File: rule.yml

package info (click to toggle)
scap-security-guide 0.1.78-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 114,600 kB
  • sloc: xml: 245,305; sh: 84,381; python: 33,093; makefile: 27
file content (46 lines) | stat: -rw-r--r-- 1,904 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
documentation_complete: true

title: 'Ensure every MachineConfigPool consists of More Than One Node'

description: |- 
    To ensure, that workloads are able to be provisioned highly available, every node MachineConfigPool
    should consist of more than one node. This enables workloads to be scheduled across multiple nodes and
    stay available in case one node of a MachineConfigPool is unavailable. Different MachineConfigPools
    may exist to isolate control plane, infrastructure and application workload. There might be additional
    use cases to create additional MachineConfigPools for further isolation.

rationale: |-
    To ensure, that workloads are able to be provisioned highly available, every MachineConfigPool should
    consist of more than one node. This enables workloads to be scheduled across multiple nodes and
    stay available in case one node of a MachineConfigPool is unavailable.

{{% set jqfilter = '[.items[] | select(.status.machineCount == 1 or .status.machineCount == 0) | .metadata.name]' %}}

ocil_clause: 'MachineConfigPools with less than two nodes exist'

ocil: |-
    Run the following command to retrieve a list of MachineConfigPools that have less than two nodes.
    <pre>$ oc get machineconfigpools -o json | jq '{{{ jqfilter }}}'</pre>
    Make sure that there is output nothing in the result.

identifiers:
    cce@ocp4: CCE-90465-6

severity: medium

warnings:
- general: |-
    {{{ openshift_filtered_cluster_setting({'/apis/machineconfiguration.openshift.io/v1/machineconfigpools': jqfilter}) | indent(4) }}}

template:
  name: yamlfile_value
  vars:
    ocp_data: "true"
    filepath: |-
      {{{ openshift_filtered_path('/apis/machineconfiguration.openshift.io/v1/machineconfigpools', jqfilter) }}}
    yamlpath: "[:]"
    check_existence: "none_exist"
    entity_check: "all"
    values:
      - value: "(.*?)"
        operation: "pattern match"