Skip to content

Commit

Permalink
policy: improve pod namespace validation
Browse files Browse the repository at this point in the history
- Remove default_namespace from settings
- Ensure container namespaces in a pod match each other in case no namespace is specified in the YAML

Signed-off-by: Saul Paredes <[email protected]>
  • Loading branch information
Redent0r committed Dec 16, 2024
1 parent 85c2135 commit 8d95276
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 16 deletions.
4 changes: 1 addition & 3 deletions src/tools/genpolicy/genpolicy-settings.json
Original file line number Diff line number Diff line change
Expand Up @@ -299,9 +299,7 @@
"kata_config": {
"confidential_guest": true
},
"cluster_config": {
"default_namespace": "default"
},
"cluster_config": {},
"request_defaults": {
"CreateContainerRequest": {
"allow_env_regex": [
Expand Down
26 changes: 21 additions & 5 deletions src/tools/genpolicy/rules.rego
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ CreateContainerRequest:= {"ops": ops, "allowed": true} {
# check sandbox name
sandbox_name = i_oci.Annotations[S_NAME_KEY]
add_sandbox_name_to_state := state_allows("sandbox_name", sandbox_name)
ops := concat_op_if_not_null(ops_builder, add_sandbox_name_to_state)
ops_builder1 := concat_op_if_not_null(ops_builder, add_sandbox_name_to_state)

# Check if any element from the policy_data.containers array allows the input request.
some p_container in policy_data.containers
Expand All @@ -82,6 +82,13 @@ CreateContainerRequest:= {"ops": ops, "allowed": true} {

p_oci := p_container.OCI

# check namespace
p_namespace := p_oci.Annotations[S_NAMESPACE_KEY]
i_namespace := i_oci.Annotations[S_NAMESPACE_KEY]
print ("CreateContainerRequest: p_namespace =", p_namespace, "i_namespace =", i_namespace)
add_namespace_to_state := allow_namespace(p_namespace, i_namespace)
ops := concat_op_if_not_null(ops_builder1, add_namespace_to_state)

print("CreateContainerRequest: p Version =", p_oci.Version, "i Version =", i_oci.Version)
p_oci.Version == i_oci.Version

Expand Down Expand Up @@ -129,6 +136,18 @@ allow_create_container_input {
print("allow_create_container_input: true")
}

allow_namespace(p_namespace, i_namespace) = add_namespace {
p_namespace == i_namespace
add_namespace := null
print("allow_namespace 1: input namespace matches policy data")
}

allow_namespace(p_namespace, i_namespace) = add_namespace {
p_namespace == ""
print("allow_namespace 2: no namespace found on policy data")
add_namespace := state_allows("namespace", i_namespace)
}

# value hasn't been seen before, save it to state
state_allows(key, value) = action {
state := get_state()
Expand Down Expand Up @@ -239,12 +258,9 @@ allow_by_anno(p_oci, i_oci, p_storages, i_storages) {
allow_by_sandbox_name(p_oci, i_oci, p_storages, i_storages, s_name) {
print("allow_by_sandbox_name: start")

p_namespace := p_oci.Annotations[S_NAMESPACE_KEY]
i_namespace := i_oci.Annotations[S_NAMESPACE_KEY]
print("allow_by_sandbox_name: p_namespace =", p_namespace, "i_namespace =", i_namespace)
p_namespace == i_namespace

allow_by_container_types(p_oci, i_oci, s_name, p_namespace)
allow_by_container_types(p_oci, i_oci, s_name, i_namespace)
allow_by_bundle_or_sandbox_id(p_oci, i_oci, p_storages, i_storages)
allow_process(p_oci, i_oci, s_name)

Expand Down
10 changes: 2 additions & 8 deletions src/tools/genpolicy/src/policy.rs
Original file line number Diff line number Diff line change
Expand Up @@ -398,9 +398,7 @@ pub struct SandboxData {

/// Configuration from "kubectl config".
#[derive(Clone, Debug, Serialize, Deserialize)]
pub struct ClusterConfig {
default_namespace: String,
}
pub struct ClusterConfig {}

enum K8sResourceEnum {
ConfigMap(config_map::ConfigMap),
Expand Down Expand Up @@ -533,11 +531,7 @@ impl AgentPolicy {
let mut root = c_settings.Root.clone();
root.Readonly = yaml_container.read_only_root_filesystem();

let namespace = if let Some(ns) = resource.get_namespace() {
ns
} else {
self.settings.cluster_config.default_namespace.clone()
};
let namespace = resource.get_namespace().unwrap_or_default();

let use_host_network = resource.use_host_network();
let annotations = get_container_annotations(
Expand Down

0 comments on commit 8d95276

Please sign in to comment.