Skip to content

Latest commit

 

History

History
201 lines (156 loc) · 15.6 KB

logging-guide-windows-endpoint-logs.md

File metadata and controls

201 lines (156 loc) · 15.6 KB

Logging - Endpoint Logs

Windows

Windows Log Sources

Windows events have the ability to be exceedingly granular, but also produce more logs than we can handle. Determining the logging level is a critical first step for on-boarding windows log sources. Managing Windows logging can be easily managed by powershell commands and Group Policy Objects.

Windows Log Management

Windows Event logs are typically broken out into what windows calls "Channels" which specifies the category of Events such as Application, Security, System, etc. There are four types of channels that existing within Windows:

  • Admin - Well known events. (evtx)
  • Operational - Used for human analysis (evtx)
  • Analytic and Debug - High volume of information for the most granular of analysis. (.etl)

Windows uses audit policies to control what is logged and can easily be defined by group policy. Policies can con in a basic format or an advanced format for more granular control over your logging. Remember: when using advanced audit policies, enable "Force audit policy subcategory settings". Sometimes we will have systems that are not joined to the domain. Since group policy is not available, we can use a handy utility called auditpol.exe to remotely fetch and set audit policy settings.
Microsoft has a fantastic set of recommendations for how to set-up your audit policy. CIS also has a set of configuration recommendations that have tons of helpful detail on why their settings are recommended.

Windows Event Types

  • Account management - Used for tracking un authorized changes in the environment. Can track changes to:
    • Application Groups,
    • System Accounts
    • User Active Directory Distribution Groups
    • Security Groups
    • Account Management related events such as password change or account lockout.
  • Logon/Logoff - The primary event type for detecting credential theft and reuse.
    • Logon/logoff activity
    • Special group logons
    • Failed logins, and thier failure reason
    • Account lockouts.
  • Detailed Tracking - Next level details of endpoint activity
    • Process creation and termination
    • RPC events
    • Token rights changes
    • Plug-N-Play activity (Requires Win10/Server 2016)
    • Command-line logging (Requires manual adjustment)
  • Object Access - Event type for monitoring of network objects. Does not log all activity by default. You must place an ACL on the object or object group in order to tell the Audit Policy what to log.
    • File creation/deletion/modification
    • Registry key changes
    • Network access
    • Windows Firewall logging
    • Active Directory Objects: Users, Groups, Files, Folders, etc.
    • Certificates

Supplementary Windows logging

When Event logs are not enough

Sysmon: A Sysinternals tool that provides detailed information about process creations, network connections, and changes to file creation time. It is a wealth of information that can be used for a variety of purposes in Incident Response, Event Detection, and Threat Hunting.
Sysmon adds additional logging capabilities over standard windows event logs. It can provide logs for driver/dll loding activities, WMI monitoring, and can provide process hashes and parent processes for analysis.

Custom Powershell Log Creation: When you have a program that only outputs logs to a file, or if you have a reoccurring task that you would like to log the output from, you can use the powershell "Write-EventLog" to output the results to a log file.

Windows Log Collection

To achieve the greatest utility and flexibility, it is preferred to use a log agent over agentless collection. Windows also has a great log agent built into the platform with the Windows Event Collector.

Linux

Linux Log Sources

Syslog - The original method of logging for Linux.

  • Linux devices listen using a local socket by default
  • Syslog daemon stores in /var/log/ by default
  • Only supports UDP port 514
  • Common log files
    • /var/log/message - Global message (general activity)
    • /var/log/auth.log - Authentication related logs
    • /var/log/boot.log - Boot time events
    • /var/log/daemon.log - Background Process Events
    • /var/log/kern.log - Kernel messages (Used for trouble shooting)
    • /var/log/cron.log - Events related to scheduled tasks
    • /var/log/secure - su or sudo related events.
  • Syslog codes - These are the digits in the log files that identify both the purpose of the log and the importance.
  • Syslog Structure
    • PRI - Number that combines Severity and Faciltiy codes together. PRI= Severity + (Faciltiy*8)

Syslog-NG - Syslog enhanced

  • Created to fill in the capability gaps for original syslog
  • Adds ability to transport over TCP and SSL/TLS
  • Capable of logging higher volumes of up to 600k+ messages per second
  • Can perform custom filtering and parsing
  • Easier to use config file
  • Can send logs to multiple locations simultaneously

Rsyslog - Rocket-fast Syslog

  • As the name implies, can handle a massing 1million+ messages per second to local logging.
  • Similar in increase in function to Syslog-NG
  • Supports RELP: Reliable Event Logging Protocol
  • Uses liblognorm instead of Regex to parse

Third party logging tools

Command line and Scripting basics

In both Windows and Linux, the command line is actually an interpreter for scripting. Commands can be scripted for both the native command line utilities such as cmd.exe and Bash, as well as more powerful languages like Powershell or Python. Powershell in particular is used heavily for administrative actions within a network, as well as being used maliciously in over 38% of all incidents.

When logging command line usage and script calls it is important to understand thier common usage. Script files are used for automation and are seen being used very commonly by defenders. Defenders will often have repetitive, complex tasks that automation through a script will drastically increase their workflow. Now, all of those tasks can be put manually in the command line instead of a script, but they can be incredibly long commands. In order to bypass detection by antivirus, often times attackers will place their long commands directly into the command line or call remote code, rather than directly run a script. Remember: Antivirus cannot detect a signature, when there is no file.

Powershell Execution Policy and other security

Powershell has a built in security setting called the Execution policy. It was originally designed to prevent admins from running code they didnt intend on running. There are 4 policy settings available in Powershell.

  • Restricted - Interactive commands only. No scripts.
  • AllSigned - Permits only scripts that are digitally assigned by approved publishers
  • RemoteSigned - Permits only scripts that are signed by approved publishers or generated locally.
  • Unrestricted - Permits all scripts.

Sadly, there are quite a few ways to bypass it. That being said, you can create detections for most of these techniques. https://www.netspi.com/blog/technical/network-penetration-testing/15-ways-to-bypass-the-powershell-execution-policy/

Applocker can be used to allow or deny powershell use based on powershell itself, or particular scripts through a feature called JEA: Just Enough Administration.

Command Line Logging

Command line logging is not typically enabled by default. For windows environments, even enabled, you must take one step further in order to log the command line parameters as well.

  • Windows - Enable logging of process creations under Windows Audit Policy
    • Computer Configuration -> Policies -> Administrative Templates -> System -> Audit Process Creation.
  • Powershell
    • Event logs under Application and service logs -> Microsoft -> Windows -> "Microsoft-Windows-Powershell/Operational"
    • Module Logging - Records when a function from a module is invoked. Extremely verbose.
      • Event ID 4103 - Powershell Module Loaded
      • Requires Powershell 3.0
    • Script Block Logging - Generates a log for each block of code executed.
      • Recorded at time of execution. Data is decoded within the log. Combine with command line logging to get both the before and after data.
      • Contains extra field called Event Type. Can classify suspicious commands with a WARNING level log.
      • Event ID 4104 - Creation of Script Block
      • Event ID 4105 - Script Block Execution Start
      • Event ID 4106 - Script Block Execution Stop
      • Requires Powershell 5.0
    • Transcription Logging - Contains both the input and output, only saves to a file.

Command line key words for detection

  • Powershell
    • "/ExecutionPolicy bypass"

Reference