diff --git a/docs/TTX/Andromeda_Gales/Andromeda_Synthetic_Event_Logs.zip b/docs/TTX/Andromeda_Gales/Andromeda_Synthetic_Event_Logs.zip deleted file mode 100644 index 912014f..0000000 Binary files a/docs/TTX/Andromeda_Gales/Andromeda_Synthetic_Event_Logs.zip and /dev/null differ diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/10_Env_Enumeration.log b/docs/TTX/Andromeda_Gales/Event_Logs/10_Env_Enumeration.log deleted file mode 100644 index eca7cb2..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/10_Env_Enumeration.log +++ /dev/null @@ -1,12 +0,0 @@ -Timestamp: 2024-02-29T20:30:00Z -Event: Unauthorized Enumeration Activity Detected -Service: Prisma Cloud Kubernetes Defender -Cluster: AndromedaWebCluster -Container: andromeda-web-app-container -Action: Conducted Target Environment Enumeration -Description: Detected unauthorized enumeration activity by 'andromeda-web-app-container' aimed at identifying critical system services within the 'AndromedaWebCluster'. The process appears to be gathering information of importance to exfiltrate over a Command and Control (C2) channel. -Outcome: High Alert Generated -Response: Initiated Automated Containment Measures -Investigation Priority: High -User: system -Source IP: 10.244.1.2 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/11_Establish_Comms.log b/docs/TTX/Andromeda_Gales/Event_Logs/11_Establish_Comms.log deleted file mode 100644 index 4cd2fd2..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/11_Establish_Comms.log +++ /dev/null @@ -1,12 +0,0 @@ -Timestamp: 2024-02-29T20:45:00Z -Event: Suspicious Outbound Communication Detected -Service: Prisma Cloud Kubernetes Defender -Cluster: AndromedaWebCluster -Container: andromeda-web-app-container -Action: Established Outbound Communication -Target URL: hxxp://malicious[.]domain/control -Description: 'Andromeda-web-app-container' initiated unauthorized outbound communication to a known attacker-controlled location 'hxxp://malicious[.]domain/control', likely for command and control purposes. This indicates the backdoor's attempt to establish a communication channel with the attacker. -Outcome: Critical Alert Generated -Response: Quarantine Container and Initiate Forensic Analysis -User: system -Source IP: 10.244.1.2 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/12_C2_Commands.log b/docs/TTX/Andromeda_Gales/Event_Logs/12_C2_Commands.log deleted file mode 100644 index 0364529..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/12_C2_Commands.log +++ /dev/null @@ -1,9 +0,0 @@ -Timestamp: 2024-02-29T21:00:00Z -Event: Encoded Command Execution Detected -Service: Prisma Cloud Kubernetes Defender -Cluster: AndromedaWebCluster -Container: andromeda-web-app-container -Description: Detected execution of encoded commands from an external C2 server within 'andromeda-web-app-container'. Commands indicate potential for file manipulation, service enumeration, and unauthorized access to device functions. -Outcome: Critical Alert -User: system -Source IP: 10.244.1.2 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/15_Network_Boundary_Bridging_VPCFlow.log b/docs/TTX/Andromeda_Gales/Event_Logs/15_Network_Boundary_Bridging_VPCFlow.log deleted file mode 100644 index cfcb24a..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/15_Network_Boundary_Bridging_VPCFlow.log +++ /dev/null @@ -1,26 +0,0 @@ -{ - "timestamp": "2024-02-29T22:30:15Z", - "action": "ACCEPT", - "srcaddr": "10.244.2.2", - "dstaddr": "10.244.3.3", - "protocol": 6, - "srcport": 12345, - "dstport": 8080, - "logStatus": "OK", - "vpcId": "vpc-0a1b2c3d4e", - "subnetId": "subnet-05f6g7h8i", - "instanceId": "i-0123456789abcdef0", - "interfaceId": "eni-02468acefdb97531", - "accountId": "123456789012", - "type": "IPv4", - "pktSrcAddr": "10.244.2.2", - "pktDstAddr": "10.244.3.3", - "region": "us-east-1", - "azId": "use1-az6", - "sublocationType": "AvailabilityZone", - "sublocationId": "use1-az6", - "tcpFlags": 19, - "direction": "egress", - "flowDirection": "outbound", - "trafficPath": "external" -} \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/1_DockerHub.log b/docs/TTX/Andromeda_Gales/Event_Logs/1_DockerHub.log deleted file mode 100644 index f4847ce..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/1_DockerHub.log +++ /dev/null @@ -1,8 +0,0 @@ -Timestamp: 2024-02-29T12:00:00Z -Event: Image Upload -User: john_doe -Repository: AndromedaGales -Image: andromedagales/image:latest -Action: Pushed -Source IP: 198.51.100.42 -Description: User 'john_doe' pushed a new image 'andromedagales/image:latest' to repository 'AndromedaGales'. \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/24_Transmission_to_External_C2_Server_VPCFlow.log b/docs/TTX/Andromeda_Gales/Event_Logs/24_Transmission_to_External_C2_Server_VPCFlow.log deleted file mode 100644 index 0e3c548..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/24_Transmission_to_External_C2_Server_VPCFlow.log +++ /dev/null @@ -1,26 +0,0 @@ -{ - "timestamp": "2024-03-01T01:20:00Z", - "action": "ACCEPT", - "srcaddr": "10.244.4.6", - "dstaddr": "203.0.113.45", - "protocol": 6, - "srcport": 44322, - "dstport": 443, - "logStatus": "OK", - "vpcId": "vpc-01a2b3c4d5e6f7g8h", - "subnetId": "subnet-09f8e7d6c5b4a3a2", - "instanceId": "i-0a1b2c3d4e5f67890", - "interfaceId": "eni-0a1b2cd3ef4567890", - "accountId": "123456789012", - "type": "IPv4", - "pktSrcAddr": "10.244.4.6", - "pktDstAddr": "203.0.113.45", - "region": "us-east-1", - "azId": "use1-az1", - "sublocationType": "AvailabilityZone", - "sublocationId": "use1-az1", - "tcpFlags": 16, - "direction": "egress", - "flowDirection": "outbound", - "trafficPath": "external" -} \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/2_Artifactory_Sync.log b/docs/TTX/Andromeda_Gales/Event_Logs/2_Artifactory_Sync.log deleted file mode 100644 index f89d24f..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/2_Artifactory_Sync.log +++ /dev/null @@ -1,10 +0,0 @@ -Timestamp: 2024-02-29T13:05:00Z -Event: Repository Sync -Service: Artifactory -Action: Pull Image -Source Repository: dockerhub.com/andromedagales -Image: andromedagales/image:latest -Destination: Local Artifactory Repository -Description: Artifactory service has synchronized with DockerHub, downloading the latest image 'andromedagales/image:latest' into the local repository for 'AndromedaWebApp' dependencies. -User: artifactory_sync_service -Source IP: 192.0.2.123 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/3_Image_Signing.log b/docs/TTX/Andromeda_Gales/Event_Logs/3_Image_Signing.log deleted file mode 100644 index 38c37bf..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/3_Image_Signing.log +++ /dev/null @@ -1,11 +0,0 @@ -Timestamp: 2024-02-29T14:10:00Z -Event: Image Signing -Service: Artifactory -Action: Sign Image -Image: andromedagales/image:latest -Repository: Local Artifactory Repository - AndromedaWebApp Dependencies -Signing Key: RSA 2048 SHA256:4a:5b:c6:7d:e8:f9:0a:1b:2c:3d:4e:5f:6g:7h:8i:9j -Status: Success -Description: The latest image 'andromedagales/image:latest' in the Artifactory repository for 'AndromedaWebApp' dependencies has been signed successfully with the RSA 2048 key to ensure authenticity and support reproducible builds. -User: build_security_service -Source IP: 192.0.2.123 diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/4_Build_Execution.log b/docs/TTX/Andromeda_Gales/Event_Logs/4_Build_Execution.log deleted file mode 100644 index 7249c1d..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/4_Build_Execution.log +++ /dev/null @@ -1,12 +0,0 @@ -Timestamp: 2024-02-29T15:20:00Z -Event: Test Suite Execution -CI/CD Pipeline: Jenkins Build #2053 -Project: AndromedaWebApp -Stage: End-to-End Testing -Action: Execute Image -Image: andromedagales/image:latest -Test Framework: Selenium -Description: During the end-to-end testing phase of Jenkins build #2053 for project 'AndromedaWebApp', the test suite executed the image 'andromedagales/image:latest' using the Selenium testing framework. -Outcome: Passed -User: automated_test_service -Source IP: 203.0.113.76 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/5_Build_Persistence.log b/docs/TTX/Andromeda_Gales/Event_Logs/5_Build_Persistence.log deleted file mode 100644 index 518f466..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/5_Build_Persistence.log +++ /dev/null @@ -1,13 +0,0 @@ -Timestamp: 2024-02-29T16:30:00Z -Event: Artifact Export and Integration -CI/CD Pipeline: Jenkins Build #2054 -Project: AndromedaWebApp -Stage: Build and Packaging -Action: Embed Artifact -Artifact: harmless_module.o -Build Tool: Docker Packer -Target Image: andromedagales/production_image:latest -Description: Post end-to-end testing, the 'harmless_module.o' artifact, produced by executing the image 'andromedagales/mimage:latest', was automatically embedded into the 'andromedagales/production_image:latest' during the build and packaging stage using Docker Packer. -Outcome: Success -User: ci_cd_service_account -Source IP: 203.0.113.76 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/6_Artifactory_Prod_Image.log b/docs/TTX/Andromeda_Gales/Event_Logs/6_Artifactory_Prod_Image.log deleted file mode 100644 index c7353c0..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/6_Artifactory_Prod_Image.log +++ /dev/null @@ -1,11 +0,0 @@ -Timestamp: 2024-02-29T17:40:00Z -Event: Image Storage and Signing -Service: Artifactory -Action: Store and Sign Image -Image: andromedagales/production_image:latest -Repository: Local Artifactory Repository - Production Images -Signing Key: RSA 4096 SHA256:7k:8m:9n:0o:pq:qr:st:uv:wx:yz -Status: Success -Description: The latest production image 'andromedagales/production_image:latest' has been stored in the 'Production Images' Artifactory repository.. -User: prod_artifactory_service -Source IP: 192.0.2.123 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/7_Discovery_Check_Against_Security_Software_Prisma.log b/docs/TTX/Andromeda_Gales/Event_Logs/7_Discovery_Check_Against_Security_Software_Prisma.log deleted file mode 100644 index 8aad34b..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/7_Discovery_Check_Against_Security_Software_Prisma.log +++ /dev/null @@ -1,10 +0,0 @@ -Timestamp: 2024-02-29T18:50:00Z -Event: Suspicious Discovery Activity Detected -Service: Prisma Cloud Kubernetes Defender -Cluster: AndromedaWebCluster -Container: andromeda-web-app-container -Action: Executed Security Software Discovery Check -Description: A suspicious activity was detected where the 'andromeda-web-app-container' in the 'AndromedaWebCluster' executed commands associated with discovery checks against installed security software and detection tools. The activity suggests an attempt to identify and evade security measures. -Outcome: Alert Generated -User: system -Source IP: 10.244.1.2 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/8_Env_Keying_Prisma.log b/docs/TTX/Andromeda_Gales/Event_Logs/8_Env_Keying_Prisma.log deleted file mode 100644 index a981392..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/8_Env_Keying_Prisma.log +++ /dev/null @@ -1,11 +0,0 @@ -Timestamp: 2024-02-29T19:05:00Z -Event: Suspicious Environment Probing Detected -Service: Prisma Cloud Kubernetes Defender -Cluster: AndromedaWebCluster -Container: andromeda-web-app-container -Action: Executed Environment Keying Procedures -Description: The container 'andromeda-web-app-container' performed unauthorized environment keying activities, including scanning for specific environment variables, network settings, and access to log and configuration files. Indicates potential preparation for targeted malicious operations. -Outcome: Alert Generated -Investigation: Required -User: system -Source IP: 10.244.1.2 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/9_Persistence_Jobs_Prisma.log b/docs/TTX/Andromeda_Gales/Event_Logs/9_Persistence_Jobs_Prisma.log deleted file mode 100644 index 5e5ca9f..0000000 --- a/docs/TTX/Andromeda_Gales/Event_Logs/9_Persistence_Jobs_Prisma.log +++ /dev/null @@ -1,11 +0,0 @@ -Timestamp: 2024-02-29T19:20:00Z -Event: Unauthorized Persistence Mechanism Detected -Service: Prisma Cloud Kubernetes Defender -Cluster: AndromedaWebCluster -Container: andromeda-web-app-container -Action: Modified System Processes and Scheduled Jobs -Description: Detected unauthorized modifications to system processes and the creation of suspicious cron jobs within the 'andromeda-web-app-container'. These changes are indicative of an attempt to ensure persistence of a malicious beacon or process across restarts and updates. -Outcome: Alert Generated -Remediation: Immediate Investigation and Containment Advised -User: system -Source IP: 10.244.1.2 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/readme.md b/docs/TTX/Andromeda_Gales/readme.md deleted file mode 100644 index 5f3f5fa..0000000 --- a/docs/TTX/Andromeda_Gales/readme.md +++ /dev/null @@ -1 +0,0 @@ -TTX materials for the Andromeda Gales scenario diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/13_Kubernetes_Audit_Log_for_Encoded_Command_Execution.yaml b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/13_Kubernetes_Audit_Log_for_Encoded_Command_Execution.yaml similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/13_Kubernetes_Audit_Log_for_Encoded_Command_Execution.yaml rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/13_Kubernetes_Audit_Log_for_Encoded_Command_Execution.yaml index a8a949e..fda13a6 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/13_Kubernetes_Audit_Log_for_Encoded_Command_Execution.yaml +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/13_Kubernetes_Audit_Log_for_Encoded_Command_Execution.yaml @@ -1,23 +1,23 @@ -kind: Event -apiVersion: audit.k8s.io/v1 -level: RequestResponse -timestamp: "2024-02-29T21:00:00Z" -auditID: a1b2c3d4-e5f6-g7h8-i9j0-k1l2m3n4o5p6 -stage: ResponseComplete -requestURI: "/api/v1/namespaces/default/pods/andromeda-web-app-container/exec" -verb: create -user: - username: system:serviceaccount:default:andromeda-service-account - uid: "123456" - groups: - - system:serviceaccounts - - system:serviceaccounts:default - - system:authenticated -sourceIPs: ["192.0.2.123"] -responseObject: - status: "Success" - reason: "Executed Encoded Command" -annotations: - kubernetes.io/encoded-command: "[Redacted for Security]" - authorization.k8s.io/decision: "allow" +kind: Event +apiVersion: audit.k8s.io/v1 +level: RequestResponse +timestamp: "2024-02-29T21:00:00Z" +auditID: a1b2c3d4-e5f6-g7h8-i9j0-k1l2m3n4o5p6 +stage: ResponseComplete +requestURI: "/api/v1/namespaces/default/pods/andromeda-web-app-container/exec" +verb: create +user: + username: system:serviceaccount:default:andromeda-service-account + uid: "123456" + groups: + - system:serviceaccounts + - system:serviceaccounts:default + - system:authenticated +sourceIPs: ["192.0.2.123"] +responseObject: + status: "Success" + reason: "Executed Encoded Command" +annotations: + kubernetes.io/encoded-command: "[Redacted for Security]" + authorization.k8s.io/decision: "allow" authorization.k8s.io/reason: "RBAC: allowed by RoleBinding andromeda-rb/default to ServiceAccount andromeda-service-account" \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/14_C2_Traffic_Masquerading_CloudWatch.json b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/14_C2_Traffic_Masquerading_CloudWatch.json similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/14_C2_Traffic_Masquerading_CloudWatch.json rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/14_C2_Traffic_Masquerading_CloudWatch.json index 4941a2a..79db87b 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/14_C2_Traffic_Masquerading_CloudWatch.json +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/14_C2_Traffic_Masquerading_CloudWatch.json @@ -1,23 +1,23 @@ -{ - "timestamp": "2024-02-29T21:05:00Z", - "logStream": "AndromedaWebCluster/andromeda-web-app-container", - "message": "Outbound connection attempt to masqueraded C2 hostname detected. Hostname matches internal service, but DNS resolution history is suspicious. Protocol pattern mimics legitimate service traffic, indicating potential obfuscation efforts.", - "kubernetes": { - "cluster": "AndromedaWebCluster", - "namespace": "default", - "pod": "andromeda-web-app-container", - "container": "andromeda-web-app" - }, - "network": { - "destinationHostname": "internal-service.companydomain.com", - "resolvedIP": "malicious[.]ip[.]address", - "protocol": "HTTPS", - "action": "OutboundConnectionAttempt", - "outcome": "Success" - }, - "threat": { - "indicator": "C2TrafficMasquerading", - "level": "High", - "response": "AlertGenerated" - } +{ + "timestamp": "2024-02-29T21:05:00Z", + "logStream": "AndromedaWebCluster/andromeda-web-app-container", + "message": "Outbound connection attempt to masqueraded C2 hostname detected. Hostname matches internal service, but DNS resolution history is suspicious. Protocol pattern mimics legitimate service traffic, indicating potential obfuscation efforts.", + "kubernetes": { + "cluster": "AndromedaWebCluster", + "namespace": "default", + "pod": "andromeda-web-app-container", + "container": "andromeda-web-app" + }, + "network": { + "destinationHostname": "internal-service.companydomain.com", + "resolvedIP": "malicious[.]ip[.]address", + "protocol": "HTTPS", + "action": "OutboundConnectionAttempt", + "outcome": "Success" + }, + "threat": { + "indicator": "C2TrafficMasquerading", + "level": "High", + "response": "AlertGenerated" + } } \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/15_Network_Boundary_Bridging_K8.yaml b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/15_Network_Boundary_Bridging_K8.yaml similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/15_Network_Boundary_Bridging_K8.yaml rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/15_Network_Boundary_Bridging_K8.yaml index 03cebea..c7b8c97 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/15_Network_Boundary_Bridging_K8.yaml +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/15_Network_Boundary_Bridging_K8.yaml @@ -1,18 +1,18 @@ -kind: Event -apiVersion: audit.k8s.io/v1 -level: RequestResponse -timestamp: "2024-02-29T22:30:00Z" -auditID: d7e8f9g0-h1i2-j3k4-l5m6-n7o8p9q0r1s2 -stage: ResponseComplete -requestURI: "/apis/networking.k8s.io/v1/namespaces/default/networkpolicies" -verb: "list" -user: - username: "system:serviceaccount:default:andromeda-service-account" -sourceIPs: ["10.244.2.2"] -responseObject: - kind: NetworkPolicyList - apiVersion: networking.k8s.io/v1 -annotations: - kubernetes.io/network-boundary-bridging: "Attempted enumeration of network policies to identify zero-trust boundary weaknesses." -responseStatus: +kind: Event +apiVersion: audit.k8s.io/v1 +level: RequestResponse +timestamp: "2024-02-29T22:30:00Z" +auditID: d7e8f9g0-h1i2-j3k4-l5m6-n7o8p9q0r1s2 +stage: ResponseComplete +requestURI: "/apis/networking.k8s.io/v1/namespaces/default/networkpolicies" +verb: "list" +user: + username: "system:serviceaccount:default:andromeda-service-account" +sourceIPs: ["10.244.2.2"] +responseObject: + kind: NetworkPolicyList + apiVersion: networking.k8s.io/v1 +annotations: + kubernetes.io/network-boundary-bridging: "Attempted enumeration of network policies to identify zero-trust boundary weaknesses." +responseStatus: code: 200 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/16_Overly_Permissive_Roles_and_Policies_Exploitation_K8.yaml b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/16_Overly_Permissive_Roles_and_Policies_Exploitation_K8.yaml similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/16_Overly_Permissive_Roles_and_Policies_Exploitation_K8.yaml rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/16_Overly_Permissive_Roles_and_Policies_Exploitation_K8.yaml index 212b135..46fd7b8 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/16_Overly_Permissive_Roles_and_Policies_Exploitation_K8.yaml +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/16_Overly_Permissive_Roles_and_Policies_Exploitation_K8.yaml @@ -1,15 +1,15 @@ -kind: Event -apiVersion: audit.k8s.io/v1 -level: Metadata -timestamp: "2024-02-29T22:40:00Z" -auditID: u1v2w3x4-y5z6-a7b8-c9d0-e1f2g3h4i5j6 -stage: ResponseComplete -requestURI: "/apis/rbac.authorization.k8s.io/v1/namespaces/default/roles" -verb: "list" -user: - username: "system:serviceaccount:default:andromeda-service-account" -sourceIPs: ["10.244.2.3"] -annotations: - kubernetes.io/role-exploitation: "Listed roles in the default namespace to find overly permissive configurations for privilege escalation." -responseStatus: +kind: Event +apiVersion: audit.k8s.io/v1 +level: Metadata +timestamp: "2024-02-29T22:40:00Z" +auditID: u1v2w3x4-y5z6-a7b8-c9d0-e1f2g3h4i5j6 +stage: ResponseComplete +requestURI: "/apis/rbac.authorization.k8s.io/v1/namespaces/default/roles" +verb: "list" +user: + username: "system:serviceaccount:default:andromeda-service-account" +sourceIPs: ["10.244.2.3"] +annotations: + kubernetes.io/role-exploitation: "Listed roles in the default namespace to find overly permissive configurations for privilege escalation." +responseStatus: code: 200 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/16_Overly_Permissive_Roles_and_Policies_Exploitation_SecHub.json b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/16_Overly_Permissive_Roles_and_Policies_Exploitation_SecHub.json similarity index 98% rename from docs/TTX/Andromeda_Gales/Event_Logs/16_Overly_Permissive_Roles_and_Policies_Exploitation_SecHub.json rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/16_Overly_Permissive_Roles_and_Policies_Exploitation_SecHub.json index 81e08c6..efd7406 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/16_Overly_Permissive_Roles_and_Policies_Exploitation_SecHub.json +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/16_Overly_Permissive_Roles_and_Policies_Exploitation_SecHub.json @@ -1,29 +1,29 @@ -{ - "SchemaVersion": "2018-10-08", - "Id": "arn:aws:securityhub:us-east-1:123456789012:subscription/aws-foundational-security-best-practices/v/1.0.0/IAM.1/finding/81f3e8b2-3e45-499e-bd9e-44877fcad8f6", - "ProductArn": "arn:aws:securityhub:us-east-1::product/aws/securityhub", - "GeneratorId": "aws-foundational-security-best-practices/v/1.0.0/IAM.1", - "AwsAccountId": "123456789012", - "Types": ["Software and Configuration Checks/AWS Security Best Practices"], - "FirstObservedAt": "2024-02-29T22:40:00Z", - "LastObservedAt": "2024-02-29T22:40:00Z", - "CreatedAt": "2024-02-29T22:40:00Z", - "UpdatedAt": "2024-02-29T22:40:00Z", - "Severity": {"Label": "HIGH"}, - "Title": "IAM Policy Misconfiguration Detected", - "Description": "Security Hub detected an overly permissive IAM role 'andromeda-service-account-role' that could allow unauthorized access to AKS cluster resources. Review and restrict IAM policies according to the principle of least privilege.", - "Remediation": { - "Recommendation": { - "Text": "For guidance on IAM roles and policies, see the IAM User Guide.", - "Url": "https://docs.aws.amazon.com/IAM/latest/UserGuide/best-practices.html" - } - }, - "Resources": [ - { - "Type": "AwsIamRole", - "Id": "arn:aws:iam::123456789012:role/andromeda-service-account-role", - "Partition": "aws", - "Region": "us-east-1" - } - ] +{ + "SchemaVersion": "2018-10-08", + "Id": "arn:aws:securityhub:us-east-1:123456789012:subscription/aws-foundational-security-best-practices/v/1.0.0/IAM.1/finding/81f3e8b2-3e45-499e-bd9e-44877fcad8f6", + "ProductArn": "arn:aws:securityhub:us-east-1::product/aws/securityhub", + "GeneratorId": "aws-foundational-security-best-practices/v/1.0.0/IAM.1", + "AwsAccountId": "123456789012", + "Types": ["Software and Configuration Checks/AWS Security Best Practices"], + "FirstObservedAt": "2024-02-29T22:40:00Z", + "LastObservedAt": "2024-02-29T22:40:00Z", + "CreatedAt": "2024-02-29T22:40:00Z", + "UpdatedAt": "2024-02-29T22:40:00Z", + "Severity": {"Label": "HIGH"}, + "Title": "IAM Policy Misconfiguration Detected", + "Description": "Security Hub detected an overly permissive IAM role 'andromeda-service-account-role' that could allow unauthorized access to AKS cluster resources. Review and restrict IAM policies according to the principle of least privilege.", + "Remediation": { + "Recommendation": { + "Text": "For guidance on IAM roles and policies, see the IAM User Guide.", + "Url": "https://docs.aws.amazon.com/IAM/latest/UserGuide/best-practices.html" + } + }, + "Resources": [ + { + "Type": "AwsIamRole", + "Id": "arn:aws:iam::123456789012:role/andromeda-service-account-role", + "Partition": "aws", + "Region": "us-east-1" + } + ] } \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/17_Permission_Enumeration_K8.yaml b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/17_Permission_Enumeration_K8.yaml similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/17_Permission_Enumeration_K8.yaml rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/17_Permission_Enumeration_K8.yaml index aa0e238..c35ef59 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/17_Permission_Enumeration_K8.yaml +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/17_Permission_Enumeration_K8.yaml @@ -1,15 +1,15 @@ -kind: Event -apiVersion: audit.k8s.io/v1 -level: Request -timestamp: "2024-02-29T22:50:00Z" -auditID: k5l6m7n8-o9p0-q1r2-s3t4-u5v6w7x8y9z0 -stage: ResponseComplete -requestURI: "/api/v1/namespaces/default/pods" -verb: "list" -user: - username: "system:serviceaccount:default:andromeda-service-account" -sourceIPs: ["10.244.2.4"] -annotations: - kubernetes.io/resource-enumeration: "Enumerated pods to discover resources and assess permissions available to the compromised account." -responseStatus: +kind: Event +apiVersion: audit.k8s.io/v1 +level: Request +timestamp: "2024-02-29T22:50:00Z" +auditID: k5l6m7n8-o9p0-q1r2-s3t4-u5v6w7x8y9z0 +stage: ResponseComplete +requestURI: "/api/v1/namespaces/default/pods" +verb: "list" +user: + username: "system:serviceaccount:default:andromeda-service-account" +sourceIPs: ["10.244.2.4"] +annotations: + kubernetes.io/resource-enumeration: "Enumerated pods to discover resources and assess permissions available to the compromised account." +responseStatus: code: 200 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/18_Cloud_Instance_Metadata_API_Misuse_CloudWatch.json b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/18_Cloud_Instance_Metadata_API_Misuse_CloudWatch.json similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/18_Cloud_Instance_Metadata_API_Misuse_CloudWatch.json rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/18_Cloud_Instance_Metadata_API_Misuse_CloudWatch.json index d438bb8..997b571 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/18_Cloud_Instance_Metadata_API_Misuse_CloudWatch.json +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/18_Cloud_Instance_Metadata_API_Misuse_CloudWatch.json @@ -1,15 +1,15 @@ -{ - "timestamp": "2024-02-29T23:00:00Z", - "logStream": "AndromedaWebCluster/andromeda-web-app-container", - "message": "Detected unauthorized access to the Azure Instance Metadata Service from within 'andromeda-web-app-container'. Attempted retrieval of credentials and tokens for lateral movement or escalation.", - "kubernetes": { - "cluster": "AndromedaWebCluster", - "namespace": "default", - "pod": "andromeda-web-app-container" - }, - "security": { - "action": "MetadataServiceAccess", - "outcome": "Detected", - "indicator": "CredentialRetrievalAttempt" - } +{ + "timestamp": "2024-02-29T23:00:00Z", + "logStream": "AndromedaWebCluster/andromeda-web-app-container", + "message": "Detected unauthorized access to the Azure Instance Metadata Service from within 'andromeda-web-app-container'. Attempted retrieval of credentials and tokens for lateral movement or escalation.", + "kubernetes": { + "cluster": "AndromedaWebCluster", + "namespace": "default", + "pod": "andromeda-web-app-container" + }, + "security": { + "action": "MetadataServiceAccess", + "outcome": "Detected", + "indicator": "CredentialRetrievalAttempt" + } } \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/18_Cloud_Instance_Metadata_API_Misuse_CloudWatch_CloudTrail.json b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/18_Cloud_Instance_Metadata_API_Misuse_CloudWatch_CloudTrail.json similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/18_Cloud_Instance_Metadata_API_Misuse_CloudWatch_CloudTrail.json rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/18_Cloud_Instance_Metadata_API_Misuse_CloudWatch_CloudTrail.json index 2b236b0..4c95240 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/18_Cloud_Instance_Metadata_API_Misuse_CloudWatch_CloudTrail.json +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/18_Cloud_Instance_Metadata_API_Misuse_CloudWatch_CloudTrail.json @@ -1,48 +1,48 @@ -{ - "eventVersion": "1.08", - "userIdentity": { - "type": "AssumedRole", - "principalId": "AWS:AROAXXXXXXXXXXXXX:andromeda-service-account", - "arn": "arn:aws:sts::123456789012:assumed-role/andromeda-service-account-role/i-0123456789abcdef0", - "accountId": "123456789012", - "accessKeyId": "ASIAxxxxxxxxxxxxxx", - "sessionContext": { - "sessionIssuer": { - "type": "Role", - "principalId": "AROAXXXXXXXXXXXXX", - "arn": "arn:aws:iam::123456789012:role/andromeda-service-account-role", - "accountId": "123456789012", - "userName": "andromeda-service-account-role" - }, - "webIdFederationData": {}, - "attributes": { - "mfaAuthenticated": "false", - "creationDate": "2024-02-29T23:00:00Z" - } - } - }, - "eventTime": "2024-02-29T23:05:00Z", - "eventSource": "sts.amazonaws.com", - "eventName": "AssumeRole", - "awsRegion": "us-east-1", - "sourceIPAddress": "10.244.2.4", - "userAgent": "aws-cli/1.18.69 Python/3.6.10", - "requestParameters": { - "roleArn": "arn:aws:iam::123456789012:role/andromeda-service-account-role", - "roleSessionName": "andromeda-web-app-container-session" - }, - "responseElements": { - "credentials": { - "accessKeyId": "ASIAxxxxxxxxxxxxxx", - "expiration": "2024-02-29T29:59:59Z", - "sessionToken": "FwoGZXIvYXdzEDMaDXXXXXXXXXXXXXX" - }, - "assumedRoleUser": { - "assumedRoleId": "AROAXXXXXXXXXXXXX:andromeda-web-app-container-session", - "arn": "arn:aws:sts::123456789012:assumed-role/andromeda-service-account-role/andromeda-web-app-container-session" - } - }, - "requestID": "6f8d2c1b-4c3d-4f5e-ba3d-c2d3e5f4g6h7", - "eventType": "AwsApiCall", - "recipientAccountId": "123456789012" +{ + "eventVersion": "1.08", + "userIdentity": { + "type": "AssumedRole", + "principalId": "AWS:AROAXXXXXXXXXXXXX:andromeda-service-account", + "arn": "arn:aws:sts::123456789012:assumed-role/andromeda-service-account-role/i-0123456789abcdef0", + "accountId": "123456789012", + "accessKeyId": "ASIAxxxxxxxxxxxxxx", + "sessionContext": { + "sessionIssuer": { + "type": "Role", + "principalId": "AROAXXXXXXXXXXXXX", + "arn": "arn:aws:iam::123456789012:role/andromeda-service-account-role", + "accountId": "123456789012", + "userName": "andromeda-service-account-role" + }, + "webIdFederationData": {}, + "attributes": { + "mfaAuthenticated": "false", + "creationDate": "2024-02-29T23:00:00Z" + } + } + }, + "eventTime": "2024-02-29T23:05:00Z", + "eventSource": "sts.amazonaws.com", + "eventName": "AssumeRole", + "awsRegion": "us-east-1", + "sourceIPAddress": "10.244.2.4", + "userAgent": "aws-cli/1.18.69 Python/3.6.10", + "requestParameters": { + "roleArn": "arn:aws:iam::123456789012:role/andromeda-service-account-role", + "roleSessionName": "andromeda-web-app-container-session" + }, + "responseElements": { + "credentials": { + "accessKeyId": "ASIAxxxxxxxxxxxxxx", + "expiration": "2024-02-29T29:59:59Z", + "sessionToken": "FwoGZXIvYXdzEDMaDXXXXXXXXXXXXXX" + }, + "assumedRoleUser": { + "assumedRoleId": "AROAXXXXXXXXXXXXX:andromeda-web-app-container-session", + "arn": "arn:aws:sts::123456789012:assumed-role/andromeda-service-account-role/andromeda-web-app-container-session" + } + }, + "requestID": "6f8d2c1b-4c3d-4f5e-ba3d-c2d3e5f4g6h7", + "eventType": "AwsApiCall", + "recipientAccountId": "123456789012" } \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/19_Exploitation_for_Privilege_Escalation_CloudTrail.json b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/19_Exploitation_for_Privilege_Escalation_CloudTrail.json similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/19_Exploitation_for_Privilege_Escalation_CloudTrail.json rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/19_Exploitation_for_Privilege_Escalation_CloudTrail.json index a7ca9af..789ab02 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/19_Exploitation_for_Privilege_Escalation_CloudTrail.json +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/19_Exploitation_for_Privilege_Escalation_CloudTrail.json @@ -1,46 +1,46 @@ -{ - "eventVersion": "1.08", - "userIdentity": { - "type": "AssumedRole", - "principalId": "AWS:AROAXXXXXXXXXXXXX:compromised-service-account", - "arn": "arn:aws:iam::123456789012:role/eks-irsa-compromised-role", - "accountId": "123456789012", - "accessKeyId": "ASIAxxxxxxxxxxxxxx", - "sessionContext": { - "attributes": { - "mfaAuthenticated": "false", - "creationDate": "2024-02-29T23:35:00Z" - }, - "sessionIssuer": { - "userName": "eks-irsa-compromised-role", - "type": "Role", - "arn": "arn:aws:iam::123456789012:role/eks-irsa-compromised-role", - "accountId": "123456789012", - "principalId": "AROAXXXXXXXXXXXXX" - } - } - }, - "eventTime": "2024-02-29T23:35:00Z", - "eventSource": "sts.amazonaws.com", - "eventName": "AssumeRole", - "awsRegion": "us-east-1", - "sourceIPAddress": "10.244.3.4", - "userAgent": "aws-sdk-java/1.11.999 Linux/4.9.112-java", - "requestParameters": { - "roleArn": "arn:aws:iam::123456789012:role/eks-irsa-compromised-role", - "roleSessionName": "session123456789" - }, - "responseElements": { - "assumedRoleUser": { - "assumedRoleId": "AROAXXXXXXXXXXXXX:session123456789", - "arn": "arn:aws:sts::123456789012:assumed-role/eks-irsa-compromised-role/session123456789" - }, - "credentials": { - "accessKeyId": "ASIAxxxxxxxxxxxxxx", - "expiration": "2024-03-01T03:35:00Z", - "sessionToken": "FwoGZXIvYXdzEDMaDXXXXXXXXXXXXXX" - } - }, - "eventType": "AwsApiCall", - "recipientAccountId": "123456789012" +{ + "eventVersion": "1.08", + "userIdentity": { + "type": "AssumedRole", + "principalId": "AWS:AROAXXXXXXXXXXXXX:compromised-service-account", + "arn": "arn:aws:iam::123456789012:role/eks-irsa-compromised-role", + "accountId": "123456789012", + "accessKeyId": "ASIAxxxxxxxxxxxxxx", + "sessionContext": { + "attributes": { + "mfaAuthenticated": "false", + "creationDate": "2024-02-29T23:35:00Z" + }, + "sessionIssuer": { + "userName": "eks-irsa-compromised-role", + "type": "Role", + "arn": "arn:aws:iam::123456789012:role/eks-irsa-compromised-role", + "accountId": "123456789012", + "principalId": "AROAXXXXXXXXXXXXX" + } + } + }, + "eventTime": "2024-02-29T23:35:00Z", + "eventSource": "sts.amazonaws.com", + "eventName": "AssumeRole", + "awsRegion": "us-east-1", + "sourceIPAddress": "10.244.3.4", + "userAgent": "aws-sdk-java/1.11.999 Linux/4.9.112-java", + "requestParameters": { + "roleArn": "arn:aws:iam::123456789012:role/eks-irsa-compromised-role", + "roleSessionName": "session123456789" + }, + "responseElements": { + "assumedRoleUser": { + "assumedRoleId": "AROAXXXXXXXXXXXXX:session123456789", + "arn": "arn:aws:sts::123456789012:assumed-role/eks-irsa-compromised-role/session123456789" + }, + "credentials": { + "accessKeyId": "ASIAxxxxxxxxxxxxxx", + "expiration": "2024-03-01T03:35:00Z", + "sessionToken": "FwoGZXIvYXdzEDMaDXXXXXXXXXXXXXX" + } + }, + "eventType": "AwsApiCall", + "recipientAccountId": "123456789012" } \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/19_Exploitation_for_Privilege_Escalation_K8.yaml b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/19_Exploitation_for_Privilege_Escalation_K8.yaml similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/19_Exploitation_for_Privilege_Escalation_K8.yaml rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/19_Exploitation_for_Privilege_Escalation_K8.yaml index d3648b9..bbdac77 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/19_Exploitation_for_Privilege_Escalation_K8.yaml +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/19_Exploitation_for_Privilege_Escalation_K8.yaml @@ -1,20 +1,20 @@ -kind: Event -apiVersion: audit.k8s.io/v1 -level: RequestResponse -timestamp: "2024-02-29T23:30:00Z" -auditID: f8g9h0i1-j2k3-l4m5-n6o7-p8q9r0s1t2u3 -stage: ResponseComplete -requestURI: "/apis/rbac.authorization.k8s.io/v1/namespaces/default/rolebindings" -verb: "create" -user: - username: "system:serviceaccount:default:compromised-service-account" -sourceIPs: ["10.244.3.4"] -responseObject: - kind: RoleBinding - apiVersion: rbac.authorization.k8s.io/v1 - metadata: - name: "escalated-access-binding" -annotations: - kubernetes.io/rbac-abuse: "Created a RoleBinding 'escalated-access-binding' to exploit trust relationships and escalate privileges within the EKS cluster." -responseStatus: +kind: Event +apiVersion: audit.k8s.io/v1 +level: RequestResponse +timestamp: "2024-02-29T23:30:00Z" +auditID: f8g9h0i1-j2k3-l4m5-n6o7-p8q9r0s1t2u3 +stage: ResponseComplete +requestURI: "/apis/rbac.authorization.k8s.io/v1/namespaces/default/rolebindings" +verb: "create" +user: + username: "system:serviceaccount:default:compromised-service-account" +sourceIPs: ["10.244.3.4"] +responseObject: + kind: RoleBinding + apiVersion: rbac.authorization.k8s.io/v1 + metadata: + name: "escalated-access-binding" +annotations: + kubernetes.io/rbac-abuse: "Created a RoleBinding 'escalated-access-binding' to exploit trust relationships and escalate privileges within the EKS cluster." +responseStatus: code: 201 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/20_Extracting_Credentials_and_Privilege_Escalation_K8.yaml b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/20_Extracting_Credentials_and_Privilege_Escalation_K8.yaml similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/20_Extracting_Credentials_and_Privilege_Escalation_K8.yaml rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/20_Extracting_Credentials_and_Privilege_Escalation_K8.yaml index 1b8e087..2fd6153 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/20_Extracting_Credentials_and_Privilege_Escalation_K8.yaml +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/20_Extracting_Credentials_and_Privilege_Escalation_K8.yaml @@ -1,35 +1,35 @@ -{ - "eventVersion": "1.08", - "userIdentity": { - "type": "AssumedRole", - "principalId": "AWS:AROAXXXXXXXXXXXXX:compromised-service-account", - "arn": "arn:aws:sts::123456789012:assumed-role/compromised-service-account", - "accountId": "123456789012", - "accessKeyId": "ASIAxxxxxxxxxxxxxx", - "sessionContext": { - "attributes": { - "mfaAuthenticated": "false", - "creationDate": "2024-02-29T23:40:00Z" - }, - "sessionIssuer": { - "userName": "compromised-service-account", - "type": "Role", - "arn": "arn:aws:iam::123456789012:role/compromised-service-account", - "accountId": "123456789012", - "principalId": "AROAXXXXXXXXXXXXX" - } - } - }, - "eventTime": "2024-02-29T23:40:00Z", - "eventSource": "secretsmanager.amazonaws.com", - "eventName": "GetSecretValue", - "awsRegion": "us-east-1", - "sourceIPAddress": "10.244.3.4", - "userAgent": "aws-sdk-java/1.11.999 Linux/4.9.112-java", - "requestParameters": { - "secretId": "arn:aws:secretsmanager:us-east-1:123456789012:secret:compromised-db-credentials-abc123" - }, - "responseElements": null, - "eventType": "AwsApiCall", - "recipientAccountId": "123456789012" +{ + "eventVersion": "1.08", + "userIdentity": { + "type": "AssumedRole", + "principalId": "AWS:AROAXXXXXXXXXXXXX:compromised-service-account", + "arn": "arn:aws:sts::123456789012:assumed-role/compromised-service-account", + "accountId": "123456789012", + "accessKeyId": "ASIAxxxxxxxxxxxxxx", + "sessionContext": { + "attributes": { + "mfaAuthenticated": "false", + "creationDate": "2024-02-29T23:40:00Z" + }, + "sessionIssuer": { + "userName": "compromised-service-account", + "type": "Role", + "arn": "arn:aws:iam::123456789012:role/compromised-service-account", + "accountId": "123456789012", + "principalId": "AROAXXXXXXXXXXXXX" + } + } + }, + "eventTime": "2024-02-29T23:40:00Z", + "eventSource": "secretsmanager.amazonaws.com", + "eventName": "GetSecretValue", + "awsRegion": "us-east-1", + "sourceIPAddress": "10.244.3.4", + "userAgent": "aws-sdk-java/1.11.999 Linux/4.9.112-java", + "requestParameters": { + "secretId": "arn:aws:secretsmanager:us-east-1:123456789012:secret:compromised-db-credentials-abc123" + }, + "responseElements": null, + "eventType": "AwsApiCall", + "recipientAccountId": "123456789012" } \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/20_Extracting_Credentials_and_Privilege_Escalation_K8_ConfMap.yaml b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/20_Extracting_Credentials_and_Privilege_Escalation_K8_ConfMap.yaml similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/20_Extracting_Credentials_and_Privilege_Escalation_K8_ConfMap.yaml rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/20_Extracting_Credentials_and_Privilege_Escalation_K8_ConfMap.yaml index cd814be..1538a68 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/20_Extracting_Credentials_and_Privilege_Escalation_K8_ConfMap.yaml +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/20_Extracting_Credentials_and_Privilege_Escalation_K8_ConfMap.yaml @@ -1,18 +1,18 @@ -kind: Event -apiVersion: audit.k8s.io/v1 -level: RequestResponse -timestamp: "2024-02-29T23:45:00Z" -auditID: v3w4x5y6-z7a8-b9c0-d1e2-f3g4h5i6j7k8 -stage: ResponseComplete -requestURI: "/api/v1/namespaces/default/configmaps" -verb: "list" -user: - username: "system:serviceaccount:default:compromised-service-account" -sourceIPs: ["10.244.3.4"] -responseObject: - kind: ConfigMapList - apiVersion: v1 -annotations: - kubernetes.io/configmap-access: "Enumerated ConfigMaps in the default namespace to extract stored credentials and configuration details." -responseStatus: +kind: Event +apiVersion: audit.k8s.io/v1 +level: RequestResponse +timestamp: "2024-02-29T23:45:00Z" +auditID: v3w4x5y6-z7a8-b9c0-d1e2-f3g4h5i6j7k8 +stage: ResponseComplete +requestURI: "/api/v1/namespaces/default/configmaps" +verb: "list" +user: + username: "system:serviceaccount:default:compromised-service-account" +sourceIPs: ["10.244.3.4"] +responseObject: + kind: ConfigMapList + apiVersion: v1 +annotations: + kubernetes.io/configmap-access: "Enumerated ConfigMaps in the default namespace to extract stored credentials and configuration details." +responseStatus: code: 200 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/21_Lateral_Movement_via_Compromised_Roles_K8.yaml b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/21_Lateral_Movement_via_Compromised_Roles_K8.yaml similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/21_Lateral_Movement_via_Compromised_Roles_K8.yaml rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/21_Lateral_Movement_via_Compromised_Roles_K8.yaml index e4e155f..521a771 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/21_Lateral_Movement_via_Compromised_Roles_K8.yaml +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/21_Lateral_Movement_via_Compromised_Roles_K8.yaml @@ -1,20 +1,20 @@ -kind: Event -apiVersion: audit.k8s.io/v1 -level: RequestResponse -timestamp: "2024-03-01T00:10:00Z" -auditID: y7z8a9b0-c1d2-e3f4-g5h6-i7j8k9l0m1n2 -stage: ResponseComplete -requestURI: "/apis/rbac.authorization.k8s.io/v1/clusterrolebindings" -verb: "create" -user: - username: "system:serviceaccount:linked:compromised-service-account" -sourceIPs: ["10.244.4.5"] -responseObject: - kind: ClusterRoleBinding - apiVersion: rbac.authorization.k8s.io/v1 - metadata: - name: "cross-environment-access-binding" -annotations: - kubernetes.io/pass-the-role: "Created a ClusterRoleBinding 'cross-environment-access-binding' using a compromised role to assume additional roles within the EKS cluster." -responseStatus: +kind: Event +apiVersion: audit.k8s.io/v1 +level: RequestResponse +timestamp: "2024-03-01T00:10:00Z" +auditID: y7z8a9b0-c1d2-e3f4-g5h6-i7j8k9l0m1n2 +stage: ResponseComplete +requestURI: "/apis/rbac.authorization.k8s.io/v1/clusterrolebindings" +verb: "create" +user: + username: "system:serviceaccount:linked:compromised-service-account" +sourceIPs: ["10.244.4.5"] +responseObject: + kind: ClusterRoleBinding + apiVersion: rbac.authorization.k8s.io/v1 + metadata: + name: "cross-environment-access-binding" +annotations: + kubernetes.io/pass-the-role: "Created a ClusterRoleBinding 'cross-environment-access-binding' using a compromised role to assume additional roles within the EKS cluster." +responseStatus: code: 201 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/21_Lateral_Movement_via_Compromised_Roles_K8_CloudTrail.json b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/21_Lateral_Movement_via_Compromised_Roles_K8_CloudTrail.json similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/21_Lateral_Movement_via_Compromised_Roles_K8_CloudTrail.json rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/21_Lateral_Movement_via_Compromised_Roles_K8_CloudTrail.json index b8fbd15..47ac70c 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/21_Lateral_Movement_via_Compromised_Roles_K8_CloudTrail.json +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/21_Lateral_Movement_via_Compromised_Roles_K8_CloudTrail.json @@ -1,46 +1,46 @@ -{ - "eventVersion": "1.08", - "userIdentity": { - "type": "AssumedRole", - "principalId": "AWS:AROAXXXXXXXXXXXXX:compromised-linked-account-role", - "arn": "arn:aws:sts::987654321098:assumed-role/compromised-linked-account-role/role-session123", - "accountId": "987654321098", - "accessKeyId": "ASIAxxxxxxxxxxxxxx", - "sessionContext": { - "attributes": { - "mfaAuthenticated": "false", - "creationDate": "2024-03-01T00:15:00Z" - }, - "sessionIssuer": { - "userName": "compromised-linked-account-role", - "type": "Role", - "arn": "arn:aws:iam::987654321098:role/compromised-linked-account-role", - "accountId": "123456789012", - "principalId": "AROAXXXXXXXXXXXXX" - } - } - }, - "eventTime": "2024-03-01T00:15:00Z", - "eventSource": "sts.amazonaws.com", - "eventName": "AssumeRole", - "awsRegion": "us-east-1", - "sourceIPAddress": "10.244.4.5", - "userAgent": "aws-sdk-java/1.11.999 Linux/4.9.112-java", - "requestParameters": { - "roleArn": "arn:aws:iam::987654321098:role/cross-account-access-role", - "roleSessionName": "cross-account-session" - }, - "responseElements": { - "assumedRoleUser": { - "assumedRoleId": "AROAXXXXXXXXXXXXX:cross-account-session", - "arn": "arn:aws:sts::987654321098:assumed-role/cross-account-access-role/cross-account-session" - }, - "credentials": { - "accessKeyId": "ASIAxxxxxxxxxxxxxx", - "expiration": "2024-03-01T04:15:00Z", - "sessionToken": "FwoGZXIvYXdzEDMaDXXXXXXXXXXXXXX" - } - }, - "eventType": "AwsApiCall", - "recipientAccountId": "987654321098" +{ + "eventVersion": "1.08", + "userIdentity": { + "type": "AssumedRole", + "principalId": "AWS:AROAXXXXXXXXXXXXX:compromised-linked-account-role", + "arn": "arn:aws:sts::987654321098:assumed-role/compromised-linked-account-role/role-session123", + "accountId": "987654321098", + "accessKeyId": "ASIAxxxxxxxxxxxxxx", + "sessionContext": { + "attributes": { + "mfaAuthenticated": "false", + "creationDate": "2024-03-01T00:15:00Z" + }, + "sessionIssuer": { + "userName": "compromised-linked-account-role", + "type": "Role", + "arn": "arn:aws:iam::987654321098:role/compromised-linked-account-role", + "accountId": "123456789012", + "principalId": "AROAXXXXXXXXXXXXX" + } + } + }, + "eventTime": "2024-03-01T00:15:00Z", + "eventSource": "sts.amazonaws.com", + "eventName": "AssumeRole", + "awsRegion": "us-east-1", + "sourceIPAddress": "10.244.4.5", + "userAgent": "aws-sdk-java/1.11.999 Linux/4.9.112-java", + "requestParameters": { + "roleArn": "arn:aws:iam::987654321098:role/cross-account-access-role", + "roleSessionName": "cross-account-session" + }, + "responseElements": { + "assumedRoleUser": { + "assumedRoleId": "AROAXXXXXXXXXXXXX:cross-account-session", + "arn": "arn:aws:sts::987654321098:assumed-role/cross-account-access-role/cross-account-session" + }, + "credentials": { + "accessKeyId": "ASIAxxxxxxxxxxxxxx", + "expiration": "2024-03-01T04:15:00Z", + "sessionToken": "FwoGZXIvYXdzEDMaDXXXXXXXXXXXXXX" + } + }, + "eventType": "AwsApiCall", + "recipientAccountId": "987654321098" } \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/22_Data_Collection_from_Information_Repositories_CloudTrail.json b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/22_Data_Collection_from_Information_Repositories_CloudTrail.json similarity index 96% rename from docs/TTX/Andromeda_Gales/Event_Logs/22_Data_Collection_from_Information_Repositories_CloudTrail.json rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/22_Data_Collection_from_Information_Repositories_CloudTrail.json index 5b8c690..56bd02f 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/22_Data_Collection_from_Information_Repositories_CloudTrail.json +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/22_Data_Collection_from_Information_Repositories_CloudTrail.json @@ -1,20 +1,20 @@ -{ - "eventVersion": "1.08", - "userIdentity": { - "type": "AssumedRole", - "principalId": "AWS:AROAXXXXXXXXXXXXX:exfiltration-role", - "arn": "arn:aws:sts::123456789012:assumed-role/exfiltration-role/exfiltration-session", - "accountId": "123456789012" - }, - "eventTime": "2024-03-01T01:00:00Z", - "eventSource": "s3.amazonaws.com", - "eventName": "ListObjects", - "awsRegion": "us-east-1", - "sourceIPAddress": "10.244.4.6", - "requestParameters": { - "bucketName": "sensitive-data-bucket" - }, - "responseElements": null, - "eventType": "AwsApiCall", - "recipientAccountId": "123456789012" +{ + "eventVersion": "1.08", + "userIdentity": { + "type": "AssumedRole", + "principalId": "AWS:AROAXXXXXXXXXXXXX:exfiltration-role", + "arn": "arn:aws:sts::123456789012:assumed-role/exfiltration-role/exfiltration-session", + "accountId": "123456789012" + }, + "eventTime": "2024-03-01T01:00:00Z", + "eventSource": "s3.amazonaws.com", + "eventName": "ListObjects", + "awsRegion": "us-east-1", + "sourceIPAddress": "10.244.4.6", + "requestParameters": { + "bucketName": "sensitive-data-bucket" + }, + "responseElements": null, + "eventType": "AwsApiCall", + "recipientAccountId": "123456789012" } \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/23_Snapshot_for_Exfiltration_CloudTrail.json b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/23_Snapshot_for_Exfiltration_CloudTrail.json similarity index 96% rename from docs/TTX/Andromeda_Gales/Event_Logs/23_Snapshot_for_Exfiltration_CloudTrail.json rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/23_Snapshot_for_Exfiltration_CloudTrail.json index 82442a1..c6f648e 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/23_Snapshot_for_Exfiltration_CloudTrail.json +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/23_Snapshot_for_Exfiltration_CloudTrail.json @@ -1,23 +1,23 @@ -{ - "eventVersion": "1.08", - "userIdentity": { - "type": "AssumedRole", - "principalId": "AWS:AROAXXXXXXXXXXXXX:exfiltration-role", - "arn": "arn:aws:sts::123456789012:assumed-role/exfiltration-role/exfiltration-session", - "accountId": "123456789012" - }, - "eventTime": "2024-03-01T01:10:00Z", - "eventSource": "ec2.amazonaws.com", - "eventName": "CreateSnapshot", - "awsRegion": "us-east-1", - "sourceIPAddress": "10.244.4.6", - "requestParameters": { - "volumeId": "vol-0abcd1234efgh5678", - "description": "Data exfiltration snapshot" - }, - "responseElements": { - "snapshotId": "snap-0abcd1234efgh5678" - }, - "eventType": "AwsApiCall", - "recipientAccountId": "123456789012" +{ + "eventVersion": "1.08", + "userIdentity": { + "type": "AssumedRole", + "principalId": "AWS:AROAXXXXXXXXXXXXX:exfiltration-role", + "arn": "arn:aws:sts::123456789012:assumed-role/exfiltration-role/exfiltration-session", + "accountId": "123456789012" + }, + "eventTime": "2024-03-01T01:10:00Z", + "eventSource": "ec2.amazonaws.com", + "eventName": "CreateSnapshot", + "awsRegion": "us-east-1", + "sourceIPAddress": "10.244.4.6", + "requestParameters": { + "volumeId": "vol-0abcd1234efgh5678", + "description": "Data exfiltration snapshot" + }, + "responseElements": { + "snapshotId": "snap-0abcd1234efgh5678" + }, + "eventType": "AwsApiCall", + "recipientAccountId": "123456789012" } \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/7_Discovery_Check_Against_Security_Software_K8.yaml b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/7_Discovery_Check_Against_Security_Software_K8.yaml similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/7_Discovery_Check_Against_Security_Software_K8.yaml rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/7_Discovery_Check_Against_Security_Software_K8.yaml index 5e59f82..d709311 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/7_Discovery_Check_Against_Security_Software_K8.yaml +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/7_Discovery_Check_Against_Security_Software_K8.yaml @@ -1,15 +1,15 @@ -kind: Event -apiVersion: audit.k8s.io/v1 -level: Metadata -timestamp: "2024-02-29T21:10:00Z" -auditID: a3b4c5d6-e7f8-g9h0-i1j2-k3l4m5n6o7p8 -stage: ResponseComplete -requestURI: "/api/v1/namespaces/default/pods/andromeda-web-app-container/logs" -verb: "get" -user: - username: "system:serviceaccount:default:andromeda-service-account" -sourceIPs: ["10.244.1.2"] -annotations: - kubernetes.io/discovery-check: "Security software enumeration attempt detected" -responseStatus: +kind: Event +apiVersion: audit.k8s.io/v1 +level: Metadata +timestamp: "2024-02-29T21:10:00Z" +auditID: a3b4c5d6-e7f8-g9h0-i1j2-k3l4m5n6o7p8 +stage: ResponseComplete +requestURI: "/api/v1/namespaces/default/pods/andromeda-web-app-container/logs" +verb: "get" +user: + username: "system:serviceaccount:default:andromeda-service-account" +sourceIPs: ["10.244.1.2"] +annotations: + kubernetes.io/discovery-check: "Security software enumeration attempt detected" +responseStatus: code: 200 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/8_Env_Keying_K8.yaml b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/8_Env_Keying_K8.yaml similarity index 97% rename from docs/TTX/Andromeda_Gales/Event_Logs/8_Env_Keying_K8.yaml rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/8_Env_Keying_K8.yaml index f6efae8..3913661 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/8_Env_Keying_K8.yaml +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/8_Env_Keying_K8.yaml @@ -1,15 +1,15 @@ -kind: Event -apiVersion: audit.k8s.io/v1 -level: Request -timestamp: "2024-02-29T21:15:00Z" -auditID: b4c5d6e7-f8g9-h0i1-j2k3-l4m5n6o7p8q9 -stage: ResponseComplete -requestURI: "/api/v1/namespaces/default/pods/andromeda-web-app-container/exec" -verb: "create" -user: - username: "system:serviceaccount:default:andromeda-service-account" -sourceIPs: ["10.244.1.3"] -annotations: - kubernetes.io/environment-keying: "Executed command for environment reconnaissance" -responseStatus: +kind: Event +apiVersion: audit.k8s.io/v1 +level: Request +timestamp: "2024-02-29T21:15:00Z" +auditID: b4c5d6e7-f8g9-h0i1-j2k3-l4m5n6o7p8q9 +stage: ResponseComplete +requestURI: "/api/v1/namespaces/default/pods/andromeda-web-app-container/exec" +verb: "create" +user: + username: "system:serviceaccount:default:andromeda-service-account" +sourceIPs: ["10.244.1.3"] +annotations: + kubernetes.io/environment-keying: "Executed command for environment reconnaissance" +responseStatus: code: 200 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/9_Persistence_Jobs_K8.yaml b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/9_Persistence_Jobs_K8.yaml similarity index 96% rename from docs/TTX/Andromeda_Gales/Event_Logs/9_Persistence_Jobs_K8.yaml rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/9_Persistence_Jobs_K8.yaml index ed65161..6fdbbc0 100644 --- a/docs/TTX/Andromeda_Gales/Event_Logs/9_Persistence_Jobs_K8.yaml +++ b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/9_Persistence_Jobs_K8.yaml @@ -1,20 +1,20 @@ -kind: Event -apiVersion: audit.k8s.io/v1 -level: RequestResponse -timestamp: "2024-02-29T21:20:00Z" -auditID: c5d6e7f8-g9h0-i1j2-k3l4-m5n6o7p8q9r0 -stage: ResponseComplete -requestURI: "/apis/batch/v1/namespaces/default/jobs" -verb: "create" -user: - username: "system:serviceaccount:default:andromeda-service-account" -sourceIPs: ["10.244.1.4"] -responseObject: - kind: Job - apiVersion: batch/v1 - metadata: - name: "persistence-job-andromeda" -annotations: - kubernetes.io/persistence-mechanism: "Created job for persistence mechanism establishment" -responseStatus: +kind: Event +apiVersion: audit.k8s.io/v1 +level: RequestResponse +timestamp: "2024-02-29T21:20:00Z" +auditID: c5d6e7f8-g9h0-i1j2-k3l4-m5n6o7p8q9r0 +stage: ResponseComplete +requestURI: "/apis/batch/v1/namespaces/default/jobs" +verb: "create" +user: + username: "system:serviceaccount:default:andromeda-service-account" +sourceIPs: ["10.244.1.4"] +responseObject: + kind: Job + apiVersion: batch/v1 + metadata: + name: "persistence-job-andromeda" +annotations: + kubernetes.io/persistence-mechanism: "Created job for persistence mechanism establishment" +responseStatus: code: 201 \ No newline at end of file diff --git a/docs/TTX/Andromeda_Gales/Event_Logs/readme.md b/docs/TTX/SOSS Community Day NA 2024/Event_Logs/readme.md similarity index 100% rename from docs/TTX/Andromeda_Gales/Event_Logs/readme.md rename to docs/TTX/SOSS Community Day NA 2024/Event_Logs/readme.md diff --git a/docs/TTX/Andromeda_Gales/Andromeda_Gales_Final.afb b/docs/TTX/SOSS Community Day NA 2024/SOSS_Community_Day_NA_2024_AttackFlow.afb similarity index 100% rename from docs/TTX/Andromeda_Gales/Andromeda_Gales_Final.afb rename to docs/TTX/SOSS Community Day NA 2024/SOSS_Community_Day_NA_2024_AttackFlow.afb diff --git a/docs/TTX/Andromeda_Gales/Andromeda_Gales.md b/docs/TTX/SOSS Community Day NA 2024/SOSS_Community_Day_NA_2024_Scenario.md similarity index 74% rename from docs/TTX/Andromeda_Gales/Andromeda_Gales.md rename to docs/TTX/SOSS Community Day NA 2024/SOSS_Community_Day_NA_2024_Scenario.md index a32a3f1..6e9078c 100644 --- a/docs/TTX/Andromeda_Gales/Andromeda_Gales.md +++ b/docs/TTX/SOSS Community Day NA 2024/SOSS_Community_Day_NA_2024_Scenario.md @@ -1,17 +1,20 @@ -# Scenario Descripton -## Andromeda Gales -As part of the OpenSSF incident response scenario an open source product has unknowingly been compromised. A malicious payload has been merged into the underlying container image / test suite, infecting a multitude of public and private organisations on update. - -The infected software provides integration with numerous CI/CD build pipelines, managing the repeatable build stages for an organisation's software. The malicious payload has been designed to exfiltrate sensitive data from the target deployment and send it to a remote server. The payload is also capable of executing arbitrary code on the host system, potentially leading to further compromise. - -The incident response team has been tasked with identifying the malicious payload, understanding the extent of the compromise, and providing guidance on remediation steps to affected organisations. The team must also provide guidance on how to prevent similar incidents in the future. The team has access to the following resources: - -- A copy of the infected container image\n- A list of affected organisations -- A copy of the malicious payload -- A list of build pipeline integrations -- A list of potential indicators of compromise (IOCs) -- A list of potential attack vectors -- A list of potential remediation steps -- A list of potential preventative measures - -The team is expected to provide a detailed incident report outlining the steps taken to identify and contain the incident, the impact of the compromise, and the recommended remediation and preventative measures. The incident report should also include a timeline of events and any lessons learned from the incident response process. +# Scenario Descripton +## SOSS Community Day NA 2024 +As part of the OpenSSF incident response scenario an open source product has unknowingly been compromised. A malicious payload has been merged into the underlying container image / test suite, infecting a multitude of public and private organisations on update. + +The infected software provides integration with numerous CI/CD build pipelines, managing the repeatable build stages for an organisation's software. The malicious payload has been designed to exfiltrate sensitive data from the target deployment and send it to a remote server. The payload is also capable of executing arbitrary code on the host system, via an implanted backdoor, potentially leading to further compromise. + +The incident response team has been tasked with identifying the malicious payload, understanding the extent of the compromise, and providing guidance on remediation steps to affected organisations. The team must also provide guidance on how to prevent similar incidents in the future. The team has access to the following resources: + +- A copy of the infected container image +- A list of affected organisations +- A copy of the malicious payload +- A list of build pipeline integrations +- A list of potential indicators of compromise (IOCs) +- A list of potential attack vectors +- A list of potential remediation steps +- A list of potential preventative measures + +The team is expected to provide a detailed incident report outlining the steps taken to identify and contain the incident, the impact of the compromise, and the recommended remediation and preventative measures. The incident report should also include a timeline of events and any lessons learned from the incident response process. + +The correlating security and incident events and alerts have been captured in the /Event_Logs directory within this repository for technical visibility into stages of the attack flow (provided as SOSS_Community_Day_NA_2024_AttackFlow.afb) to be used with https://center-for-threat-informed-defense.github.io/attack-flow/ui/ \ No newline at end of file diff --git a/docs/TTX/SOSS Community Day NA 2024/SOSS_Community_Day_NA_2024_Template.md b/docs/TTX/SOSS Community Day NA 2024/SOSS_Community_Day_NA_2024_Template.md new file mode 100644 index 0000000..685a281 --- /dev/null +++ b/docs/TTX/SOSS Community Day NA 2024/SOSS_Community_Day_NA_2024_Template.md @@ -0,0 +1,187 @@ +# Panelists & Contributors + +## Panelists + +- **Panelist 1** + - Role: Maintainer + +- **Panelist 2** + - Role: Maintainer + +- **Panelist 3** + - Role: Maintainer + +- **Panelist 4** + - Role: Maintainer + +- **Panelist 5** + - Role: Maintainer + +- **Panelist 6** + - Role: Repo package registry + +- **Panelist 7** + - Role: SOC/IRT + +- **Panelist 8** + - Role: End user + +- **Panelist 9** + - Role: End user + +- **Panelist 10** + - Role: End user + +- **Panelist 11** + - Role: End user + +- **Panelist 12** + - Role: End user + +## Contributors + +- **Contributor 1** + - Role: Maintainer + +- **Contributor 2** + - Role: Maintainer + +- **Contributor 3** + - Role: End user + +- **Contributor 4** + - Role: End user + +- **Contributor 5** + - Role: Public sector + +- **Contributor 6** + - Role: Public sector + +# Desired Outcomes + +1. Provide a TTX template/formula for maintainers, contributors, and open source consumers to adopt and customize to start running their own TTX and improve their incident response and overall security posture. +2. Provide education for developers who are learning security. +3. Demonstrate how current OpenSSF technologies may be helpful during a security incident. + +- **Welcome background description and desired outcomes for the TTX** + +## Breakthrough 1: Initial Incident + +A large mature organization has disclosed a cybersecurity incident as encouraged by the Cyber Incident Reporting for Critical Infrastructure Act of 2022 (CIRCIA). The details are initially sparse, but the known facts are: + +- A security analyst has identified anomalous egress connections from their Cloud estate. +- The connections originated from workloads running on their Kubernetes cluster. +- These workloads run a business application with access to confidential data. +- Cluster logs show workloads running some commands against the cluster API, harvesting runtime environmental information. +- The workloads have recently been updated as part of routine patching/updates, coinciding with the timing of some suspicious alerts generated. +- The Incident Response Team (IRT) is still investigating ongoing threads. + +### Questions + +1. What are the typical steps an organization may take on initial security alert disclosure when initiating a Cyber Incident Response process? +2. After initial cyber incident response processes have been carried out and the org has moved into in-depth investigation, what steps are typical at this stage of the IR process? + +## Breakthrough 2: Scenario Evolution + +As the investigation progresses, more details come to light: + +- From the CI/CD build account, the Incident Response Team (IRT) has traced the event back to a specific pipeline execution. +- The pipeline includes several steps where external images are pulled from a public repository. +- A specific container image pulled consists of a widely used open source application. +- IRT obtains a copy of the image for further investigation but finds no signs of image tampering. +- Enhanced monitoring was put in place on the suspicious workloads. +- Signs of a possible Remote Code Execution (RCE) are detected, but the Vulnerability Management team reports no known CVEs affecting the open source application. +- Everything points to a 0-day vulnerability affecting one or more applications components with an active exploitation campaign ongoing. + +### Questions + +1. In light of the latest investigation progress after inconclusive findings, the team have decided to focus some effort on the internal repository (e.g., GitLab self-hosted) and the CI/CD pipeline. What kind of actions should they be looking to carry out at this point and with what goals in mind? +2. With the ongoing security incident and deep investigation, could you give some insight into how keeping a detailed inventory of both software and hardware, including open source software and dependencies, can be influential to incident response? +3. Additionally, could you explain the concept and significance of a Software Bill of Materials (SBOM) in managing open source security and share how SBOMs can be instrumental in streamlining the investigation process particularly in identifying compromised components and mapping out dependencies for a more efficient incident response? + +## Breakthrough 3: Scenario Evolution + +The scenario further evolves: + +- Internal investigations have concluded and found that the exploit has spread across various resources, necessitating disclosure of the vulnerability. +- The 0-day vulnerability is confirmed with exploitation replicated. +- Open Source maintainers have been contacted through their vulnerability disclosure process to work on a fix. +- Considering the active malicious campaign, the degree of urgency is communicated. +- Threat intelligence organizations provide data on the active campaign: + - Malicious destination domains and IPs + - Malicious binary hashes + - Malicious process names + - Malicious exploitation strings + +### Questions + +1. With the recent information provided by the IRT (Incident Response Team), the scenario has grown to include open source maintainers at this stage; they're required to begin their vulnerability disclosure process. How does this typically work? +2. In today's world, maintaining reputation across platforms is paramount. How can organizations and maintainers alike manage social media scrutiny and pressure, especially in 'crisis' events such as highly visible exploits targeting specific projects? +3. How can you aim to protect the people working under pressure and stress throughout these events? + +## Breakthrough 4: Scenario Evolution + +The scenario evolves: + +- The maintainers have successfully produced and tested a fix. +- The fix was incorporated into a new release of the application and made available to the general public. +- Indicators of Compromise are available to aid detections. +- The CVE now has a remediation/fix with a 9.5 score made available to the general public. + +### Questions + +1. In light of the recent successful development and release of a patch for a high-severity vulnerability, could you elaborate on best practices for coordinating efforts of maintainers and open source project teams to ensure the fix's security and authenticity, preventing it from becoming a secondary attack vector? +2. Additionally, how can you collaborate with larger organizations or the initial disclosing entity to validate and publicize the remedy? + +3. Considering the recent CVE announcement, could you walk us through the process your organization employs to create a comprehensive and timely response to customers? +4. Specifically, how do you integrate communication, patch management, and incident response strategies to address vulnerabilities and maintain trust in a cloud-native platform? + +5. When looking at enhancing security within open source projects, how does a collaborative project like GUAC contribute to this goal? +6. How do projects like GUAC integrate with existing security practices to comprehensively secure open source software, and what unique advantages does GUAC provide in the broader context of open source security management? + +7. In light of our ongoing discussion and the scenario we've navigated, how can the OSV database and scanner be strategically used to support the identification, tracking, and resolution of vulnerabilities such as the one we've encountered? +8. Could you share insights or experiences on how these tools have facilitated a more streamlined and effective response to vulnerabilities in past incidents? + +## Breakthrough 5: Postmortem / Open Discussion + +### Reflections on the Scenario + +### Questions + +1. What is CISA’s role in OSS security? +2. A number of sectors have an inherent distrust in open source due to a number of factors including time to remediation, SLAs, enterprise-level support, and its 'open' nature. How do you think this could be tackled, and are there any initiatives that could support this? + +### End User(s) Discussion + +#### Forum Discussion Style Topic: 10-15 Minutes + +"Leveraging Corporate Resources for Open Source Security" +- A conversation about how large organizations who have fully established policies, processes, and resources in place to respond to such incidents, invest and establish mutual beneficiary outcomes with open source maintainers and projects, potentially creating a framework for mutual support. + +"Collaborative Incident Response: Bridging the Gap between Large Organizations and Open Source Projects" +- This discussion topic aims to explore how large organizations could potentially extend their incident response capabilities to support open source projects during security incidents. +- It will focus on sharing actionable insights, resources, and best practices to enhance the resilience of open source software against emerging threats, emphasizing collaborative efforts, shared responsibility, and the alignment of incident response strategies for the collective benefit of the digital ecosystem. + +#### Forum Discussion Style Topic: 10-15 Minutes + +"Fostering Trust and Transparency: The Art of Communicating with Security Issue Reporters" +- Discuss the importance of open lines of communication between project maintainers and Security issue reporters for enhancing project security and community trust. + +### Lesson Learnt, Final Observations + +### Closing Remarks + +### Q&A + +# Acknowledgments + +We thank all the panelists, contributors, and attendees for their active participation and valuable contributions to the success of this event. Special thanks to the organizing team for their efforts in coordinating and facilitating the session. + +# About This Document + +This document was created to provide a structured overview of the tabletop exercise (TTX) and to serve as a reference for future similar events. + +# Contact Information + +For any inquiries related to this document or the discussions held during the TTX, please contact OpenSSF \ No newline at end of file diff --git a/docs/TTX/SOSS Community Day NA 2024/readme.md b/docs/TTX/SOSS Community Day NA 2024/readme.md new file mode 100644 index 0000000..0e0bdbd --- /dev/null +++ b/docs/TTX/SOSS Community Day NA 2024/readme.md @@ -0,0 +1 @@ +TTX materials for the SOSS_Community_Day_NA_2024 scenario diff --git a/docs/TTX/readme.md b/docs/TTX/readme.md index 442dea3..061bfed 100644 --- a/docs/TTX/readme.md +++ b/docs/TTX/readme.md @@ -1,4 +1,4 @@ -This directory contains files from the OpenSSF's Table Top Exercises (TTX) that demonstrate how to prepare and "roleplay" a cyber seecurity incident. +This directory contains files from the OpenSSF's Table Top Exercises (TTX) that demonstrate how to prepare and "roleplay" a cyber security incident. # Cyber Incident Response - Table Top Exercises ## Table of Contents @@ -15,22 +15,38 @@ This directory contains files from the OpenSSF's Table Top Exercises (TTX) that - [References](#references) ## Introduction -The purpose of this document is to provide guidance on how to conduct a table top exercise for cyber incident response. This document is intended to be used by organizations that want to test their incident response plans and procedures in a controlled environment. The document provides a scenario, objectives, and materials for the exercise. It also provides guidance on how to prepare for, execute, and debrief the exercise. +The purpose of this document is to provide guidance on how to conduct a table top exercise for cyber incident response. This document is intended to be used by organizations, and anyone who wishes to contribute to building future exercises, that want to test their incident response plans and procedures in a controlled environment. The document provides guidance on how to craft a scenario, objectives, and materials for the exercise. It also provides guidance on how to prepare for, execute, and debrief the exercise. ## Table Top Exercise A table top exercise is a discussion-based exercise that is designed to test an organization's incident response plans and procedures. The exercise is conducted in a controlled environment and involves key personnel who are responsible for responding to a cyber incident. The exercise is designed to identify gaps in the organization's incident response plans and procedures and to improve the organization's ability to respond to a cyber incident. +Typically at a TTX level the policies and process are under scrutiny as a standard, however we are pushing more towards involving technical investigation, response and resolution processes and guidance, as Cyber Incidents have become more widespread and visible over recent times. + +With this in mind we aim to produce two 'sides' to each TTX Exercise; +- Documentation based TTX +- - Typically involves a Question and Answer document revovling around a hypothetical scenario, for participants to walkthrough and discuss hwo and why they may take specific actions against steps of the incident +- - Ideal for conference 'panelist' discussion forums, where Subject Matter Experts (SMEs) can share insights and guidance for specific steps of scenarios (e.g. Project maintainer can divulge how they would react to vulnerability disclosures) + +- Technical TTX +- - We use this to underpin the entire TTX scenario, so that what we deliver is as realistic as possible, as opposed to 100% hypotheticals that are technically never exposable or viable as attack vectors in a real deployment +- - Currently we use the Center for Threat Informed Defense (CTID) Attack Flow builder - https://center-for-threat-informed-defense.github.io/attack-flow/ui/ +- - Each scenario will have a .afb file attached, allowing attendees to open the technical attack flow to follow along. This proves valuable for 'technical' individuals who benefit from having a further visual and technical aid to understanding the scenario +- - Where possible we produce 'synthetic' alerts and events to accompany the Incident Response process. These are normally hand crafted to mirror what an analyst/developer may see in a typical real-world scenario, again emphasising the realness of our scenarios + + ## Scenario -The scenario for the table top exercise is a cyber incident that has occurred in the organization. The scenario is designed to be realistic and to test the organization's incident response plans and procedures. The scenario includes a series of events that unfold over time, and the participants are required to respond to the events as they occur. +The scenarios for the table top exercise typically occur after a cyber incident that has occurred. The scenarios are designed to be realistic and to test the organization's incident response plans and procedures. The scenario should includes a series of events that unfold over time, and the participants are required to respond to the events as they occur, and if technical members are in attendance you should be able to dive into attack flows, indicators and relevant data sources that correlate against the scenario. + +Included with every scenario should be a template (e.g. Within SOSS_Community_Day_NA_2024 there is a SOSS_Community_Day_NA_2024_template.md) which covers the scenario walkthrough / roleplay, required attendees, questions and format to the TTX. ## Exercise Objectives The objectives of the table top exercise are to: - Test the organization's incident response plans and procedures - Identify gaps in the organization's incident response plans and procedures -- Improve the organization's ability to respond to a cyber incident +- Improve the organization's ability to respond to a cyber incident, including technical directive where suitable ## Exercise Participants -The participants in the table top exercise are key personnel who are responsible for responding to a cyber incident. The participants include: +The participants in the table top exercise are key personnel who are responsible for responding to a cyber incident. The participants normally include: - Incident Response Team - IT Security Team - IT Operations Team @@ -39,26 +55,32 @@ The participants in the table top exercise are key personnel who are responsible - Human Resources Team - Business Continuity Team - Executive Management -- Placeholder for other teams +- Additional participants on ad-hoc basis ## Exercise Materials The materials for the table top exercise include: - Table top exercise scenario - Table top exercise objectives -- Table top exercise slack channel +- Table top exercise questions based upon the scenario +- Table top exercise technical attack flow +- Table top exercise synthetic events and alerts +- Table top exercise slack channel (If running technical analysis) - Table top exercise evaluation form ## Exercise Preparation The preparation for the table top exercise includes: -- Reviewing the table top exercise scenario +- Creating and Reviewing the table top exercise scenario - Reviewing the table top exercise objectives -- Setting up the table top exercise slack channel +- Creating a real-world viable technical attack flow including indicators and data source requirements +- Creating synethitic event logs and alerts from technical analysis of scenario +- Setting up the table top exercise slack channel (If required) - Distributing the table top exercise materials to the participants ## Exercise Execution The execution of the table top exercise includes: - Introducing the table top exercise scenario - Facilitating the discussion of the scenario +- If a technical exercise, setting up the technical aspects (events, alerting and feeds) into a relevant space (e.g. Slack) for analysts / developers etc to respond to - Documenting the responses of the participants - Evaluating the responses of the participants @@ -66,6 +88,7 @@ The execution of the table top exercise includes: The debrief of the table top exercise includes: - Reviewing the responses of the participants - Identifying gaps in the organization's incident response plans and procedures +- Identifying technical gaps in the organiation's observability and security posture (e.g. visibility of indicators, data source requirements etc) - Developing an action plan to address the gaps ## Exercise Conclusion