Src/Private/Get-AbrVbrBackupjob.ps1
function Get-AbrVbrBackupjob { <# .SYNOPSIS Used by As Built Report to returns backup jobs created in Veeam Backup & Replication. .DESCRIPTION Documents the configuration of Veeam VBR in Word/HTML/Text formats using PScribo. .NOTES Version: 0.8.5 Author: Jonathan Colon Twitter: @jcolonfzenpr Github: rebelinux Credits: Iain Brighton (@iainbrighton) - PScribo module .LINK https://github.com/AsBuiltReport/AsBuiltReport.Veeam.VBR #> [CmdletBinding()] param ( ) begin { Write-PScriboMessage "Discovering Veeam VBR Backup jobs information from $System." } process { try { $Bkjobs = Get-VBRJob -WarningAction SilentlyContinue | Where-Object { $_.TypeToString -ne 'Windows Agent Backup' -and $_.TypeToString -ne 'Hyper-V Replication' -and $_.TypeToString -ne 'VMware Replication' } | Sort-Object -Property Name if ($Bkjobs) { $OutObj = @() foreach ($Bkjob in $Bkjobs) { try { $inObj = [ordered] @{ 'Name' = $Bkjob.Name 'Type' = $Bkjob.TypeToString 'Status' = Switch ($Bkjob.IsScheduleEnabled) { 'False' { 'Disabled' } 'True' { 'Enabled' } } 'Latest Result' = $Bkjob.info.LatestStatus 'Scheduled?' = Switch ($Bkjob.IsScheduleEnabled) { 'True' { 'Yes' } 'False' { 'No' } default { 'Unknown' } } } $OutObj += [pscustomobject]$inObj } catch { Write-PScriboMessage -IsWarning "Backup Jobs Section: $($_.Exception.Message)" } } if ($HealthCheck.Jobs.Status) { $BackupJobsStatus | Where-Object { $_.'Latest Result' -eq 'Failed' } | Set-Style -Style Critical -Property 'Latest Result' $BackupJobsStatus | Where-Object { $_.'Latest Result' -eq 'Warning' } | Set-Style -Style Warning -Property 'Latest Result' $BackupJobsStatus | Where-Object { $_.'Status' -eq 'Disabled' } | Set-Style -Style Warning -Property 'Status' $BackupJobsStatus | Where-Object { $_.'Scheduled?' -eq 'No' } | Set-Style -Style Warning -Property 'Scheduled?' } $TableParams = @{ Name = "Backup Jobs - $VeeamBackupServer" List = $false ColumnWidths = 41, 20, 13, 13, 13 } if ($Report.ShowTableCaptions) { $TableParams['Caption'] = "- $($TableParams.Name)" } try { $Alljobs = @() if ($Bkjobs.info.LatestStatus) { $Alljobs += $Bkjobs.info.LatestStatus } if ((Get-VBRTapeJob -ErrorAction SilentlyContinue).LastResult) { $Alljobs += (Get-VBRTapeJob).LastResult } if ((Get-VBRSureBackupJob -ErrorAction SilentlyContinue).LastResult) { $Alljobs += (Get-VBRSureBackupJob -ErrorAction SilentlyContinue).LastResult } $sampleData = @{ 'Success' = ($Alljobs | Where-Object { $_ -eq "Success" } | Measure-Object).Count 'Warning' = ($Alljobs | Where-Object { $_ -eq "Warning" } | Measure-Object).Count 'Failed' = ($Alljobs | Where-Object { $_ -eq "Failed" } | Measure-Object).Count 'None' = ($Alljobs | Where-Object { $_ -eq "None" } | Measure-Object).Count } $sampleDataObj = $sampleData.GetEnumerator() | Select-Object @{ Name = 'Category'; Expression = { $_.key } }, @{ Name = 'Value'; Expression = { $_.value } } | Sort-Object -Property 'Category' $chartFileItem = Get-ColumnChart -SampleData $sampleDataObj -ChartName 'BackupJobs' -XField 'Category' -YField 'Value' -ChartAreaName 'Infrastructure' -AxisXTitle 'Status' -AxisYTitle 'Count' -ChartTitleName 'BackupJobs' -ChartTitleText 'Jobs Latest Result' } catch { Write-PScriboMessage -IsWarning "Backup Jobs chart section: $($_.Exception.Message)" } if ($OutObj) { if ($chartFileItem) { Image -Text 'Backup Repository - Chart' -Align 'Center' -Percent 100 -Base64 $chartFileItem } Section -Style Heading3 'Backup Jobs' { Paragraph "The following section list backup jobs created in Veeam Backup & Replication." BlankLine Section -ExcludeFromTOC -Style NOTOCHeading4 'Backup Job Status' { $OutObj | Sort-Object -Property Name | Table @TableParams } if ($Bkjobs) { try { Section -ExcludeFromTOC -Style NOTOCHeading4 'Backup Jobs Duration' { $OutObj = @() foreach ($Bkjob in $Bkjobs) { try { $BKJobSession = Get-VBRSession -Job $Bkjob | Select-Object -First 10 $Duration = $Null $StandardDeviation = $Null if ($BKJobSession) { try { $Duration = Get-AvgTimeDuration -InputObject $BKJobSession -StartTime 'CreationTime' -EndTime 'EndTime' } catch { Out-Null } } if ($BKJobSession) { try { $StandardDeviation = (Get-StrdDevDuration -JobSessions $BKJobSession).StandardDeviation } catch { Out-Null } } $inObj = [ordered] @{ 'Name' = $Bkjob.Name 'Last Backup Duration' = Switch ([string]::IsNullOrEmpty($BKJobSession)) { $true { '--' } $false { Get-TimeDuration -TimeSpan (New-TimeSpan -Start $BKJobSession[0].CreationTime -End $BKJobSession[0].EndTime) } } 'Last 10 Backup AVG Duration' = Switch ([string]::IsNullOrEmpty($Duration)) { $true { '--' } $false { $Duration } default { 'Unknown' } } 'Standard Deviation' = Switch ([string]::IsNullOrEmpty($StandardDeviation)) { $true { '--' } $false { $StandardDeviation } default { 'Unknown' } } } $OutObj += [pscustomobject]$inObj } catch { Write-PScriboMessage -IsWarning "Backup Jobs $($Bkjob.Name) Time Table: $($_.Exception.Message)" } } $TableParams = @{ Name = "Backup Jobs Time - $VeeamBackupServer" List = $false ColumnWidths = 40, 20, 20, 20 } if ($Report.ShowTableCaptions) { $TableParams['Caption'] = "- $($TableParams.Name)" } $OutObj | Sort-Object -Property Name | Table @TableParams } } catch { Write-PScriboMessage -IsWarning "Backup Jobs Time Section: $($_.Exception.Message)" } } } } } } catch { Write-PScriboMessage -IsWarning "Backup Jobs Section: $($_.Exception.Message)" } } end {} } |