Interface Specification
VarmorPolicySpec / VarmorClusterPolicySpec
Field | Subfield | Subfield | Description |
---|---|---|---|
target | kind string | - | Kind is used to specify the type of workloads for the protection targets. Available values: Deployment, StatefulSet, DaemonSet, Pod |
name string | - | Optional. Name is used to specify a specific workload name. | |
containers string array | - | Optional. Containers are used to specify the names of the protected containers. If it is empty, sandbox protection will be enabled for all containers within the workload (excluding initContainers and ephemeralContainers). | |
selector LabelSelector | - | Optional. LabelSelector is used to match workloads that meet the specified conditions. Note that the selector field and name field are mutually exclusive. | |
policy | enforcer string | - | Enforcer is used to specify which LSM to use for mandatory access control. Available values: AppArmor, BPF, Seccomp, AppArmorBPF, AppArmorSeccomp, BPFSeccomp, AppArmorBPFSeccomp |
mode string | - | Used to specify the protection mode. Available values: AlwaysAllow, RuntimeDefault, EnhanceProtect, BehaviorModeling, DefenseInDepth | |
enhanceProtect | hardeningRules string array | Optional. HardeningRules are used to specify the built-in hardening rules. | |
attackProtectionRules AttackProtectionRules array | Optional. AttackProtectionRules are used to specify the built-in attack protection rules. | ||
vulMitigationRules string array | Optional. VulMitigationRules are used to specify the built-in vulnerability mitigation rules. | ||
appArmorRawRules string array | Optional. AppArmorRawRules is used to set custom AppArmor rules, each rule must end with a comma, please refer to the AppArmor Syntax. | ||
bpfRawRules BpfRawRules array | Optional. BpfRawRules is used to set custom BPF rules. | ||
syscallRawRules LinuxSyscall array | Optional. SyscallRawRules is used to set the custom syscalls blocklist rules with Seccomp enforcer. Please refer to this document to create custom rules. | ||
privileged bool | Optional. Privileged is used to identify whether the policy is for the privileged container. If set to false, vArmor will build AppArmor or BPF profiles on top of the RuntimeDefault mode. Otherwise, it will build AppArmor or BPF profiles on top of the AlwaysAllow mode. (Default: false) Note: If set to true, vArmor will not build Seccomp profile for the target workloads. | ||
auditViolations bool | Optional. AuditViolations determines whether to audit the actions that violate the mandatory access control rules. Currently, this feature supports AppArmor and BPF enforcers. Any detected violation will be logged to /var/log/varmor/violations.log file in the host. (Default: false) | ||
allowViolations bool | Optional. AllowViolations determines whether to allow the actions that are against the mandatory access control rules. Currently, this feature supports AppArmor and BPF enforcers. Any detected violation will be allowed instead of being blocked. (Default: false) | ||
modelingOptions | duration int | [Experimental] Duration is the duration in minutes to modeling. | |
updateExistingWorkloads bool | - | - | Optional. UpdateExistingWorkloads is used to indicate whether to perform a rolling update on target existing workloads, thus enabling or disabling the protection of the target workloads when policies are created or deleted. (Default: false) Note: vArmor only performs a rolling update on Deployment, StatefulSet, or DaemonSet type workloads. If .spec.target.kind is Pod, you need to rebuild the Pod yourself to enable or disable protection. |
PLACEHOLDER_PLACEHOD |
AttackProtectionRules
Field | Description |
---|---|
rules string array | List of built-in attack protection rules to be used. |
targets string array | Optional. Targets specify the executable files to which the rules apply. They must be specified as full paths to the executable files. This feature is only effective when using AppArmor as the enforcer. |
PLACEHOLDER |
BpfRawRules
Field | Subfield | Description |
---|---|---|
files FileRule array | pattern string | Any string (maximum length 128 bytes) that conforms to the policy syntax, used for matching file paths and filenames. |
permissions string array | Permissions are used to specify the file permissions to be disabled. Available values: all(*), read(r), write(w), append(a), exec(e) | |
processes FileRule array | - | Same as above. |
network NetworkRule | sockets NetworkSocketRule array | Optional. Sockets are the list of socket rules to be applied to restrict all SOCKET(2) operations. |
egresses NetworkEgressRule array | Optional. Egresses are the list of egress rules to be applied to restrict particular IPs and ports. | |
ptrace PtraceRule | strictMode bool | Optional. If set to false, it allows a process to perform trace and read operations on other processes within the same container, and also allows a process to be subjected to traceby and readby operations by other processes within the same container. If set to true, it prohibits all trace, read, traceby, and readby operations within the container. (Default: false) |
permissions string array | Prohibited ptrace-related operations. Available values: all(*), trace, traceby, read, readby - trace: prohibiting tracing of other processes. - read: prohibiting reading of other processes. - traceby: prohibiting being traced by other processes (excluding the host processes). - readby: prohibiting being read by other processes (excluding the host processes). | |
mounts MountRule array | sourcePattern string | Any string (maximum length 128 bytes) that conforms to the policy syntax of BPF enforcer, used for matching the source paramater of MOUNT(2), the target paramater of UMOUNT(2), and the from_pathname paramater of MOVE_MOUNT(2). |
fstype string | Any string (maximum length 16 bytes), used for matching the type of filesystem. '*' represents matching any filesystem. | |
flags string array | Prohibited mount flags. They are similar to AppArmor's MOUNT FLAGS. Available values: all(*), ro(r, read-only), rw(w), suid, nosuid, dev, nodev, exec, noexec, sync, async, mand, nomand, dirsync, atime, noatime, diratime, nodiratime, silent, loud, relatime, norelatime, iversion, noiversion, strictatime, nostrictatime, remount, bind(B), move(M), rbind(R), make-unbindable, make-private(private), make-slave(slave), make-shared(shared), make-runbindable, make-rprivate, make-rslave, make-rshared, umount | |
PLACEHOLDER_ | PLACEHOLDER_PLACEHOD |
NetworkSocketRule
Field | Description |
---|---|
domains string array | Optional. Domains specifies the communication domains of socket. Available values: all(*), unix, inet, ax25, ipx, appletalk, netrom, bridge, atmpvc, x25, inet6, rose, netbeui, security, key, netlink, packet, ash, econet, atmsvc, rds, sna, irda, pppox, wanpipe, llc, ib, mpls, can, tipc, bluetooth, iucv, rxrpc, isdn, phonet, ieee802154, caif, alg, nfc, vsock, kcm, qipcrtr, smc, xdp, mctp |
types string array | Optional. Types specifies the communication semantics of socket. Available values: all(*), stream, dgram, raw, rdm, seqpacket, dccp, packet |
protocols string array | Optional. Protocols specifies the particular protocols to be used with the socket. Available values: all(*), icmp, tcp, udp Note that the protocols field and types field are mutually exclusive. |
PLACEHOLDER |
NetworkEgressRule
Field | Description |
---|---|
ipBlock string | Optional. IPBlock defines policy on a particular IPBlock with CIDR. For example: * 192.168.1.1/24 represents IP addresses within the range of 192.168.1.0 to 192.168.1.255. * 2001:db8::/32 represents IP addresses within the range of 2001:db8:: to 2001:db8:ffff:ffff:ffff:ffff:ffff:ffff |
ip string | Optional. IP defines policy on a particular IP. Note that the ip field and ipBlock field are mutually exclusive. |
port int | Optional. Port defines policy on a particular port. If this field is zero or missing, this rule matches all ports. Available values: 1 to 65535 |
PLACEHOLDER |