Cyber security

GPOHunter – Active Directory Group Policy Security Analyzer

GPOHunter is a comprehensive tool designed to analyze and identify security misconfigurations in Active Directory Group Policy Objects (GPOs).

It automates security checks and provides detailed reports on potential vulnerabilities, helping administrators secure their environments.

Features

  • Connects to Active Directory using LDAP/LDAPS protocols.
  • Supports NTLM authentication and Pass-the-Hash techniques.
  • Analyzes all GPOs within the domain.
  • Identifies and reports security misconfigurations.
  • Displays affected organizational units (OUs) and objects.
  • Offers multiple output formats: JSON, CSV, and HTML.
  • Provides an option to view detailed XML content of GPO files.

Security Checks

Currently, GPOHunter implements the following security checks:

  1. Clear Text Password Storage
    • Detects the “ClearTextPassword = 1” setting in GPOs.
    • This setting allows passwords to be stored in unencrypted form, posing a critical security risk by exposing credentials.
  2. GPP Passwords (MS14-025)
    • Identifies encrypted passwords within Group Policy Preferences.
    • Examines various GPP files such as Groups.xml, Services.xml, and others.
    • These passwords are encrypted with a known key and can be easily decrypted using public information.
  3. NetNTLMv1 Authentication Enabled
    • Detects insecure LmCompatibilityLevel settings.
    • Identifies GPOs that enable NetNTLMv1, which is vulnerable to:
      • Relay attacks when combined with Coerce.
      • Password cracking using rainbow tables.

Future Development

The list of security checks will be continuously expanded with additional checks and verifications.

Usage

To run GPOHunter, use the following command:

python gpo_analyzer_cli.py -u USERNAME -p PASSWORD -d DOMAIN -dc DC_HOST [options]

Options:

  • -H, --hash: NTLM hash for Pass-the-Hash.
  • -o, --output: Path to the output file.
  • -f, --format: Output format (json, csv, html).
  • -v, --verbose: Verbose output.
  • --show-xml: Show raw XML content of GPO files.

Requirements

  • Python 3.7+
  • ldap3
  • impacket
  • colorama
  • pycryptodome

Installation

Clone the repository. Install the required packages:

pip install -r requirements.txt

Varshini

Varshini is a Cyber Security expert in Threat Analysis, Vulnerability Assessment, and Research. Passionate about staying ahead of emerging Threats and Technologies.

Recent Posts

Bash Scripting Best Practices Every Beginner Should Know

Introduction Bash scripting is a powerful way to automate Linux tasks, but writing a script…

1 day ago

How To Create A Self-Signed SSL Certificate Using Bash And OpenSSL

Introduction A self-signed SSL certificate is a certificate that is created and signed by the…

1 day ago

How To Debug Bash Scripts Using bash -x And set Commands

Introduction Debugging is an important part of Bash scripting. When a script does not work…

1 day ago

How To Use Cron Jobs With Bash Scripts For Automation

Introduction Cron jobs are used in Linux to run commands or Bash scripts automatically at…

1 day ago

How To Use Pipes In Bash Scripts For Command Chaining

Introduction Pipes are an important feature in Linux and Bash scripting. A pipe allows you…

1 day ago

How To Use grep, awk, And sed In Bash Scripts

Introduction The grep, awk, and sed commands are powerful text-processing tools in Linux. They are…

1 day ago