Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/chanduusc/prismacloud-demo

Complete CNAPP Demo using Prisma Cloud
https://github.com/chanduusc/prismacloud-demo

ccs cloud cnapp code compliance cwp devops devsecops security security-automation security-tools

Last synced: about 10 hours ago
JSON representation

Complete CNAPP Demo using Prisma Cloud

Awesome Lists containing this project

README

        

Complete CNAPP Demo using Prisma Cloud demonstrating Cloud Code Security, Cloud Workload Protection (Agent, Agentless, Web Application and API Security) , Cloud Infrastructure Entitlement Management, Cloud Data Security, Cloud Security Posture Management . Demonstrates how the platform adds value to different persona's starting from developers to executives.
Uses Github actions for CI and CD process.

> This demo only focuses on some capabilities of modules within Prisma Cloud. Please refer to documentation for full list of capabilities
## Intent:
Demo intent is to showcase Prisma Cloud Capabilities across
- Multiple clouds. (EKS,GKE,AKS)
- Multiple form factors. (Container, Host, Serverless, Google Run)
- Different phases of application lifecycle.
- Multiple teams.
- Processes which are already part of organizational day to day activities.

AND you have a copy-paste coder like Sandeep in your team :)
Also want to showcase how not following best practices at dev/devops level might have increased blast radius.

## Installation:
- Terraform templates are provided in IaC folder. These are for reference only. Please modify as per your requirements.
- Yaml files for K8s deployment are provided in root folder
- Github action files can be found in .github folder and secrets configured can be found [here](https://github.com/chanduusc/prismacloud-demo/blob/schandu-tmp/IaC/README.md#secrets)
## Code Security:
### Coding phase (Persona: Developer/Devops)
1. Install Checkov plugin for VSCode (or IntelliJ)
2. Copy copy_to_req file to requirements.txt
3. The developer/devops will be notified of misconfigurations/vulnerabilites within IDE while coding.
![Check the vulnerabilities in IDE](img/checkov_plugin.png "Check the vulnerabilities in IDE")
> Example files for terraform,yaml,secrets can be found in fake_commits folder. Please use as per your requirement.
### Review/CI phase (Persona: Dev/Devops Leads/Managers)
1. Integrate your Github repo with Primsa Cloud Code Security module.
2. Push the code to your branch and raise pull request
3. The reviewers will be notified of misconfigurations/vulnerabilites in review process.This makes reviewers aware of the security issues in addition to coding issues.
4. Code-checkins are gated by security as PC scan becomes one of the checks during CI process
![Failed check in the Github Console](img/review_failed_gh_console.png "Failed check in the Github Console")
![Prisma bot comment in Github review process](img/prisma-cloud-devsecops-bot.png "Prisma bot comment in Github review process")
### Review/CI phase (Persona: Secops/Security Team)
1. Security team can see the same failures in Prisma Cloud console.
2. Security team can submit fixes from Prisma Cloud console which will open a new PR against your repo.
3. Prisma bot will mark the comments outdated once fixed.
![Check the vulnerabilities in PC Console](img/review_failed_pc_console.png "Check the vulnerabilities in PC Console")
![Submit fix from the PC Console](img/submit_pr_from_pc.png "Submit fix from the PC Console")
![Verify PR in the Github](img/pr_opened_by_prisma_cloud.png "Verify PR in the Github")
![Outdated activities after fixing the issue](img/outdated_requirements.png "Outdated activities after fixing the issue")

__**Please pay attention to docker file where apt is used against best practices**__
![APT warning](img/apt-alert.png "APT warning")
## Cloud Workload Protection:
__**Vulnerability policies are used as example here. Can be used with compliance policies too**__
### CD phase (Persona: Developer/Devops)
1. Github actions trigger build and deploy jobs in EKS,GKE and AKS.
2. Prisma Cloud image scan is inserted as part of github actions.
3. Policies for vulnerabilites (or compliance) can be set from Prisma Cloud.
4. Prisma Cloud will scan the image and fail the CD job hence the non-approved images are not pushed to registries.
> Remember Code security warned you about APT :)

![Failed build in CD process](img/gh_failed_build.png "Failed build in CD process")
### CD phase (Persona: Secops/Security Team)
1. Sets the polices related to images being built on day to day basis within the tools/process which are already part of organization.
2. Can view the real time status of builds in Prisma Cloud console.
3. Can debug/know which layer of build introduced the vulnerabilities.
![PC policy for vulnerability severity](img/pc-vuln-policy.png "PC policy for vulnerability severity")
![PC status showing where vulnerabilities got introduced](img/pc_failed_build.png "PC status showing where vulnerabilities got introduced")
![PC showing CD status](img/pc_cd_status.png "PC showing CD status")
### Image storage in registry (Persona: Secops/Security Team)
1. Image scanning is important after image build and push to registry
2. Vulnerabilites present in the image might be discovered after the image is built.
3. The same applies to deployed images.
![Image scan - registry](img/registry_image_scan.png "Image scan - registry")
![Image scan - deployed](img/deployed_image_scan.png "Image scan - deployed")
### Deploy phase (Persona: Devops and Production Engineering)
1. Devops team can see the vulnerable images not getting deployed.
2. The reason of failure (policy) can be viewed in audit logs
![Deploy fail - audit logs](img/kubectl_events.png "Deploy fail - audit logs")
![Deploy fail - pods](img/kubectl_pods.png "Deploy fail - pods")
### Deploy phase (Persona: Secops/Security Team)
1. Security team can set policies around deployment. Advanced features/exceptions can also be configured.
2. A message can be set so deployment team can know the reason/next steps.
3. Deployment failures are logged in PC Events tab.
![Deploy policy - PC](img/pc_deploy_policy.png "Deploy policy - PC")
![Deploy policy cont - PC](img/pc_deploy_policy_cont.png "Deploy policy cont - PC")
![Deploy audit - PC](img/pc_deploy_audits.png "Deploy audit - PC")
>Notice that the message set in Prisma Cloud console is visible in k8s audit logs
### Runtime (Persona: Secops/Security team)
1. Set runtime rules so that no malicious activities are happening during run time.
2. Set WAAS rules to protect your applications from real time attacks.
>We have unrealistic example in wild.py but any imported module can be the bad actor. Requirements.txt scan of code security should have caught it realistically.
3. Observe the event and alerts to keep track on production application health.
>Use tools like nuclei to simulate attacks --> nuclei -u http:/// -t nuclei-templates/f/ (more info : https://medium.com/@cyb_detective/using-nuclei-for-osint-5-minute-basic-guide-f8764424902b )

![Runtime policy - PC](img/runtime_policy.png "Runtime policy - PC")
![Runtime audit - PC](img/runtime_audit_pc.png "Runtime audit - PC")
![WAAS policy - PC](img/waas_policy.png "WAAS policy - PC")
![WAAS audit - PC](img/waas_audit_log.png "WAAS audit - PC")
![WAAS attacks - PC](img/waas_attacks.png "WAAS attacks - PC")
### Runtime (Persona: Production Engineering)
1. Work closely with dev and security teams based on the production runtime results.
2. Provide continous feedback about app/api deployment pattern to security teams.
![Runtime pod error in k8s - PC](img/runtime_pod_k8s.png "Runtime pod error in k8s")
## Cloud Infrastructure Entitlement Management:
### Post Deployment (Production Engineering / Secops or Security team)
1. CIEM module detects that one of the nodes have escalated permissions.
2. The nodes has permission to perform any action(*) on s3 service. Hence those capabilities are inherited by pods.
![Get host info - kubectl](img/kubectl_get_instance_id.png "Get host info - kubectl")
![Node asset view - PC](img/node_asset_pc.png "Node asset view - PC")
![Node alerts list - PC](img/alerts_list.png "Node alerts list - PC")
![Node graph view - PC](img/pc_graph.png "Node graph view - PC")
## Cloud Data Security:
### Post Deployment (Production Engineering / Secops or Security team)
> This is th only place where something is hardcoded in this entire project (Azure blobname and AWS s3 bucket needs to be changed)
1. The script wild.py copies malware and sensitive files to S3 bucket (and azureblob) which are public.
2. Again developers aren't educated about security and this is consequence of lack of security awareness.
![Data alerts list - PC](img/pc_data_sec_alerts.png "Data alerts list - PC")
## Cloud Security Posture Management:
### Post Deployment (Production Engineering / Secops or Security team and compliance teams)
1. Prisma Cloud ships with lot of out of box policies which provides visibility (or protection) across modules.
2. Generate reports for compliance, business unit and cloud security assesment on regular basis.
3. Review your compliance and asset trend to check how your organization is doing against time.
4. Setup alerts to be emailed to concerned people in your organization and audit them on regular basis.
5. Make sure you integrate alerts with change management and/or incident reporting tools to track remidiation.[Integrations link](https://docs.paloaltonetworks.com/prisma/prisma-cloud/prisma-cloud-admin/configure-external-integrations-on-prisma-cloud/prisma-cloud-integrations)
![Compliance Overview- PC](img/node_asset_pc.png "Compliance Overview- PC")
![Reports - PC](img/cspm_reports.png "Report - PC")
![Asset Inventory - PC](img/asset_inventory.png "Asset Inventory - PC")