PSFRedirect.psm1

#Region '.\Public\Disable-PFSRedirect.ps1' -1

# if ($ENV:PSFREDIRECT -in ('FALSE','DISABLED')) {

# Remove-Item Alias:'Write-Verbose'
# Remove-Item Alias:'Write-Debug'
# Remove-Item Alias:'Write-Warning'
# Remove-Item Alias:'Write-Error'
# Remove-Item Alias:'Write-Host'
# Remove-Item Alias:'Write-Output'
# Remove-Item Alias:'Write-Progress'
# Remove-Item Alias:'Out-Host'
# }
#EndRegion '.\Public\Disable-PFSRedirect.ps1' 12
#Region '.\Public\Enable-PSFRedirect.ps1' -1

function Enable-PSFRedirect {
    if (-not $ENV:PSFREDIRECT)   { Update-EnvironmentVariable -VariableName PSFRedirect   }
    if (-not $ENV:PSFRemotePath) { Update-EnvironmentVariable -VariableName PSFRemotePath }

    if (-not (Get-Alias Write-Warning -ErrorAction SilentlyContinue)) {
        Microsoft.PowerShell.Utility\Write-Warning -Message 'All Write commands are being redirected to Write-PSFMessage'

        Set-Alias Write-Information -Value Write-MyInformation  -Scope Global
        Set-Alias Write-Verbose     -Value Write-MyVerbose      -Scope Global
        Set-Alias Write-Debug       -Value Write-MyDebug        -Scope Global
        Set-Alias Write-Warning     -Value Write-MyWarning      -Scope Global
        Set-Alias Write-Error       -Value Write-MyError        -Scope Global
        Set-Alias Write-Host        -Value Write-MyHost         -Scope Global
        Set-Alias Write-Output      -Value Write-MyOutput       -Scope Global
        Set-Alias Write-Progress    -Value Write-MyProgress     -Scope Global
        Set-Alias Write-Eventlog    -Value Write-MyEventlog     -Scope Global
        Set-Alias Out-Host          -Value Out-MyHost           -Scope Global

    }# end if module exists

    $CurrentUser = [System.Security.Principal.WindowsIdentity]::GetCurrent()
    $Principal  = New-Object System.Security.Principal.WindowsPrincipal($CurrentUser)
    $IsAdmin    = $Principal.IsInRole([System.Security.Principal.WindowsBuiltInRole]::Administrator)

    $ThisProfile = $PROFILE
    
    if ($IsAdmin) {# use global pwsh profile
            $ThisProfile = $PROFILE.AllUsersAllHosts
    }


    if ($ThisProfile -and
        $ENV:PSFREDIRECT -in ('TRUE','ENABLED')) {# add module-import to profile
        
        if (-not (Test-Path $ThisProfile)) {# create profile file
            New-Item $ThisProfile -ItemType File -Force | Out-Null
        }
        
        if (-not (Select-String $ThisProfile -Pattern 'Enable-PSFRedirect')) {# if needed
            'Enable-PSFRedirect' | Out-File $ThisProfile -Append -Encoding utf8
        }
    }

    if ($ThisProfile -and
        $ENV:PSFREMOTEPATH) {# add start logging to profile

        Microsoft.PowerShell.Utility\Write-Warning -Message "All Write commands for process ($PID) are being logged to $($ENV:PSFRemotePath)"
        
        New-Item  $ENV:PSFRemotePath -ItemType Directory -ErrorAction SilentlyContinue
        if (-not (Test-Path $ENV:PSFRemotePath)) {
            Microsoft.PowerShell.Utility\Write-Warning -Message 'Issue with using folder in $ENV:PSFRemotePath variable.'
        }

        Start-PSFRemoteLogging -FolderPath $ENV:PSFRemotePath
    }

<#
.SYNOPSIS
    Enables redirection of all Write-commands of PowerShell to use Write-PSFMessage.
 
.DESCRIPTION
    Enables redirecting all Write-commands of PowerShell to use Write-PSFMessage of the
    module PSFramework such as Write-Verbose, Write-Host, Write-Output etc.
 
.NOTES
    To configure your environment to always redirect Write-messages to Write-PSFMessage,
    set the machine environment variable %PSFREDIRECT% to 'TRUE' or 'ENABLED'.
 
    Running this as admin will enable redirection for all PowerShell user profiles.
 
    If you'd like to get a logfile of the output in an additional place besides the
    PSFRamework default, create the %PSFREMOTEPATH% environment variable and add
    the folder path where you want all your log files to e saved.
 
.EXAMPLE
    Enable-PSFRedirect
 
    Will active redirection for this sessesion.
 
.EXAMPLE
    [System.Environment]::SetEnvironmentVariable('PSFRedirect','True','Machine')
    Update-EnvironmentVariable -VariableName PSFRedirect
 
    Enable-PSFRedirect
 
    Will activate redirection for this session and configure your $PROFILE to always
    enable PSF redirect.
 
    If run as admin, the global $PROFILE will be set to pre-load PSFRedirect instead.
 
.EXAMPLE
    [System.Environment]::SetEnvironmentVariable('PSFRedirect','True','Machine')
    Update-EnvironmentVariable -VariableName PSFRedirect
 
    [System.Environment]::SetEnvironmentVariable('PSFRemotePath', '\\MySrv\MyShare\logfolder','Machine')
    Update-EnvironmentVariable -VariableName PSFRemotePath
 
    Enable-PSFRedirect
 
    Will add a logfile at \\MySrv\MyShare\logfolder
 
#>


}#end function Enable-PSFRedirect
#EndRegion '.\Public\Enable-PSFRedirect.ps1' 105
#Region '.\Public\Out-MyHost.ps1' -1

function Out-MyHost {
    [CmdletBinding()]
    param (
        [Parameter(ValueFromPipeline)]
        [psobject[]]$InputObject,
        [switch]$Paging
    )

    begin {
        $Caller = (Get-PSCallStack)[1].Command

    }

    process {
        Microsoft.PowerShell.Core\Out-Host @PSBoundParameters

        Write-PSFMessage -Level InternalComment -Message $InputObject -Tag 'Out-Host' -Function $Caller
    }

<#
 
.ForwardHelpTargetName Microsoft.PowerShell.Core\Out-Host
.ForwardHelpCategory Cmdlet
 
#>

}# end function
#EndRegion '.\Public\Out-MyHost.ps1' 27
#Region '.\Public\Start-PSFRemoteLogging.ps1' -1

function Start-PSFRemoteLogging {
    [CmdletBinding()]
    param (
        [Parameter(Mandatory, Position = 0)]
        [string]$FolderPath
    )

    if (-not (Get-Module PSFramework)) {
        throw 'Module PSFramework missing'
    }
    

    $param = @{
        Name        = 'logfile'
        InstanceName = 'Remote'
        FilePath    = "$FolderPath/PSF_%ComputerName%_%ProcessId%.log"
        FileType    = 'CSV'
        Enabled     = $true
        Wait        = $true
    }
    Set-PSFLoggingProvider @param
<# ! Test below doesn't wait for LoggingProvider
    if (-not (Test-Path "$FolderPath\PSF_%ComputerName%_%ProcessId%.log")) {
        throw "Failed to create PSFramework log file at remote $FolderPath"
    }
 #>

<#
.SYNOPSIS
    Defines a log file for PSFramework to use at a remote location.
 
.DESCRIPTION
    Defines the logfile LoggingProvider of PSFRamework when an instance named Remote
    with a filepath using the name PSF_%ComputerName%_%ProcessId%.log
 
    By always using PFS_*.log you can easaly set up file specific parsing rules in
    your favorite log viewer tool.
 
.NOTES
    The account starting the PowerShell session needs write permission at the share.
 
    PSFramework do support setting up persistent log file definitions, but I didn't had
    the time to figure at a working syntax.
 
.EXAMPLE
    Start-PSFRemoteLoging -FolderPath \\srv1\logshare\logfolder
     
#>


}
#EndRegion '.\Public\Start-PSFRemoteLogging.ps1' 50
#Region '.\Public\Update-EnvironmentVariable.ps1' -1

function Update-EnvironmentVariable {
    [CmdletBinding()]
    param (
        [Parameter(Mandatory, Position = 0)]
        [string]$VariableName
    )

    $MachineValue   = [System.Environment]::GetEnvironmentVariable($VariableName, 'Machine')
    $UserValue      = [System.Environment]::GetEnvironmentVariable($VariableName, 'User')

    if ($MachineValue)  { $ThisValue = $MachineValue    }
    if ($UserValue)     { $ThisValue = $UserValue       } #User Overrides

    if ($ThisValue)     { Set-Item ENV:$VariableName -Value $ThisValue }

<#
.SYNOPSIS
    Updates content of an Environment variable
 
.DESCRIPTION
    Setting the machine or user envrionement variable within a PowerShell session
    won't update the $ENV used within that session (or even within a user session).
 
    This function iterates over both System and User environments and updates the
    $ENV:-value within the current session.
 
.EXAMPLE
    $ENV:MyVar = 'Initial Example'
    [System.Environment]::SetEnvironmentVariable('MyVar', 'System Example', 'Machine')
 
    Update-EnvironmentVariable -VariableName 'MyVar'
 
    Sets $ENV:MyVar to the value of the System variable for MyVar.
 
.EXAMPLE
    $ENV:MyVar = 'Initial Example'
    [System.Environment]::SetEnvironmentVariable('MyVar', 'User Example', 'User')
    [System.Environment]::SetEnvironmentVariable('MyVar', 'System Example', 'Machine')
 
    Update-EnvironmentVariable -VariableName 'MyVar'
 
    Sets $ENV:MyVar to the value of the User variable for MyVar.
 
#>


}
#EndRegion '.\Public\Update-EnvironmentVariable.ps1' 47
#Region '.\Public\Write-MyDebug.ps1' -1

function Write-MyDebug {
    [CmdletBinding()]
    param (
        [Parameter(Mandatory, Position = 0)]
        [String]$Message
    )
    $Caller = (Get-PSCallStack)[1].Command

    Write-PSFMessage -Level Debug -Message $Message -Tag 'Write-Debug' -Function $Caller

<#
 
.ForwardHelpTargetName Microsoft.PowerShell.Utility\Write-Debug
.ForwardHelpCategory Cmdlet
 
#>


}# end function Write-MyDebug
#EndRegion '.\Public\Write-MyDebug.ps1' 19
#Region '.\Public\Write-MyError.ps1' -1

function Write-MyError {
    [CmdletBinding(DefaultParameterSetName = 'Message')]
    param (
        [Parameter(ParameterSetName = 'Message')]
        [System.Management.Automation.ErrorCategory]$Category,

        [string]$CategoryActivity,

        [string]$CategoryReason,

        [string]$CategoryTargetName,

        [string]$CategoryTargetType,

        [Parameter(ParameterSetName = 'Message')]
        [Parameter(ParameterSetName = 'Exception')]
        [string]$ErrorId,

        [Parameter(ParameterSetName = 'ErrorRecord', Mandatory)]
        [System.Management.Automation.ErrorRecord]$ErrorRecord,

        [Parameter(ParameterSetName = 'Exception', Mandatory)]
        [Exception]$Exception,

        [Parameter(ParameterSetName = 'Exception')]
        [Parameter(ParameterSetName = 'Message', Position = 0)]
        [string]$Message,

        [string]$RecommendedAction,

        [Parameter(ParameterSetName = 'Exception')]
        [Parameter(ParameterSetName = 'Message')]
        [Object]$TargetObject
    )
    $Caller = (Get-PSCallStack)[1].Command

    Microsoft.PowerShell.Utility\Write-Error @PSBoundParameters

    $LogMessage = "$ErrorRecord - $Exeption"
    if ($Message) {
        $LogMessage = "$ErrorRecord - $Exeption - $Message"
    }

    Write-PSFMessage -Level Error -Message $LogMessage -Tag 'Write-Error' -Function $Caller

<#
 
.ForwardHelpTargetName Microsoft.PowerShell.Utility\Write-Error
.ForwardHelpCategory Cmdlet
 
#>

}#end function Write-MyError
#EndRegion '.\Public\Write-MyError.ps1' 53
#Region '.\Public\Write-MyEventlog.ps1' -1

function Write-MyEvenlog {
    [CmdletBinding()]
    param (
        [Parameter(Mandatory, Position = 0)]
        [string]$LogName,

        [Parameter(Mandatory, Position = 1)]
        [string]$Source,

        [Parameter(Mandatory, Position = 2)]
        [int]$EventId,

        [Parameter(Position = 3)]
        [EventEntryType]$EntryType,

        [Parameter(Mandatory, Position = 4)]
        [string]$Message,

        [int16]$Category,

        [byte[]]$Rawdata,

        [string]$ComputerName
    )

    $Caller = (Get-PSCallStack)[1].Command

    Microsoft.PowerShell.Utility\Write-Eventlog @PSBoundParameters

    $LogMessage = "$LogName - $Source : $EntryType : $Message"

    Write-PSFMessage -Level VeryVerbose -Message $LogMessage -Tag 'Write-EventLog', $Source -Function $Caller

<#
 
.ForwardHelpTargetName Microsoft.PowerShell.Utility\Write-Eventlog
.ForwardHelpCategory Cmdlet
 
#>

}# end function Write-MyProgress
#EndRegion '.\Public\Write-MyEventlog.ps1' 41
#Region '.\Public\Write-MyHost.ps1' -1

function Write-MyHost {
    [CmdletBinding()]
    param (
        [ConsoleColor]$BackgroundColor,
        [ConsoleColor]$ForeGroundColor,
        [switch]$NoNewline,
        [Parameter(Position = 0)]
        $Object,
        $Separator
    )

    $Caller = (Get-PSCallStack)[1].Command

    Microsoft.PowerShell.Utility\Write-Host @PSBoundParameters

    $LogMessage = "$Object"

    Write-PSFMessage -Level InternalComment -Message $LogMessage -Tag 'Write-Host' -Function $Caller

<#
 
.ForwardHelpTargetName Microsoft.PowerShell.Utility\Write-Host
.ForwardHelpCategory Cmdlet
 
#>

}# end function Write-MyHost
#EndRegion '.\Public\Write-MyHost.ps1' 27
#Region '.\Public\Write-MyInformation.ps1' -1

function Write-MyOutput {
    [CmdletBinding()]
    param (
        [Parameter(Mandatory,Position = 0)]
        [psobject]$MessageData,
        [Parameter(Position = 1)]
        [string[]]$Tag
    )

    begin {
        $Caller = (Get-PSCallStack)[1].Command
    }

    process {
        Microsoft.PowerShell.Utility\Write-Output @PSBoundParameters
        Write-PSFMessage -Level InternalComment -Message $MessageData -Tag 'Write-Information' -Function $Caller -Tag $Tag
    }

<#
 
.ForwardHelpTargetName Microsoft.PowerShell.Utility\Write-Information
.ForwardHelpCategory Cmdlet
 
#>

}
#EndRegion '.\Public\Write-MyInformation.ps1' 26
#Region '.\Public\Write-MyOutput.ps1' -1

function Write-MyOutput {
    [CmdletBinding()]
    param (
        [Parameter(Mandatory,ValueFromPipeline,Position = 0)]
        [psobject[]]$InputObject,
        [switch]$NoEnumerate
    )

    begin {
        $Caller = (Get-PSCallStack)[1].Command
    }

    process {
        $LogMessage = "$InputObject"

        Microsoft.PowerShell.Utility\Write-Output @PSBoundParameters
        Write-PSFMessage -Level InternalComment -Message $LogMessage -Tag 'Write-Output' -Function $Caller
    }

<#
 
.ForwardHelpTargetName Microsoft.PowerShell.Utility\Write-Output
.ForwardHelpCategory Cmdlet
 
#>

}
#EndRegion '.\Public\Write-MyOutput.ps1' 27
#Region '.\Public\Write-MyProgress.ps1' -1

function Write-MyProgress {
    [CmdletBinding()]
    param (
        [Parameter(Mandatory, Position = 0)]
        [string]$Activity,
        $Completed,
        [string]$CurrentOperation,
        [int]$Id,
        [int]$ParentId,
        [int]$PercentComplete,
        [int]$SecondsRemaining,
        [int]$SourceId,
        [string]$Status = 'Processing'
    )

    $Caller = (Get-PSCallStack)[1].Command

    Microsoft.PowerShell.Utility\Write-Progress @PSBoundParameters

    $LogMessage = "$Activity - $Status"
    if ($PercentComplete) {
        $LogMessage = "$Activity - $Status - $PercentComplete"
    }
    if ($SecondsRemaining) {
        $LogMessage = "$Activity - $Status - $SecondsRemaining"
    }

    Write-PSFMessage -Level InternalComment -Message $LogMessage -Tag 'Write-Progress' -Function $Caller

<#
 
.ForwardHelpTargetName Microsoft.PowerShell.Utility\Write-Progress
.ForwardHelpCategory Cmdlet
 
#>

}# end function Write-MyProgress
#EndRegion '.\Public\Write-MyProgress.ps1' 37
#Region '.\Public\Write-MyWarning.ps1' -1

function Write-MyWarning {
    [CmdletBinding()]
    param (
        [Parameter(Mandatory, Position = 0)]
        [String]$Message
    )
    $Caller = (Get-PSCallStack)[1].Command

    Write-PSFMessage -Level Warning -Message $Message -Tag 'Write-Warning' -Function $Caller

<#
 
.ForwardHelpTargetName Microsoft.PowerShell.Utility\Write-Warning
.ForwardHelpCategory Cmdlet
 
#>


}# end function Write-MyWarning
#EndRegion '.\Public\Write-MyWarning.ps1' 19
#Region '.\Public\Write-MyVerbose.ps1' -1

function Write-MyVerbose {
    [CmdletBinding()]
    param (
        [Parameter(Mandatory)]
        [String]$Message
    )
    $Caller = (Get-PSCallStack)[1].Command

    Write-PSFMessage -Level Verbose -Message $Message -Tag 'Write-Verbose' -Function $Caller

<#
 
.ForwardHelpTargetName Microsoft.PowerShell.Utility\Write-Verbose
.ForwardHelpCategory Cmdlet
 
#>


}# end function
#EndRegion '.\Public\Write-MyVerbose.ps1' 19