Private/Notifiers/Invoke-NotifierSlack.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
#requires -modules PSSlack

function Invoke-NotifierSlack {
    [cmdletbinding()]
    param(
        [parameter(Mandatory, ValueFromPipeline)]
        [ValidateScript({ $_.PSObject.TypeNames[0] -eq 'Watchmen.Notifier.Slack' })]
        [pscustomobject]$Notifier,

        [parameter(Mandatory)]
        [ValidateScript({ $_.PSObject.TypeNames[0] -eq 'OperationValidationResult' })]
        [pscustomobject]$Results
    )

    if ($Notifier.Enabled) {
        Import-Module -Name PSSlack -Verbose:$false -ErrorAction Stop

        $o = ($Notifier | Format-Table -Property * -AutoSize | Out-String)
        Write-Debug -Message "Slack notifier called with options:`n$o"

        $text = @"
Watchmen reported a failure in OVF test:
 
Computer: $env:COMPUTERNAME
 
Module: $($results.Module)
 
File: $($results.FileName)
 
Describe: $($results.RawResult.Describe)
 
Context: $($results.RawResult.Context)
 
Test: $($results.RawResult.Name)
 
Result: $($results.Result)
 
Message: $($results.RawResult.FailureMessage)
 
Duration: $($results.RawResult.Time.ToString())
"@


        $fields = @(
            @{title = 'Computer'; value = $env:COMPUTERNAME; short = $true }
            @{title = 'Module'; value = $results.Module; short = $true }
            @{title = 'Test'; value = $results.RawResult.Name; short = $false }
            @{title = 'Describe'; value = $results.RawResult.Describe; short = $true }
            @{title = 'Context'; value = $results.RawResult.Context; short = $true }
            @{title = 'File'; value = $results.FileName; short = $false }
            @{title = 'Result'; value = $results.Result; short = $true }
            @{title = 'Message'; value = $results.RawResult.FailureMessage; short = $true }
            @{title = 'Duration'; value = $results.RawResult.Time.ToString(); short = $true }
        )

        if ($null -ne $Notifier.PreText -and $Notifier.PreText -ne [string]::Empty) {
            $pretext = $Notifier.PreText
        } else {
            $pretext = 'Failed Watchmen Test'
        }

        $params = @{
            Color = [System.Drawing.Color]::Red
            Title = "$($Notifier.IconEmoji) $($results.Result.ToUpper()) - $($results.RawResult.Name)"
            Fields = $fields
            PreText = $pretext
            AuthorName = $Notifier.AuthorName
            Fallback = $text
        }
        $att = New-SlackMessageAttachment @params
        if ($Notifier.IconEmoji -ne [string]::Empty) {
            $msg = $att | New-SlackMessage -Channel $Notifier.Channel -IconEmoji $Notifier.IconEmoji
        } else {
            $msg = $att | New-SlackMessage -Channel $Notifier.Channel -IconUrl $Notifier.IconUrl
        }
        $msg | Send-SlackMessage -Uri $Notifier.Token | Out-Null
    }
}