forked from jymcheong/FreeEDR-agents
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinstall.ps1
315 lines (224 loc) · 13.4 KB
/
install.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
function Test-Administrator
{
[OutputType([bool])]
param()
process {
[Security.Principal.WindowsPrincipal]$user = [Security.Principal.WindowsIdentity]::GetCurrent();
return $user.IsInRole([Security.Principal.WindowsBuiltinRole]::Administrator);
}
}
if(!(Test-Administrator))
{
Write-Error "This script must be executed as Administrator.";
exit;
}
if ($PSVersionTable.PSVersion.Major -lt 5)
{
Write-Error "Need Powershell 5 or above.";
exit;
}
$TARGETDIR="c:\windows\freeEDR"
$DOWNLOADDIR="$env:TEMP\freeEDR"
$INSTALLERZIP='installer.zip'
$EDRSETUPFILENAME='setup.msi'
$NXLOGFILENAME="nxlog-ce-2.10.2150.msi"
$NET46FILENAME="NDP46-KB3045557-x86-x64-AllOS-ENU.exe"
$openEdrInstallerURL='https://github.com/jymcheong/FreeEDR-agents/blob/main/installer.zip?raw=true'
$net46InstallerURL='https://download.microsoft.com/download/C/3/A/C3A5200B-D33C-47E9-9D70-2F7C65DAAD94/NDP46-KB3045557-x86-x64-AllOS-ENU.exe'
# System.Net.WebClient will fail to download if remote site has TLS1.2
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
$OPENEDR_SHA256_HASH='3AADCE34B2322ADA19AB8EC4F3F11398A6215E29D4F2C9DB2B2F92717E322D94'
$NET46_SHA256_HASH='B21D33135E67E3486B154B11F7961D8E1CFD7A603267FB60FEBB4A6FEAB5CF87'
# clear any previously downloaded installer.zip
if(Test-Path "$PSScriptRoot\$INSTALLERZIP") { Remove-Item -LiteralPath "$PSScriptRoot\$INSTALLERZIP" -Force -Recurse | Out-Null }
if(Test-Path $DOWNLOADDIR) { Remove-Item -LiteralPath $DOWNLOADDIR -Force -Recurse | Out-Null }
# Create a location to download the files to
if(Test-Path $DOWNLOADDIR) { Remove-Item -LiteralPath $DOWNLOADDIR -Force -Recurse | Out-Null }
New-Item -ItemType Directory -Force -Path $DOWNLOADDIR | Out-Null
$wc = New-Object System.Net.WebClient
# Check .NET 4.6
$net46 = $false
Get-ChildItem 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP' -recurse |
Get-ItemProperty -name Version,Release -EA 0 | ForEach-Object { if($_.Release -ge 393295) { $net46 = $true}}
if($net46 -eq $false) {
$wc.DownloadFile("https://raw.githubusercontent.com/jymcheong/FreeEDR-agents/main/install.ps1", "$DOWNLOADDIR\install.ps1")
Set-Location -Path 'HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\RunOnce'
Set-ItemProperty -Path . -Name installOpenEDR -Value "C:\WINDOWS\system32\WindowsPowerShell\v1.0\powershell.exe -noexit -executionPolicy Unrestricted -File $DOWNLOADDIR\install.ps1"
Write-Output "Downloading .NET 4.6 Standalone Installer..."
$wc.DownloadFile($net46InstallerURL, "$DOWNLOADDIR\$NET46FILENAME")
$FileHash = Get-FileHash -Path "$DOWNLOADDIR\$NET46FILENAME"
if($FileHash.Hash -ne $NET46_SHA256_HASH) { Write-Host 'Checksum failed!'; exit }
Write-Output "Installing .NET 4.6..."
Start-Process -FilePath "$env:comspec" -Verb runAs -Wait -ArgumentList "/c $DOWNLOADDIR\$NET46FILENAME"
shutdown /r /t 30
exit
}
if(!(Test-Path "$PSScriptRoot\installer.zip")){
# Download the installers...
Write-Host 'Downloading FreeEDR...'
$wc.DownloadFile($openEdrInstallerURL, "$PSScriptRoot\$INSTALLERZIP")
}
$FileHash = Get-FileHash -Path "$PSScriptRoot\$INSTALLERZIP"
if($FileHash.Hash -ne $OPENEDR_SHA256_HASH) { Write-Host 'Checksum failed!'; exit }
Write-Host "Extracting FreeEDR installers..."
[System.Reflection.Assembly]::LoadWithPartialName("System.IO.Compression.FileSystem") | Out-Null
[System.IO.Compression.ZipFile]::ExtractToDirectory("$PSScriptRoot\$INSTALLERZIP",$DOWNLOADDIR)
# uninstall if existing target directory exists
if(Test-Path $TARGETDIR) {
Invoke-Expression $wc.DownloadString('https://raw.githubusercontent.com/jymcheong/FreeEDR-agents/main/uninstall.ps1')
}
# start the installations
Set-Location $DOWNLOADDIR
Write-Output "Installing FreeEDR..."
Copy-Item -Path whitelist.ps1 -Destination C:\Windows
Start-Process -FilePath "$env:comspec" -Verb runAs -Wait -ArgumentList "/c msiexec /i $EDRSETUPFILENAME TARGETDIR=$TARGETDIR /qb /L*V FreeEDRinstall.log"
Write-Output "Installing Sysmon..."
Start-Process -FilePath "$env:comspec" -Verb runAs -Wait -ArgumentList "/c sysmon.exe -accepteula -i $DOWNLOADDIR\smconfig.xml"
if(!$standAlone) { # see https://github.com/jymcheong/OpenEDRclient/issues/12
Write-Output "Installing NXLOG-CE..."
Start-Process -FilePath "$env:comspec" -Verb runAs -Wait -ArgumentList "/c msiexec /i $NXLOGFILENAME INSTALLDIR=$TARGETDIR\nxlog /qb /L*V NXLOGinstall.log"
}
## Deploy in detectOnly mode; NO automated termination of foreign-file-backed processes
if($detectOnly) {
New-Item -ItemType Directory -Force -Path "$TARGETDIR\conf\dfpm\detectOnly" | Out-Null
}
if($capturePEfiles) {
New-Item -ItemType Directory -Force -Path "$TARGETDIR\conf\dfpm\UploadSample" | Out-Null
}
## Office Macro Configurations
$officePath = (Get-ItemProperty "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths\Winword.exe" -ErrorAction SilentlyContinue).Path
if($officePath -match 'Office(?<officeVersion>\d\d)')
{
if(!$allowMacro){
Write-Host "Found office version!"
$version = $Matches.officeVersion + ".0"
if([int]$version -lt 15) {
$regName = "VBAWarnings"
$regValue = 2
}
else {
$regName = "blockcontentexecutionfrominternet"
$regValue = 1
}
# for Word
if(!$allowWordMacro) {
# test with HKLM but doesn't work...
$regWordPath = "HKCU:\SOFTWARE\Microsoft\office\" + $version + "\Word\security"
if(!(Test-Path $regWordPath)) {
New-Item -Path $regWordPath -Force
}
New-ItemProperty -Path $regWordPath -Name $regName -Value $regValue -Force
}
# for Excel
if(!$allowExcelMacro) {
$regExcelPath = "HKCU:\SOFTWARE\Microsoft\office\" + $version + "\Excel\security"
if(!(Test-Path $regExcelPath)) {
New-Item -Path $regExcelPath -Force
}
New-ItemProperty -Path $regExcelPath -Name $regName -Value $regValue -Force
}
# for PowerPoint
if(!$allowPowerPointMacro) {
$regPowerPointPath = "HKCU:\SOFTWARE\Microsoft\office\" + $version + "\PowerPoint\security"
if(!(Test-Path $regPowerPointPath)) {
New-Item -Path $regPowerPointPath -Force
}
New-ItemProperty -Path $regPowerPointPath -Name $regName -Value $regValue -Force
}
}
}
# Download configuration
## Download the SFTP upload-destination configuration if defined
if($SFTPCONFURL) {
$wc.DownloadFile($SFTPCONFURL, "$TARGETDIR\sftpconf.zip")
}
## Update the target directory within various scheduled-task configuration files
Set-Location "$TARGETDIR\installers"
((Get-Content -path DFPM.xml -Raw) -replace 'TARGETDIR',$TARGETDIR) | Set-Content -Path DFPM.xml
((Get-Content -path UploadSchtasks.xml -Raw) -replace 'TARGETDIR',$TARGETDIR) | Set-Content -Path UploadSchtasks.xml
((Get-Content -path uatSchedTask.xml -Raw) -replace 'UATPATH',"$TARGETDIR\uat.exe") | Set-Content -Path uatSchedTask.xml
((Get-Content -path uatSchedTask.xml -Raw) -replace 'TARGETDIR',"$TARGETDIR") | Set-Content -Path uatSchedTask.xml
((Get-Content -path nxlog.conf -Raw) -replace 'TARGETDIR',"$TARGETDIR\") | Set-Content -Path "$TARGETDIR\nxlog\conf\nxlog.conf"
schtasks /Create /TN "DFPM" /XML "DFPM.xml"
if(!$standAlone) {
schtasks /Create /TN "UAT" /XML "uatSchedTask.xml"
schtasks /Create /TN "UATupload" /XML "UploadSchtasks.xml"
}
# Turn on Powershell ScriptBlockLogging
New-Item -Path "HKLM:\SOFTWARE\Wow6432Node\Policies\Microsoft\Windows\PowerShell\ScriptBlockLogging" -Force
Set-ItemProperty -Path "HKLM:\SOFTWARE\Wow6432Node\Policies\Microsoft\Windows\PowerShell\ScriptBlockLogging" -Name "EnableScriptBlockLogging" -Value 1 -Force
# Deny HTA execution, see https://github.com/jymcheong/OpenEDRclient/issues/2
cmd /c ftype HTAFile=C:\Windows\System32\notepad.exe %1
cmd /c ftype VBSFile=C:\Windows\System32\notepad.exe %1
cmd /c ftype VBEFile=C:\Windows\System32\notepad.exe %1
cmd /c ftype JSFile=C:\Windows\System32\notepad.exe %1
cmd /c ftype JSEFile=C:\Windows\System32\notepad.exe %1
cmd /c ftype WSFFile=C:\Windows\System32\notepad.exe %1
cmd /c ftype WSHFile=C:\Windows\System32\notepad.exe %1
# Start agents
if(!$standAlone) { schtasks /Run /TN "UATupload" }
schtasks /Run /TN "DFPM"
# Start log rotation
$scpath = $env:WinDir + "\system32\sc.exe"
if(!$standAlone) {
Start-Process -FilePath $scpath -Verb runAs -Wait -ArgumentList "start nxlog"
Write-Output "Started Nxlog service!"
}
else{ # otherwise network address events will fill up the directory because there is no uploading & clean-up
Start-Process -FilePath $scpath -Verb runAs -Wait -ArgumentList "stop datafusion"
Write-Output "Stopped DataFusion service!"
}
# Windows 10 Attack Surface Reduction Rules - see https://docs.microsoft.com/en-us/microsoft-365/security/defender-endpoint/attack-surface-reduction-rules-reference?view=o365-worldwide#block-win32-api-calls-from-office-macros
if (Get-Command "Set-MpPreference" -errorAction SilentlyContinue)
{
# Block executable content from email client and webmail
Set-MpPreference -AttackSurfaceReductionRules_Ids BE9BA2D9-53EA-4CDC-84E5-9B1EEEE46550 -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
# Block all Office applications from creating child processes
Set-MpPreference -AttackSurfaceReductionRules_Ids D4F940AB-401B-4EFC-AADC-AD5F3C50688A -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
# Block Office applications from injecting code into other processes
Set-MpPreference -AttackSurfaceReductionRules_Ids 75668C1F-73B5-4CF0-BB93-3ECF5CB7CC84 -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
# Block Win32 API calls from Office macros
Set-MpPreference -AttackSurfaceReductionRules_Ids 92e97fa1-2edf-4476-bdd6-9dd0b4dddc7b -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
# Block execution of potentially obfuscated scripts
Set-MpPreference -AttackSurfaceReductionRules_Ids 5BEB7EFE-FD9A-4556-801D-275E5FFC04CC -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
# Block Win32 API calls from Office macros
Set-MpPreference -AttackSurfaceReductionRules_Ids 92E97FA1-2EDF-4476-BDD6-9DD0B4DDDC7B -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
# Block credential stealing from the Windows local security authority subsystem (lsass.exe)
Set-MpPreference -AttackSurfaceReductionRules_Ids 9e6c4e1f-7d60-472f-ba1a-a39ef669e4b2 -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
# Block process creations originating from PSExec and WMI commands
Set-MpPreference -AttackSurfaceReductionRules_Ids d1e49aac-8f56-4280-b9ba-993a6d77406c -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
# Block untrusted and unsigned processes that run from USB
Set-MpPreference -AttackSurfaceReductionRules_Ids b2b3f03d-6a65-4f7b-a9c7-1c7ef74a9ba4 -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
# Block Office communication application from creating child processes
Set-MpPreference -AttackSurfaceReductionRules_Ids 26190899-1602-49e8-8b27-eb1d0a1ce869 -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
# Block Adobe Reader from creating child processes
Set-MpPreference -AttackSurfaceReductionRules_Ids 7674ba52-37eb-4a4f-a9a1-f0f9a1619a2c -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
# Block persistence through WMI event subscription
Set-MpPreference -AttackSurfaceReductionRules_Ids e6db77e5-3df2-4cf1-b95a-636979351e5b -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
# Block JavaScript or VBScript from launching downloaded executable content
Set-MpPreference -AttackSurfaceReductionRules_Ids d3e037e1-3eb8-44c8-a917-57927947596d -AttackSurfaceReductionRules_Actions Enabled -errorAction SilentlyContinue
}
# Enable 4688, 4689 & commandLine audit events
reg add HKLM\Software\Microsoft\Windows\CurrentVersion\Policies\System\Audit\ /v ProcessCreationIncludeCmdLine_Enabled /t REG_DWORD /d 1
auditpol.exe /set /subcategory:"Process Creation" /success:enable /failure:enable
auditpol.exe /set /subcategory:"Process Termination" /success:enable /failure:enable
# add custom context menu
New-PSDrive -Name HKCR -PSProvider Registry -Root HKEY_CLASSES_ROOT
$ContextCommand = "Whitelist executable file"
$command = "cmd.exe /c start """" /min powershell.exe -nologo -noninteractive -NoProfile -WindowStyle hidden -ExecutionPolicy bypass -File C:\\Windows\\whitelist.ps1 -Filename '%1'"
$contextKey = 'HKCR:\*\shell\WhitelistFile'
$commandKey = "$ContextKey\Command"
New-Item -Path $contextKey -Value $ContextCommand -Force
New-Item -Path $commandKey -Value $command
# Notify user
Add-Type -AssemblyName System.Windows.Forms
$global:balmsg = New-Object System.Windows.Forms.NotifyIcon
$path = (Get-Process -id $pid).Path
$balmsg.Icon = [System.Drawing.Icon]::ExtractAssociatedIcon($path)
$balmsg.BalloonTipIcon = [System.Windows.Forms.ToolTipIcon]::Warning
$balmsg.BalloonTipText = 'FreeEDR installation completed! System will reboot in 5 mins!'
$balmsg.BalloonTipTitle = "Attention $Env:USERNAME"
$balmsg.Visible = $true
$balmsg.ShowBalloonTip(20000)
shutdown /r /t 300
Write-Output "FreeEDR installation completed, you may close this session!"