Mastering Amazon Inspector: In-Depth Insights and Best Practices
In this blog we are going to explore Amazon Inspector in depth on how to manage vulnerabilities across our compute workloads, analyse a finding and understand vulnerability scoring, configuring and exporting SBOMs, setting up alerts using Eventbridge and integrating Inspector Image Scan into our CI/CD Pipeline.
- Centrally manage multiple Amazon Inspector accounts
- Assess vulnerabilities accurately with the Amazon Inspector Risk score
- Identify high-impact findings with the Amazon Inspector dashboard
- Manage your findings using customizable views
- Monitor and process findings with other services and systems
data:image/s3,"s3://crabby-images/807b0/807b0cb7023c84a9382c38885e6e5b210acc52dc" alt="Amazon Inspector"
If you want to create a Delegated Administrator for your organization to centrally manage Inspector across all accounts you can provide the respective Account ID, in our scenario we will activate this for an individual account. Click on Activate Inspector. Once the service is activated AWS will create a service role with the necessary permission to scan our resources in the backend.
data:image/s3,"s3://crabby-images/016d9/016d98ff56fffd32af46101d9a8862691db3f6a3" alt="Activate Inspector"
Inspector Dashboard
Once the service is activated, it will take some time to populate the resources and scan them against the vulnerability database, once done the findings will be populated on the dashboard.
- The Environment Coverage section helps us understand the overall percentage of compute resources (EC2 Instances, ECR Images, Lambda Functions) that is being monitored by Inspector.
- The Critical Findings lists the critical vulnerabilities for each Compute resource. We will be later drilling down into the Findings and shall see them in more details.
- Findings with exploit available and fix available is one the most important section if not the most important one, as you can see there are 5 vulnerabilities for which public exploit is available, and should be mitigated on an immediate basis.
data:image/s3,"s3://crabby-images/3a6fe/3a6fe09182e6a771ca0d2ba5602a4af9ceb53df4" alt="Inspector Dashboard"
Inspector Findings
data:image/s3,"s3://crabby-images/26dc2/26dc2d63db45f870719e65096dabeeaa7167430e" alt="Inspector Findings"
There are a total of 4 Finding Status:
- Active: The findings which are still active and has not been mitigated will be shown when this option is selected.
- Suppressed: All the suppressed findings will be listed here. We will later see how to create a suppression rule.
- Closed: The findings that have been mitigated will be shown upon selecting this option.
- Show all: Will display all the findings irrespective of their individual status.
data:image/s3,"s3://crabby-images/80090/800905e1588056501d30bfbaf08ab69ffdc2a4fa" alt="Filtering the Findings"
Now we will explore a finding in detail, for that you can select a particular finding which will open a parallel window with all the necessary details about that finding.
data:image/s3,"s3://crabby-images/3742e/3742e52b7b4ed6d3ae0f02dd95d5e0226c9bef41" alt="Details of a Finding"
data:image/s3,"s3://crabby-images/9b030/9b030ff7ea3554d424d1b0a2ef348ebcf29454f8" alt="Details of a Finding"
- Findings Overview: This includes Severity of the vulnerability, If an exploit is available for the vulnerability, If a fix is available or not, etc.
- Affected Packages: This helps to locate the package by stating it's file path, the package manager, fixed version of the package etc.
- Remediation: If a fix is available for the vulnerability, necessary remediation steps would be provided here.
- Related Vulnerabilities: If the current package relates to other CVE's those would be listed here.
- Resource Affected: This includes the details of the AWS Resource such as the Repository Name, Image Tags in case of an ECR Image Finding and likewise for other resources.
- Tags: Resource Tags
data:image/s3,"s3://crabby-images/463ef/463efe20b9af3d03e9e3d41deaa89171c65bc84b" alt="CVSS & Inspector Score"
Vulnerability Score
- CVSS Score:
CVSS stands for Common Vulnerability Scoring System, this score is obtained from the vendor such as RHEL, Debian, etc. In cases where this score is not provided, Amazon Inspector fetches the score from NVD (National Vulnerability Database) and calculates the score using the CVSS calculator. - Inspector Score:
Amazon Inspector scores each finding after correlating the base score from CVSS and the information collected after scanning the compute environment such as network reachability and exploitable data.
- Attack Vector: Context by which the vulnerability can be exploited.
- Attack Complexity: Difficulty involved in exploiting this vulnerability. Ranges from Low to High.
- Privilege Required: Level of privilege required to exploit this vulnerability.
- User Interaction: If exploiting this vulnerability requires a human user other than the attacker.
- Scope: Unchanged here means the affected resource and the impacted resource are the same. Changed means this vulnerability can be used to impact other resources.
- Confidentiality: Impact to Data Confidentiality. Ranges from Low to High.
- Integrity: Impact to Data Integrity. Ranges from Low to High.
- Availability: Impact to Data Availability. Ranges from Low to High.
- On the Findings Tab, click on Create Suppression Rule.
- Next you enter the suppression rule name, description and the filter on which Inspector would suppress the findings.
- Click on Save.
data:image/s3,"s3://crabby-images/017f4/017f44d1e2c7b44ee36fdb96f106f55f4dfa574a" alt=""
data:image/s3,"s3://crabby-images/1000d/1000dc4722993cb7b94d0703b63872fe132f8c92" alt="Creating a Suppression Rule"
Once the rule is in place the Medium and Low vulnerabilities will not be displayed in the Active Findings section and can be viewed only in the Suppressed Findings section.
data:image/s3,"s3://crabby-images/6882c/6882c6bc7dba75e4598b0a76b6f00b1a30fd77cf" alt="Suppressed Rule Enforced"
data:image/s3,"s3://crabby-images/e7fa6/e7fa6d6144819473da08a67ab8d2a1b2864f0af8" alt="Suppressed Findings"
SBOM - Configuring and Exporting
- CycloneDX 1.4
- SPDX 2.3.
- A private S3 Bucket with a bucket policy that allows Amazon Inspector to upload objects to.
- A KMS key that can be used by Amazon Inspector to encrypt the reports.
data:image/s3,"s3://crabby-images/1b926/1b9264e8f9ffd9421bfc1e13f3b8c858251d64a9" alt="Exporting SBOM"
Configuring EventBridge Rule to notify of Critical Findings
- Go to Amazon SNS Service.
- Go to Topics on the left pane and click on create Topic.
- Select Type as Standard, Name your Topic, leaving the rest as default create the topic.
- Select your Topic, click on Create Subscription, choose your protocol (for this demo we will be going ahead with Email), provide your mail address.
- Confirm the subscription in the mail that you will receive from AWS on the mentioned mail id.
data:image/s3,"s3://crabby-images/8d19f/8d19fd3940c3327849c2388b63eaa6859ea6d629" alt="SNS Topic"
Next, we will create an Amazon Eventbridge rule to detect and trigger an alert on the critical findings of Inspector.
- Go to Amazon EventBridge.
- Click on Rules in the left pane and Create Rule next.
- Provide a name to your rule and a description, then select the Rule Type as Rule with an Event Pattern and click next.
- In the Creation Method, select Custom pattern (JSON Editor)
- Enter the below snippet and click on next.
- Choose Amazon SNS as the target and select the topic you created.
- Add optional tags if needed and choose next.
- Review and click on create rule.
data:image/s3,"s3://crabby-images/16955/1695549721a66b1815c912b3aab9d30d50d2fe34" alt="Eventbridge Rule"
data:image/s3,"s3://crabby-images/8bba3/8bba3da748e8854a9b5ebe13fa77e6f051a6a7aa" alt="Email Alert"
Integrating Inspector Scans into Jenkins CI/CD Pipeline
- First one is using a plugin, currently supported CI/CD tools for the same are Jenkins, TeamCity, GitHub Actions.
- Second way is to setup a custom integration with your CI/CD solution.
You can check out the same, Inspector-Jenkins-Custom-Integration-Jenkinsfile.
data:image/s3,"s3://crabby-images/812f6/812f67c2642bf458254358d6e28a57428b7ad181" alt=""
data:image/s3,"s3://crabby-images/a2693/a2693a3c5180f5fc72d42dbd32b4ea9c70ecaa6b" alt=""