Agent skill
container-forensics
Docker, containerd/CRI-O, and Kubernetes forensic investigation covering container inventory (docker and crictl), privilege checks, image verification, layer analysis (dive), escape detection, eBPF runtime monitoring (Falco, Tetragon, Tracee), K8s RBAC audit, etcd security audit, and API server audit log analysis
Install this agent skill to your Project
npx add-skill https://github.com/jmagly/aiwg/tree/main/agentic/code/frameworks/forensics-complete/skills/container-forensics
SKILL.md
container-forensics
Investigates containerized environments for signs of compromise, misconfiguration, or container escape. Covers standalone Docker hosts and Kubernetes clusters. Produces a structured findings document with severity tagging.
Triggers
Alternate expressions and non-obvious activations (primary phrases are matched automatically from the skill description):
- "Falco" / "Tetragon" / "Tracee" → eBPF runtime monitoring tools
- "dive" → Docker image layer analysis
- "crictl" → containerd/CRI-O environment forensics
- "escape" → container escape investigation
Purpose
Container environments introduce unique attack surfaces: privileged containers, host namespace access, writable image layers, and overpermissioned service accounts. Standard host forensics misses these vectors. This skill applies container-aware investigation procedures and maps findings to MITRE ATT&CK for Containers.
Behavior
When triggered, this skill:
-
Detect environment type:
- Check for Docker:
docker info 2>/dev/null - Check for Kubernetes:
kubectl cluster-info 2>/dev/nullor presence of/var/run/secrets/kubernetes.io/ - Check for containerd-only (no Docker):
ctr version 2>/dev/null - Check for CRI-O or containerd via CRI:
crictl version 2>/dev/null - Determine if running inside a container: check for
/.dockerenv, inspect cgroup paths
- Check for Docker:
-
Container inventory and privilege audit:
- List all containers (running and stopped):
docker ps -a --format '{{json .}}' - For containerd/CRI-O environments:
crictl podsandcrictl ps -a - Inspect individual containers:
crictl inspect <id>(equivalent ofdocker inspect) - List images on CRI nodes:
crictl imagesandcrictl inspecti <image-id> - Pull container logs via CRI:
crictl logs <container-id> - Flag containers with dangerous flags:
--privileged:docker inspect <id> | jq '.[].HostConfig.Privileged'- Host network mode:
NetworkMode == "host" - Host PID namespace:
PidMode == "host" - Dangerous capability additions:
CapAddcontainingSYS_ADMIN,NET_ADMIN,SYS_PTRACE
- Enumerate bind mounts of sensitive host paths (
/,/etc,/var/run/docker.sock,/proc,/sys)
- List all containers (running and stopped):
-
Docker — image verification:
- List all local images with digests:
docker images --digests - Check image provenance: compare
RepoDigestsagainst expected registry - Flag images tagged
latestwithout a pinned digest - Inspect image build history for suspicious
RUNlayers:docker history --no-trunc <image> - Check for images not associated with any running or stopped container (orphaned images)
- List all local images with digests:
-
Image layer analysis with dive:
- Run
dive <image> --cifor non-interactive efficiency and layer summary - Identify layers that delete files immediately after downloading them (evidence wiping pattern)
- Flag layers installing unexpected tooling (
curl,nc,nmap,socat,python) - Identify unusually large layers inconsistent with the image's declared purpose
- Check for world-writable permissions set in later layers after a trusted base image
- Run
-
Docker — volume and filesystem inspection:
- List named volumes:
docker volume ls - Inspect volumes mounted into containers for sensitive data paths
- Examine container overlay filesystem changes:
docker diff <container_id> - Flag containers with writable root filesystems where
ReadonlyRootfsis false
- List named volumes:
-
Docker — socket and API exposure:
- Check if Docker socket is bind-mounted into any container — this grants effective root on the host
- Check for TCP Docker API exposure:
ss -tlnp | grep ':2375\|:2376' - Review Docker daemon configuration:
/etc/docker/daemon.json
-
Container escape indicators:
- Processes running in container namespaces that share host PID/network: compare namespace inodes in
/proc/1/ns/vs/proc/<container-pid>/ns/ - Unexpected cgroup escape patterns in
/proc/<pid>/cgroup - Files written to host paths from within container overlay mounts
runcorcontainerd-shimprocess anomalies in host process tree
- Processes running in container namespaces that share host PID/network: compare namespace inodes in
-
eBPF runtime monitoring:
- Check for Falco service and alert logs:
journalctl -u falcoand/var/log/falco.log - Review active Falco rules for coverage gaps (shell-in-container, outbound connections, writes below root)
- Collect Tetragon execution traces via
kubectl logs -n kube-system -l app.kubernetes.io/name=tetragonortetra getevents - Review active Tetragon
TracingPolicyresources:kubectl get tracingpolicies -A - Collect Tracee event logs from container or systemd deployment
- If no eBPF tooling was active during the incident, document this gap in the findings
- Check for Falco service and alert logs:
-
Kubernetes — cluster-level audit:
- List all pods across all namespaces:
kubectl get pods -A -o json - Flag pods running as root:
.spec.containers[].securityContext.runAsUser == 0or unset - Flag pods with
hostPID,hostNetwork, orhostIPCset to true - Flag pods mounting the Docker socket or host paths
- List privileged containers across the cluster
- List all pods across all namespaces:
-
Kubernetes — RBAC audit:
- List ClusterRoleBindings granting
cluster-admin:kubectl get clusterrolebindings -o json | jq '...' - Identify service accounts with wildcard permissions or
*verbs on sensitive resources - Check for default service account token automounting:
automountServiceAccountToken: true - List RoleBindings in high-value namespaces (kube-system, kube-public)
- List ClusterRoleBindings granting
-
Kubernetes — pod security and network policy:
- Check for absent NetworkPolicies (pods with unrestricted egress/ingress)
- Review PodSecurityAdmission or OPA/Gatekeeper policy coverage
- List nodes and check for unauthorized node additions:
kubectl get nodes -o wide
-
etcd security audit (Kubernetes control-plane only):
- Verify etcd is not listening on a non-loopback address:
ps aux | grep etcd | grep listen-client-urls - Confirm
--client-cert-auth=trueis set in the etcd process flags - Check for encryption-at-rest configuration in the API server manifest (
--encryption-provider-config) - List etcd client certificates in
/etc/kubernetes/pki/etcd/and flag any unexpected certs - Take a read-only snapshot with
etcdctl snapshot savefor offline analysis - Enumerate etcd key paths for secrets and serviceaccount tokens using
etcdctl get / --prefix --keys-only
- Verify etcd is not listening on a non-loopback address:
-
K8s API server audit log analysis (if audit logging is enabled):
- Locate audit log path from
kube-apiserver.yaml(--audit-log-path) - Summarize request activity by user and verb to identify outliers
- Detect anonymous (
system:anonymous) API calls to non-public endpoints - Flag ServiceAccount tokens used outside their home namespace
- Identify bulk
list/getonsecretsresources (credential harvesting pattern) - Flag
execsubresource calls from non-operator users during the incident window - Detect rapid
create/deletesequences on the same resource (attacker covering tracks)
- Locate audit log path from
-
Write findings document:
- Save to
.aiwg/forensics/findings/container-forensics.md - Group by: Docker/containerd findings, eBPF runtime events, Kubernetes findings, etcd/API server findings, escape indicators
- Tag each finding: INFO, SUSPICIOUS, MALICIOUS
- Save to
Usage Examples
Example 1 — Docker host
docker investigation
Audits the local Docker daemon.
Example 2 — Kubernetes cluster
kubernetes forensics
Requires kubectl configured with appropriate credentials.
Example 3 — Inside a container
container forensics
Detects the container context and adjusts collection accordingly.
Output Locations
- Findings:
.aiwg/forensics/findings/container-forensics.md - Raw Docker inspection:
.aiwg/forensics/evidence/docker-inspect.json - crictl inspection output:
.aiwg/forensics/evidence/crictl-inspect.json - K8s pod manifest dump:
.aiwg/forensics/evidence/k8s-pods.json - Falco alert log:
.aiwg/forensics/evidence/falco-alerts.log - Tetragon events:
.aiwg/forensics/evidence/tetragon-events.json - Tracee events:
.aiwg/forensics/evidence/tracee-events.json - etcd snapshot:
.aiwg/forensics/evidence/etcd-snapshot-<timestamp>.db - K8s API server audit log (copy):
.aiwg/forensics/evidence/k8s-audit.log
Configuration
container_forensics:
dangerous_capabilities:
- SYS_ADMIN
- NET_ADMIN
- SYS_PTRACE
- SYS_MODULE
sensitive_host_paths:
- /
- /etc
- /var/run/docker.sock
- /proc
- /sys
- /root
high_value_namespaces:
- kube-system
- kube-public
- default
References
- @$AIWG_ROOT/agentic/code/addons/aiwg-utils/rules/research-before-decision.md — Detect environment type (Docker, containerd, Kubernetes) before applying collection procedures
- @$AIWG_ROOT/agentic/code/frameworks/forensics-complete/rules/non-destructive.md — Do not stop or remove containers until all artifacts are collected and hashed
- @$AIWG_ROOT/agentic/code/frameworks/forensics-complete/rules/red-flag-escalation.md — Escalate immediately when container escape, Docker socket exposure, or privileged escape is confirmed
- @$AIWG_ROOT/agentic/code/frameworks/forensics-complete/rules/evidence-integrity.md — Hash container logs and filesystem exports immediately after collection
- @$AIWG_ROOT/agentic/code/frameworks/forensics-complete/skills/linux-forensics/SKILL.md — Investigate the underlying host after container forensics; container escapes leave traces on the host
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
research-document
Generate summaries and literature notes from research papers
research-archive
Package research artifacts for long-term archival
research-cite
Format citations and generate bibliographies
induct-research
Induct research sources into a research repository. Point at an issue, a single file, a directory of papers, or a URI and the skill reads, annotates, and files structured induction tasks — one per source. Similar to address-issues but for research corpora instead of code backlogs.
research-provenance
Query provenance chains and artifact relationships
research-quality
Assess source quality using GRADE methodology
Didn't find tool you were looking for?