If you want to log every single powershell command, run on your machine , including the ones run through C# code, one way to do it is to upgrade to powershell 5.
Once you install powershell 5 all you need to do is to update a registry key to turn it on
HKLM:\Software\Policies\Microsoft\Windows\PowerShell\Transcription
Here is the powershell script to do this
Once you install powershell 5 all you need to do is to update a registry key to turn it on
HKLM:\Software\Policies\Microsoft\Windows\PowerShell\Transcription
Here is the powershell script to do this
function Enable-PSTranscription
{
[CmdletBinding()]
param(
$OutputDirectory,
[Switch] $IncludeInvocationHeader
)
## Ensure the base path exists
$basePath = "HKLM:\Software\Policies\Microsoft\Windows\PowerShell\Transcription"
if(-not (Test-Path $basePath))
{
$null = New-Item $basePath –Force
}
## Enable transcription
Set-ItemProperty $basePath -Name EnableTranscripting -Value 1
## Set the output directory
if($PSCmdlet.MyInvocation.BoundParameters.ContainsKey("OutputDirectory"))
{
Set-ItemProperty $basePath -Name OutputDirectory -Value $OutputDirectory
}
## Set the invocation header
if($IncludeInvocationHeader)
{
Set-ItemProperty $basePath -Name EnableInvocationHeader -Value 1
}
}
Enable-PSTranscription -OutputDirectory 'C:\PowershellLogs'
To enable more detailed logging run this powershell command below after you performed the above steps
function Enable-PSScriptBlockLogging
{
$basePath = "HKLM:\Software\Policies\Microsoft\Windows\PowerShell\ScriptBlockLogging"
if(-not (Test-Path $basePath))
{
$null = New-Item $basePath –Force
}
Set-ItemProperty $basePath -Name EnableScriptBlockLogging -Value "1"
}
Enable-PSScriptBlockLogging
To enable more detailed logging run this powershell command below after you performed the above steps
function Enable-PSScriptBlockLogging
{
$basePath = "HKLM:\Software\Policies\Microsoft\Windows\PowerShell\ScriptBlockLogging"
if(-not (Test-Path $basePath))
{
$null = New-Item $basePath –Force
}
Set-ItemProperty $basePath -Name EnableScriptBlockLogging -Value "1"
}
Enable-PSScriptBlockLogging