36 lines
1.7 KiB
PowerShell
36 lines
1.7 KiB
PowerShell
# Purpose: Installs the Caldera agent on the host
|
|
|
|
If (-not (Test-Path 'C:\Program Files\cagent\cagent.exe')) {
|
|
# Add /etc/hosts entry
|
|
Add-Content "c:\windows\system32\drivers\etc\hosts" " 192.168.38.5 logger"
|
|
|
|
# Make the directory
|
|
New-Item "c:\Program Files\cagent" -type directory
|
|
|
|
# Install Visual Studio 2015 C++ Redistributable
|
|
choco install -y vcredist2015
|
|
|
|
# Download cagent and start the service
|
|
Write-Host "Downloading Caldera Agent (cagent.exe)"
|
|
$cagentPath = "C:\Program Files\cagent\cagent.exe"
|
|
$cagentConfPath = "C:\Program Files\cagent\conf.yml"
|
|
# GitHub requires TLS 1.2 as of 2/1/2018
|
|
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
|
|
(New-Object System.Net.WebClient).DownloadFile('https://github.com/mitre/caldera-agent/releases/download/v0.1.0/cagent.exe', $cagentPath)
|
|
# Ignore SSL warning for conf file download
|
|
# https://stackoverflow.com/questions/34331206/ignore-ssl-warning-with-powershell-downloadstring
|
|
[System.Net.ServicePointManager]::ServerCertificateValidationCallback = {$true} ;(New-Object System.Net.WebClient).DownloadFile('https://logger:8888/conf.yml', $cagentConfPath)
|
|
If (-not (Test-Path "$cagentConfPath" )) {
|
|
Write-Host "Caldera Agent configuration failed. Unable to retrieve config from logger"
|
|
}
|
|
Start-Process -FilePath $cagentPath -ArgumentList '--startup', 'auto', 'install' -Wait
|
|
Start-Process -FilePath $cagentPath -ArgumentList 'start' -Wait
|
|
} Else {
|
|
Write-Host "Caldera Agent is already installed. Moving on."
|
|
}
|
|
Start-Sleep 5
|
|
If ((Get-Service -name cagent).Status -ne "Running") {
|
|
throw "Caldera Agent service not running"
|
|
}
|
|
Write-Host "Cagent installation complete!"
|