This Week's/Trending Posts

Hand-Picked/Curated Posts

Most Popular/Amcache

Hand-Picked/Weekly News

The Most/Recent Articles

Daily Blog #715: Solution Saturday 1/11/25

Hello Reader,
This first week back of Sunday Fundays made me realize that I need to update the rules to account for our new times. David Nides, with the help of an AI friend, has won this week's challenge with the best entry submitted. However, for tomorrow's challenge, expect that while I appreciate the help of AI in your research, I will be expecting more human involvement in your submissions.

The Challenge:
What evidence is left behind in Azure when an attacker runs BloodHound or any derivative like SharpHound? You should document at least two scenarios:

  1. Default logging
  2. Turning on any optional logging you want to test

Your response can be a link to your own blog, an email, a document, etc. Bonus points if you point out specific indicators that can be searched for or alerted off of.

The Winning Answer:
David Nides

Here's a breakdown of the evidence left behind in Azure when an attacker runs BloodHound/SharpHound, covering both default and optional logging scenarios:

Understanding the Attack:

BloodHound and SharpHound work by querying Active Directory (AD) to map relationships between users, groups, computers, and other objects. In an Azure context, this typically means querying Azure Active Directory (Azure AD) via the Microsoft Graph API or, if AD Connect is in use, on-premises AD. The attack itself doesn't directly interact with Azure resources (like VMs or storage accounts) unless the attacker has already compromised credentials that grant them such access. The focus is on the queries made against the directory service.

Scenario 1: Default Logging

By default, Azure AD provides some logging, but it may not be granular enough to explicitly identify BloodHound/SharpHound activity. The primary logs of interest are:

  • Azure Resource Manager Activity Logs: These logs show any resource management operations, such as creation or modification of resources.
  • Azure AD Audit Logs: These logs record directory activities (sign-ins, group changes, user updates, application registrations, etc.). While they might show unusual patterns of queries (e.g., a large number of Get-AzureADUser or Get-AzureADGroupMember calls in a short timeframe), they won't specifically flag "BloodHound."
    • Limitations: Default audit logs often have limited retention and may not capture every low-level query.
  • Sign-in Logs: These detail user sign-ins/auth attempts, useful for identifying suspicious logins from unusual locations or with compromised credentials.
    • Limitations: These focus on authentication events, not subsequent data-gathering queries.

Indicators (Default Logging):

  • High volume of directory read operations: Look for a large number of Get-AzureADUser, Get-AzureADGroupMember, or Get-AzureADServicePrincipal calls from one source in a short time.
  • Unusual application access: If SharpHound uses a registered application (service principal), check logs for unexpected patterns by that application.
  • Sign-ins from unusual locations: Analyze sign-in logs for unexpected IPs or geographies.

Scenario 2: Optional Logging (Recommended)

For more detailed insights and detection, enable or use:

  • Diagnostic Settings for Azure AD: Configure these to send Azure AD audit logs and sign-in logs to a Log Analytics workspace, Event Hub, or storage for advanced analysis.
  • Microsoft Graph API Audit Logs: If supported by your license, these logs provide the most granular view of Graph API calls (ideal for detecting SharpHound).
  • Azure Advanced Threat Protection (ATP) / Microsoft Defender for Identity: Provides alerts/logs for suspicious activities like lateral movement or reconnaissance.
  • Azure Security Center (Defender for Cloud): Offers a unified view of security alerts and recommendations.
  • Azure Monitor / Sentinel: Aggregates logs and allows custom queries/detections for enumeration activities.

Indicators (Optional Logging):

  • Specific Graph API queries: Look for /users/{id}/memberOf, /groups/{id}/members, etc.
  • Large numbers of requests: A sudden spike to Graph API endpoints suggests enumeration.
  • User agent strings: Can reveal known SharpHound signatures (though attackers may spoof).
  • Unusual sign-in patterns: Sign-ins from unknown locations or devices deviating from normal user behavior.
  • Excessive directory queries: A high volume of read-based requests can indicate reconnaissance.
  • Changes to directory roles/groups: Any unexpected role or group membership changes might indicate privilege escalation attempts.
  • Alerts from Azure ATP/Security Center/Sentinel: Check these products for out-of-the-box or custom detection rules that spot enumeration behavior.

Sample KQL for Detection:

AuditLogs
| where OperationName has "Get-AzureADGroupMember"
| summarize count() by CallerIpAddress, UserDisplayName, TimeGenerated
| where count_ > 100
| render table

Key Takeaways:

  • Default logging is limited. Enable diagnostic settings and centralize logs for better visibility.
  • Detect enumeration via patterns of directory queries rather than a specific "BloodHound" signature.
  • Graph API audit logs (when available) are your best bet for catching SharpHound usage.
  • Correlate logs with other security signals (threat intel, endpoint alerts, etc.) for a fuller defense.

Daily Blog #714: Forensic Lunch 1/10/25 with Ryatt Roesrma talking about fine tuning AI models

The Forensic Lunch is Back! 🍴

Hello Readers,

I'm excited to announce that The Forensic Lunch is back with another episode! This week, we had the privilege of hosting Wyatt Roersma, who shared his insights on training open-source AI models for specialized tasks.

Wyatt has been exploring how to take open-source AI models, like Qwen-2.5, and train them using examples such as YARA rules and targeted prompts to enhance their usefulness for specific applications. In the episode, he walks us through the process step-by-step, empowering you to apply similar techniques to solve your unique challenges.

For instance, I'm currently experimenting with getting AI models to write dfvfs code. While the models are fairly accurate, I believe with a bit of fine-tuning and additional training, they could become even more precise and reliable.

Key Resources from Wyatt's Discussion

Here are some invaluable links to help you dive deeper into the topics discussed in the episode:

Watch the Episode

You can catch the full episode below and learn how to start training your own open-source AI models to tackle specialized problems:



Or click the link here:
https://www.youtube.com/live/z6QkYHo97k0

Daily Blog #713: Developing an AWS Examination Tool Part 4

 Hello Reader,

       Development continues! What all did we do today? Well here is the automated commit message the model made for me:

Enhance AWS Enumerator Tool with Lambda and Gateway Resource Support

- Added functionality to enumerate and display AWS Lambda functions, including details such as runtime, memory, timeout, and VPC configuration.
- Implemented scanning for Internet and NAT Gateways, capturing their state, type, and associated VPCs.
- Introduced a new Network Security tab in the GUI for analyzing security configurations across accounts, including security groups and network ACLs.
- Updated README.md to reflect new features and permissions required for Lambda and Gateway resource access.
- Improved error handling and progress tracking during resource scans.

This commit significantly enhances the AWS Enumerator Tool's capabilities for managing and analyzing AWS resources.


Tomorrow is the Forensic Lunch make sure to tune in!

Daily Blog #712: Developing an AWS Examination Tool Part 3

 


Hello Reader,

Today, I went down a rabbit hole of prompting and ended up adding a ton of new features to our application. Here’s what the latest version now includes:

New Features:

  • AWS Organization Scanning: Detects other AWS accounts in the organization of the accessed account.
  • Cross-Account Role Assumption: Verifies if the account key can assume the AWS Organizations role to enumerate other accounts.
  • Parallel Region Scanning: Uses multiprocessing to scan all regions simultaneously for every accessible account.
  • CloudTrail Logs: Identifies CloudTrail logs in each account and displays their locations in a dedicated GUI tab. Also checks if they are only stored by AWS (default storage).
  • VPC Flow Logs: Lists VPC Flow logs in a separate GUI tab, showing where they are stored.
  • EC2 Metadata: Adds detailed metadata for EC2 instances, snapshots, and EBS volumes.
  • CloudWatch Log Groups: Provides support for CloudWatch Log groups.
  • Lightsail Instances: Adds enumeration support for Lightsail instances.

A Different Approach:

Rather than listing the many individual prompts I used to add these features (and the iterative process of fixing errors), I decided to take a new approach. I asked the model to create a single prompt that could recreate the current state of this program. Here's what it generated:


Generated Prompt

Create a Python-based GUI application for enumerating AWS resources across multiple accounts and regions. The application should have the following specifications:

Core Requirements:

  1. GUI Framework:

    • Use PySide6 for the interface.
    • Include a tabbed layout for different resource types.
    • Show real-time progress with progress bars.
    • Provide a resource tree view for navigation.
    • Include a log window for status messages.
  2. AWS Integration:

    • Support both AWS profile and direct API key authentication.
    • Enable AWS Organizations support for multi-account scanning.
    • Implement cross-account role assumption.
    • Use boto3 with retry logic and error handling.
    • Support parallel processing of regions.
  3. Resource Types to Enumerate:

    • EC2 Resources:
      • Instances (metadata: type, IPs, key name, platform).
      • Volumes (size, type, encryption, IOPS).
      • Snapshots (size, source, encryption).
      • Security groups.
    • Storage:
      • S3 buckets (with region mapping).
      • EBS volumes (with attachments).
    • Database:
      • RDS instances.
      • Lightsail databases.
    • Logging & Monitoring:
      • CloudTrail configurations.
      • CloudWatch Log Groups.
      • VPC Flow Logs.
      • Organization-wide logging detection.
  4. Data Export:

    • Support for exporting in Excel, JSON, or text format.
    • Include metadata and a hierarchical structure in the export.
    • Use the AWS Account ID and timestamp as the default filename for uniqueness.
  5. Progress Tracking:

    • Display overall, per-account, and region-specific progress.
    • Show status messages for operations.

Technical Specifications:

  1. Multiprocessing:

    • Use Python’s multiprocessing to handle parallel region scanning.
    • Implement proper process cleanup and progress communication.
  2. Error Handling:

    • Implement exponential backoff for API calls.
    • Handle permission issues gracefully.
    • Display clear error messages in the GUI.
  3. Security:

    • Ensure secure credential handling.
    • Support AWS profiles and direct API key input.
    • Implement minimum required permissions.
  4. GUI Features:

    • Tab-based views for resource types (EC2, storage, database, logging).
    • Progress dialogs with multiple progress bars.
    • Resource tree view for navigation.
    • Color-coded status indicators.
  5. Dependencies:

    • boto3/botocore: AWS SDK.
    • PySide6: GUI framework.
    • pandas: Data handling.
    • openpyxl: Excel export.
  6. File Structure:

    • aws_enumerator.py: Main application.
    • requirements.txt: Dependency list.
    • README.md: Project documentation.
    • License file.

Progress So Far:

The best part? I still haven’t written a single line of code myself! The application now has a polished interface and works as described. I've also updated the README file and requirements.txt, so everything is ready for you to try.



 

You can check out the latest version and give it a spin here:
AWSExaminer GitHub Repository

Stay tuned for more updates as we continue building!



Daily Blog #711: Developing an AWS Examination Tool Part 2

 

 



Hello Reader,

Today, we're making progress on our feature wishlist by tackling several key enhancements:

  1. Selecting Credentials: Currently, it defaults to my AWS profile for FOR509.
  2. Adding Support for Global Views.
  3. Exporting Inventory.

Step 1: Selecting Credentials

We began by addressing the first feature with the following prompt:

"Prior to enumerating the AWS account, provide a GUI pop-up that asks how the user wants to authenticate to AWS. Options should include:

  1. Profile in the creds file
  2. An API key provided by the user

If the user selects a profile, they should see a dropdown of available profiles in the creds file to choose from. If they opt to provide an API key, the system should offer a checkbox to store the key with the collection for easy reuse."

This resulted in an error when I ran the Python code. You might think, "Aha! Your lazy adventure ends here—time to fix the code yourself!" But not so fast, dear reader. Instead, I highlighted the error and prompted:

"I got this error."

After resolving two more errors using the same prompt, the model managed to fix itself, and I got the GUI functionality I wanted. Now I can either provide a key or choose from any profiles already stored within the AWS CLI.


 


Step 2: Progress Bars

Next, I wanted to add a progress bar to keep users informed during the enumeration process. Here's how I tackled it:

  1. First Prompt:

    "Add a GUI progress window that updates as the account is enumerated so the user knows what is happening."

    This worked, but I wanted more. Since enumerating each region can take time, I added a secondary prompt:

  2. Second Prompt:

    "Add a second progress bar for each region, showing what is being enumerated."

This introduced a new issue—the progress window popped up but displayed no updates. I informed the model:

"The progress window popped up, but there were no updates displayed."

The model refactored the code to enable real-time GUI updates while enumeration was running. Voilà! A neat dual-progress bar system was now functional.


 


Step 3: Region Resource Count

To enhance the user experience further, I requested:

"Add a number next to each listed region summarizing how many resources were found in that region."

This worked beautifully, providing a clear overview of resource counts per region.


 


Step 4: Exporting Inventory

For the final item on today's list, I wrote a more detailed prompt:

"Create a toolbar option called 'Export.' When selected, it should open a dialog asking the user to save the output in one of three formats: text (as displayed), JSON, or XLSX. After selecting the format, present a window to choose a save location and filename. The default filename should include the AWS Account ID and the current timestamp, keeping it unique with the chosen extension. Then export all regions' data to the selected file."

This feature worked on the very first attempt! The code automatically added pandas and openpyxl packages to support Excel output.


 


Step 5: Finishing Touches

To wrap things up, I asked the model to create essential project files:

  1. Requirements File:

    "Create a requirements.txt file with all the necessary packages."

  2. GitHub README:

    "Create a README file in Markdown syntax that describes the project, how to install it, how to execute it, and includes an Apache 2 license."

Finally, I pushed the project to its new repository using Cursor for direct linking. You can explore it here: AWSExaminer GitHub Repository.


Conclusion

This project is shaping into a useful tool for my AWS cases. The best part? I haven’t had to write a single line of code or look up all the APIs I'm using. Rest assured, I’ll be testing thoroughly to catch any quirks the AI might have introduced.

Stay tuned for tomorrow’s update, where we’ll add even more features!


Daily Blog #710: Developing an AWS Examination Tool Part 1

 

 


Hello Reader, 
           I've been really enjoying creating forensic tools with cursor (an AI extended version of Visual Studio Code). While I'm not ready to show my main pet project, an open source clone of FTK Imager, I thought it would be fun to start a series of making a smaller tool with a much more well known API. I've found that the more well known the API is and the more example code the model has ingested the better the results are. That's not to say that less known APIs won't work well, I have it working with dfvfs, but more that it does take more work to get it to find the right examples to work with. 


For this example I've installed cursor and given it a small series of prompts:

"We are going to create a tool to assist forensic examiners and incident responders with investigating AWS accounts. You will create a tool that when provided with AWS credentials will enumerated all of the regions and the resources within them. The code should be written in python"

 

This created the first part of the script. 

 

The next prompt 

"Add on a QT GUI written in Pyside6, the top left pane should be a list of regions and when one is selected it displays the resources within it in the top right pane. The bottom pane should be a log of actions taken. There should be a region labeled ALL that allows all regions to be selected and displayed at once."

 

And now I have a working tool that is enumerating some AWS resources:



You can view the code here: https://github.com/dlcowen/AWSEnumerator

In the next series of posts I'm going to extend the functionality:

1. Selecting what credentials to use, this is defaulting to my default AWS profile for FOR509

2. Include more AWS services

3. Add in support for global views

4. Exporting out the inventory

5. Extracting cloudwatch logs

6. Extracting cloudtrail logs

7. Exporting snapshots 

8. Creating snapshots

9. Exporting lambda functions

10. Enumerating organizations 

11. Exporting flows






Daily Blog #709: Sunday Funday 1/5/25 Entra ID and Bloodhound

 



Hello Reader,

Welcome back to Sunday Funday! This week we are going straight in to topics I see as current research blind spots. We are going to be focusing on Entra ID aka Azure AD and what evidence you can find when people run tools like Bloodhound/Sharphound. I look forward to your thorough responses as we work as a community to overcome lack of knowledge. 


The Prize:

$100 Amazon Giftcard
An apperance on the following week's Forensic Lunch!

The Rules:

  1. You must post your answer before Friday 1/10/25 7PM CST (GMT -5)
  2. The most complete answer wins
  3. You are allowed to edit your answer after posting
  4. If two answers are too similar for one to win, the one with the earlier posting time wins
  5. Be specific and be thoughtful
  6. Anonymous entries are allowed, please email them to dlcowen@gmail.com. Please state in your email if you would like to be anonymous or not if you win.
  7. In order for an anonymous winner to receive a prize they must give their name to me, but i will not release it in a blog post


The Challenge:

What evidence is left behind in Azure when an attacker runs Bloodhound or any derivative like Sharphound. You should document at least two scenarios:
1. Default logging
2. Turning on any optional logging you want to test. 

Your response can be a link to your own blog, an email, a document etc.. Bonus points if you point out specific indicators that can be searched for or alerted off of. 

Daily Blog #708: Zeltser Challenge Spotlight - Oleg Skulkin

        -+



 

Hello Reader,

Several other people have joined the Zelster challenge with me and its been great reading what they've been putting out. I thought it would be great today to spotlight one of them, Oleg Skulkin. 

I've been following Oleg's work for many years now and have always enjoyed what he's written in the past, so it wasn't a surprise when I found his new blog Know Your Adversary to be just as good. In just the first four posts of the year Oleg has already put out some great posts and shared some valuable insights. If you've been reading my blog for a long time (817 posts in total as of this blog) then you should check out Oleg's as well. 


I'll be tracking and highlighting other challenge participants through the year! 


Speaking of challenges, tomorrow is Sunday! The Sunday Funday Challenge returns and I look forward to seeing what you all can do!