Write-UMN.psm1
# Module: Write-UMN function Write-UMN { <# .DESCRIPTION This function will send a message to a splunk HEC endpoint .PARAMETER msg string of the message to send .PARAMETER splunkIndex integer of the splunk index to send the message to .NOTES This function requires the UMN-Common module if splunk is enabled. #> param ( [Parameter(Mandatory = $True, Position = 0, ValueFromPipeline = $True)] [String]$Msg, [Switch]$IsError ) if ($script:Connected -and $script:Azure) { $Script:splunkIndex += 1 #region Init if ($PSPrivateMetadata.JobId.Guid) { $JobID = $PSPrivateMetadata.JobId.Guid } else { $JobID = (New-Guid).Guid } $RbHost = $Env:COMPUTERNAME ## Splunk Prep $ScriptFileName = $script:ScriptFileName $BodySplunkBase = @{'host' = $RbHost; 'source' = $ScriptFileName; 'sourcetype' = 'HEC:AzureRunbook' } #endregion $Null = Send-SplunkHEC -uri $Script:uriSplunk -metadata $BodySplunkBase -header $Script:headerSplunk -eventData @{'jobID' = $JobID; 'msg' = $Msg; 'Index' = $Script:splunkIndex } } #write outputs to the console and stop if it's an error if ($IsError) { Write-Error $Msg -ErrorAction $ErrorActionPreference } else { Write-Warning -Message $Msg } $script:summary += $Msg + "`n" } function Send-Slack { <# .DESCRIPTION This function will send a message to a slack channel .PARAMETER Message string of the message to send .PARAMETER SlackChannel string of the slack channel to send the message to .PARAMETER Title string of the title of the message .PARAMETER URI string of the URI to send the message to .EXAMPLE Send-Slack -Title "Test Message" -Message "This is a test message" -SlackChannel "#t3-virt-info" -URI (Get-AzKeyVaultSecret -VaultName 'HEAT-Automation-KV' -Name 'virt-slack-runbook-alerts' -AsPlainText)" #> param ( [Parameter (Mandatory = $True)] [string]$Message, [Parameter (Mandatory = $True)] [string]$SlackChannel, [Parameter (Mandatory = $True)] [string]$Title, [Parameter (Mandatory = $True)] [string]$URI ) $ContentType = 'application/json' $SlackBody = @" { "text": "$Title", "channel": "$slackChannel", "attachments": [ { "text": "$Message" } ] } "@ Invoke-RestMethod -Uri $URI -Method Post -Body $SlackBody -ContentType $ContentType } function Connect-Splunk { <# .DESCRIPTION This function will connect to a splunk HEC endpoint .PARAMETER uri string of the uri to connect to .PARAMETER header string of the header to use .EXAMPLE Connect-Splunk -uri 'https://splunk.umn.edu:8088/services/collector/event' -header 'Splunk 12345678-1234-1234-1234-123456789012' #> param ( [Parameter (Mandatory = $True)] [string]$URI, [Parameter (Mandatory = $True)] [string]$Header, [Parameter (Mandatory = $True)] [string]$ScriptFileName, [switch]$Azure ) $script:UriSplunk = $URI $script:HeaderSplunk = $Header $script:ScriptFileName = $ScriptFileName $script:Azure = $Azure $script:Summary = '' $script:splunkIndex = 0 $script:Connected = $true } function Get-UMNSummary { <# .DESCRIPTION This function will return the summary of the messages written to write-umn #> return $Summary } function Clear-UMNSummary { $script:summary = '' } $Summary = '' $UriSplunk = '' $HeaderSplunk = '' $ScriptFileName = '' $Azure = $false $splunkIndex = 0 |