- 
      
- 
        Save gwsales/0fd6b49ef06a4e4630893135af0ff747 to your computer and use it in GitHub Desktop. 
    Windows batch file to deploy Sysmon using a startup script via GPO
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | @echo off | |
| :: Author: Ryan Watson | |
| :: Twitter: @gentlemanwatson | |
| :: Version: 1.0 | |
| :: Credits: Credit to Syspanda.com and their Sysmon GPO article for the kick off point | |
| :: https://www.syspanda.com/index.php/2017/02/28/deploying-sysmon-through-gpo/ | |
| :: ** IMPORTANT ** | |
| :: 1) Create a Sysmon folder with the SYSVOL share on your domain controller | |
| :: 2) Download Sysmon from Microsoft and place both sysmon.exe and sysmon64.exe in | |
| :: newly created Sysmon folder | |
| :: 3) Download a sample sysmon config from SwiftOnSecurity, rename the file to | |
| :: sysmonConfig.xml and place it within the Sysmon folder | |
| :: 4) Enter the appropriate values for your DC and FQDN below. | |
| :: 5) Create a GPO that will launch this batch file on startup. | |
| :: 6) Apply the GPO to your specified OUs. | |
| :: | |
| :: Note: It is recommended that the Sysmon binaries and the Sysmon config file | |
| :: be placed in the sysvol folder on the Domain Controller. The goal | |
| :: being that the computers can read from the folder, but no one except for | |
| :: domain admins have the ability to write to the folder hosting the files. | |
| :: Otherwise this will be a great way for attackers to escalate privs | |
| :: in the domain. You have been warned. | |
| :: Enter the full name of the domain controller, and FQDN for the domain. | |
| :: Be EXTEREMLY careful of spaces!! | |
| :: Example: DC=dc.corp.local | |
| :: Example: FQDN=corp.local | |
| SET DC= | |
| SET FQDN= | |
| :: Determine architecture to set Arch Type for the SYSMON Binary | |
| IF EXIST "C:\Program Files (x86)" ( | |
| SET BINARCH=Sysmon64.exe | |
| SET SERVBINARCH=Sysmon64 | |
| ) ELSE ( | |
| SET BINARCH=Sysmon.exe | |
| SET SERVBINARCH=Sysmon | |
| ) | |
| SET SYSMONDIR=C:\windows\sysmon | |
| SET SYSMONBIN=%SYSMONDIR%\%BINARCH% | |
| SET SYSMONCONFIG=%SYSMONDIR%\SysmonConfig.xml | |
| SET GLBSYSMONBIN=\\%DC%\sysvol\%FQDN%\Sysmon\%BINARCH% | |
| SET GLBSYSMONCONFIG=\\%DC%\sysvol\%FQDN%\Sysmon\sysmonConfig.xml | |
| sc query "%SERVBINARCH%" | Find "RUNNING" | |
| If "%ERRORLEVEL%" EQU "1" ( | |
| goto startsysmon | |
| ) | |
| :installsysmon | |
| IF Not EXIST %SYSMONDIR% ( | |
| mkdir %SYSMONDIR% | |
| ) | |
| xcopy %GLBSYSMONBIN% %SYSMONDIR% /y | |
| xcopy %GLBSYSMONCONFIG% %SYSMONDIR% /y | |
| chdir %SYSMONDIR% | |
| %SYSMONBIN% -i %SYSMONCONFIG% -accepteula -h md5,sha256 -n -l | |
| sc config %SERVBINARCH% start= auto | |
| :updateconfig | |
| xcopy %GLBSYSMONCONFIG% %SYSMONCONFIG% /y | |
| chdir %SYSMONDIR% | |
| %SYSMONBIN% -c %SYSMONCONFIG% | |
| EXIT /B 0 | |
| :startsysmon | |
| sc start %SERVBINARCH% | |
| If "%ERRORLEVEL%" EQU "1060" ( | |
| goto installsysmon | |
| ) ELSE ( | |
| goto updateconfig | |
| ) | 
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment