Skip to content
This repository was archived by the owner on Feb 7, 2024. It is now read-only.

jonhurtt/secure-sdlc

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Work in Progress

Repository for showing a Secure Software Development Lifecyle

Goals

  1. Build Container Image and push to Amazon Elastic Container Registry (ECR)
  2. Build Amazon Elastic Compute Cloud (EC2) Instance with webserver (from html/index.html) via script at launch and deploy using Terraform Cloud
  3. Build EKS Cluster with Amazon Elastic Kubernetes Service (EKS)
  4. Deploy Conatiner Image within Amazon Elastic Container Service (ECS)

Technologies Used:

  • Docker (Code)
  • Terraform (IaC)
  • GitHub (VCS)
  • GitHub Actions (CI)
  • Terraform Cloud (CD)
  • Amazon Elastic Container Registry (ECR)
  • Amazon Elastic Compute Cloud (Amazon EC2)
  • Amazon Elastic Container Service (ECS)

Security Provided by Prisma Cloud

List of Security Functions provided by Prisma Cloud

Secure the Source

  1. IaC & SCA Scanning with Checkov via IDE Plugin
  2. IaC Tagging with Yor via GitHub Action @ Pull Request
  3. Image Scanning with Twistcli via GitHub Action @ Pull Request
  4. IaC & SCA Scanning with Checkov via GitHub Action @ Push to Main Branch
  5. IaC & SCA Scanning with Prisma Cloud via Integration @ Push to Main Branch

Secure @ Build & Deploy

  1. Image Scanning with Twistcli via GitHub Action @ Push to Main Branch
  2. IaC Scanning with Prisma Cloud via Terraform Run Task during Terraform Plan
  3. IaC Scanning with Prisma Cloud via Terraform Run Task during Terraform Apply
  4. Scanning Images in Container Image Registry via Prisma Cloud

Secure the Runtime

  1. Scanning for CI/CD Risk within Development Pipelines
  2. Continuous Scanning of Configurations in AWS environment
  3. Continuous Workload Vulnerability Scanning of cloud workloads

Information for Deployment

  • Ensure repository is public or part of GitHub Enterprise for GitHub Code Security Integration
  • Configure GitHub Actions to allow for Write Permissions (Settings->Actions->General->Under "Workflow permissions"->Enable "Read and Write Permissions")

Integration with AWS

  • Configure GitHub Action Secret - AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY
  • Configure GitHub Action Variables - AWS_ECR_REPOSITORY and AWS_REGION

Integrations with Terraform Cloud

  • Configure Workspace to allow for "Auto apply" for Apply Method
  • Configure GitHub Action Secret - TF_API_TOKEN
  • Configure GitHub Action Variables - TERRAFORM_CLOUD_WORKSPACE and TERRAFORM_CLOUD_ORG

Integrations with Prisma Cloud

  • Information for GitHubAction for IaC Tagging - yor-action
  • Configure GitHub Action Secret for Checkov IaC Scan Scanning & Checkov Image Scanning - BC_API_KEY
  • Configure GitHub Action Variables - PRISMA_API_URL
  • Configure GitHub Action Secret for twistcli Image Scanning - PCC_CONSOLE_URL, PCC_PASS and PCC_USER

GitHub Action Workflows

On Pull Request

on Pull Workflow

  1. [pull-01] IaC Yor Tagging
  2. [pull-02] Twistcli Image Scan
  3. [pull-03] Terraform Plan

On Push to Main Branch

on Push (Scan Code, Scan Image, Push Image & Apply)

  1. [push-01] Checkov (IaC/SCA) Scan
  2. [pull-02] Twistcli Image Scan
  3. [push-03] Push Image to AWS ECR
  4. [push-04] Terraform Apply

Deprecated Workflows

Links & Resources

Inspiration

Base Repos (Building Blocks)

Roadmap

Clean Up

  • Remove Tags from IaC Templates
  • Destroy Environment via Terraform Cloud

/end

About

Repository for showing a Secure SDLC

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published