Src/Private/Get-AbrVbrBackupToTape.ps1
function Get-AbrVbrBackupToTape { <# .SYNOPSIS Used by As Built Report to returns tape backup jobs configuration 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 Tape Backup jobs configuration information from $System." } process { try { $TBkjobs = Get-VBRTapeJob | Where-Object { $_.Type -eq 'BackupToTape' } | Sort-Object -Property Name if ($TBkjobs) { Section -Style Heading3 'Backup To Tape Job Configuration' { Paragraph "The following section details the configuration about the backup to tape jobs ." BlankLine $OutObj = @() if ($TBkjobs) { foreach ($TBkjob in $TBkjobs) { Section -Style Heading4 $($TBkjob.Name) { Section -Style NOTOCHeading5 -ExcludeFromTOC 'Backups Information' { $OutObj = @() try { Write-PScriboMessage "Discovered $($TBkjob.Name) common information." if ($TBkjob.Object.Group -eq 'BackupRepository') { $RepoSize = $TBkjob.Object | Where-Object { $_.Group -eq 'BackupRepository' } $TotalBackupSize = (($TBkjob.Object.info.IncludedSize | Measure-Object -Sum ).Sum) + ($RepoSize.GetContainer().CachedTotalSpace.InBytes - $RepoSize.GetContainer().CachedFreeSpace.InBytes) } else { $TotalBackupSize = ($TBkjob.Object.info.IncludedSize | Measure-Object -Sum).Sum } $inObj = [ordered] @{ 'Name' = $TBkjob.Name 'Type' = $TBkjob.Type 'Total Backup Size' = ConvertTo-FileSizeString $TotalBackupSize 'Next Run' = Switch ($TBkjob.Enabled) { 'False' { 'Disabled' } default { $TBkjob.NextRun } } 'Description' = ConvertTo-EmptyToFiller $TBkjob.Description } $OutObj = [pscustomobject]$inobj if ($HealthCheck.Jobs.BestPractice) { $OutObj | Where-Object { $_.'Description' -eq "--" } | Set-Style -Style Warning -Property 'Description' $OutObj | Where-Object { $_.'Description' -match "Created by" } | Set-Style -Style Warning -Property 'Description' } $TableParams = @{ Name = "Common Information - $($TBkjob.Name)" List = $true ColumnWidths = 40, 60 } if ($Report.ShowTableCaptions) { $TableParams['Caption'] = "- $($TableParams.Name)" } $OutObj | Table @TableParams if ($HealthCheck.Jobs.BestPractice) { if ($OutObj | Where-Object { $_.'Description' -match 'Created by' -or $_.'Description' -eq "--" }) { Paragraph "Health Check:" -Bold -Underline BlankLine Paragraph { Text "Best Practice:" -Bold Text "It is a general rule of good practice to establish well-defined descriptions. This helps to speed up the fault identification process, as well as enabling better documentation of the environment." } BlankLine } } } catch { Write-PScriboMessage -IsWarning "Common Information - $($TBkjob.Name) Section: $($_.Exception.Message)" } } if ($TBkjob.Object) { try { Section -Style NOTOCHeading5 -ExcludeFromTOC 'Backups Objects' { $OutObj = @() foreach ($LinkedBkJob in $TBkjob.Object) { try { Write-PScriboMessage "Discovered $($LinkedBkJob.Name) backup objects." if ($LinkedBkJob.Type) { $Repository = $LinkedBkJob.Name $Type = 'Repository' } else { $Repository = $LinkedBkJob.GetTargetRepository().Name $Type = 'Backup Job' } if ($LinkedBkJob.Group -eq 'BackupRepository') { $TotalBackupSize = ConvertTo-FileSizeString ($LinkedBkJob.GetContainer().CachedTotalSpace.InBytes - $LinkedBkJob.GetContainer().CachedFreeSpace.InBytes) } else { $TotalBackupSize = ConvertTo-FileSizeString $LinkedBkJob.Info.IncludedSize } $inObj = [ordered] @{ 'Name' = $LinkedBkJob.Name 'Type' = $Type 'Size' = $TotalBackupSize 'Repository' = $Repository } $OutObj += [pscustomobject]$inobj } catch { Write-PScriboMessage -IsWarning "Backups Objects - $($TBkjob.Name) Section: $($_.Exception.Message)" } } $TableParams = @{ Name = "Backups Objects - $($TBkjob.Name)" List = $false ColumnWidths = 35, 25, 15, 25 } if ($Report.ShowTableCaptions) { $TableParams['Caption'] = "- $($TableParams.Name)" } $OutObj | Sort-Object -Property 'Name' | Table @TableParams } } catch { Write-PScriboMessage -IsWarning "Backups Objects Section: $($_.Exception.Message)" } } if ($TBkjob.FullBackupMediaPool) { try { Section -Style NOTOCHeading5 -ExcludeFromTOC 'Media Pool' { $OutObj = @() foreach ($BackupMediaPool in $TBkjob.FullBackupMediaPool) { try { Write-PScriboMessage "Discovered $($TBkjob.Name) media pool." #Todo Fix this mess! if ($BackupMediaPool.Type -eq "Gfs") { if ($BackupMediaPool.DailyMediaSetOptions.MediaSetPolicy.MoveFromMediaPoolAutomatically) { $MoveFromMediaPoolAutomatically = 'Use any available media' } else { $MoveFromMediaPoolAutomatically = "Use $(($BackupMediaPool.DailyMediaSetOptions.MediaSetPolicy.Medium).count) selected" } if ($BackupMediaPool.DailyMediaSetOptions.MediaSetPolicy.AppendToCurrentTape) { $AppendToCurrentTape = 'append' } else { $AppendToCurrentTape = "do not append" } if ($BackupMediaPool.DailyMediaSetOptions.MediaSetPolicy.MoveOfflineToVault) { $MoveOfflineToVault = "export to vault $($BackupMediaPool.DailyMediaSetOptions.MediaSetPolicy.Vault.Name)" } else { $MoveOfflineToVault = "do not export" } if ($BackupMediaPool.WeeklyMediaSetOptions.MediaSetPolicy.MoveFromMediaPoolAutomatically) { $WeeklyMoveFromMediaPoolAutomatically = 'Use any available media' } else { $WeeklyMoveFromMediaPoolAutomatically = "Use $(($BackupMediaPool.WeeklyMediaSetOptions.MediaSetPolicy.Medium).count) selected" } if ($BackupMediaPool.WeeklyMediaSetOptions.MediaSetPolicy.AppendToCurrentTape) { $WeeklyAppendToCurrentTape = 'append' } else { $WeeklyAppendToCurrentTape = "do not append" } if ($BackupMediaPool.WeeklyMediaSetOptions.MediaSetPolicy.MoveOfflineToVault) { $WeeklyMoveOfflineToVault = "export to vault $($BackupMediaPool.WeeklyMediaSetOptions.MediaSetPolicy.Vault.Name)" } else { $WeeklyMoveOfflineToVault = "do not export" } if ($BackupMediaPool.MonthlyMediaSetOptions.MediaSetPolicy.MoveFromMediaPoolAutomatically) { $MonthlyMoveFromMediaPoolAutomatically = 'Use any available media' } else { $MonthlyMoveFromMediaPoolAutomatically = "Use $(($BackupMediaPool.MonthlyMediaSetOptions.MediaSetPolicy.Medium).count) selected" } if ($BackupMediaPool.MonthlyMediaSetOptions.MediaSetPolicy.AppendToCurrentTape) { $MonthlyAppendToCurrentTape = 'append' } else { $MonthlyAppendToCurrentTape = "do not append" } if ($BackupMediaPool.MonthlyMediaSetOptions.MediaSetPolicy.MoveOfflineToVault) { $MonthlyMoveOfflineToVault = "export to vault $($BackupMediaPool.MonthlyMediaSetOptions.MediaSetPolicy.Vault.Name)" } else { $MonthlyMoveOfflineToVault = "do not export" } if ($BackupMediaPool.QuarterlyMediaSetOptions.MediaSetPolicy.MoveFromMediaPoolAutomatically) { $QuarterlyMoveFromMediaPoolAutomatically = 'Use any available media' } else { $QuarterlyMoveFromMediaPoolAutomatically = "Use $(($BackupMediaPool.QuarterlyMediaSetOptions.MediaSetPolicy.Medium).count) selected" } if ($BackupMediaPool.QuarterlyMediaSetOptions.MediaSetPolicy.AppendToCurrentTape) { $QuarterlyAppendToCurrentTape = 'append' } else { $QuarterlyAppendToCurrentTape = "do not append" } if ($BackupMediaPool.QuarterlyMediaSetOptions.MediaSetPolicy.MoveOfflineToVault) { $QuarterlyMoveOfflineToVault = "export to vault $($BackupMediaPool.QuarterlyMediaSetOptions.MediaSetPolicy.Vault.Name)" } else { $QuarterlyMoveOfflineToVault = "do not export" } if ($BackupMediaPool.YearlyMediaSetOptions.MediaSetPolicy.MoveFromMediaPoolAutomatically) { $YearlyMoveFromMediaPoolAutomatically = 'Use any available media' } else { $YearlyMoveFromMediaPoolAutomatically = "Use $(($BackupMediaPool.YearlyMediaSetOptions.MediaSetPolicy.Medium).count) selected" } if ($BackupMediaPool.YearlyMediaSetOptions.MediaSetPolicy.AppendToCurrentTape) { $YearlyAppendToCurrentTape = 'append' } else { $YearlyAppendToCurrentTape = "do not append" } if ($BackupMediaPool.YearlyMediaSetOptions.MediaSetPolicy.MoveOfflineToVault) { $YearlyMoveOfflineToVault = "export to vault $($BackupMediaPool.YearlyMediaSetOptions.MediaSetPolicy.Vault.Name)" } else { $YearlyMoveOfflineToVault = "do not export" } } $inObj = [ordered] @{ 'Name' = $BackupMediaPool.Name 'Pool Type' = $BackupMediaPool.Type 'Tape Count' = (Get-VBRTapeMedium -MediaPool $BackupMediaPool.Name).count 'Free Space' = ConvertTo-FileSizeString ((Get-VBRTapeMedium -MediaPool $BackupMediaPool.Name).Free | Measure-Object -Sum).Sum 'Encryption Enabled' = ConvertTo-TextYN $BackupMediaPool.EncryptionOptions.Enabled 'Encryption Key' = Switch ($BackupMediaPool.EncryptionOptions.Enabled) { 'True' { (Get-VBREncryptionKey | Where-Object { $_.Id -eq $BackupMediaPool.EncryptionOptions.Key.Id }).Description } 'False' { 'Disabled' } default { $BackupMediaPool.EncryptionOptions.Key.Id } } 'Parallel Processing' = "$(ConvertTo-TextYN $BackupMediaPool.MultiStreamingOptions.NumberOfStreams) drives; Multiple Backup Chains: $(ConvertTo-TextYN $BackupMediaPool.MultiStreamingOptions.SplitJobFilesBetweenDrives)" 'Is WORM' = ConvertTo-TextYN $BackupMediaPool.Worm } if ($BackupMediaPool.Type -eq "Gfs") { $inObj.add('Daily', ("$($TBkjob.FullBackupMediaPool.DailyMediaSetOptions.OverwritePeriod) days; $MoveFromMediaPoolAutomatically; $AppendToCurrentTape; $MoveOfflineToVault")) $inObj.add('Weekly', ("$($TBkjob.FullBackupMediaPool.WeeklyMediaSetOptions.OverwritePeriod) days; $WeeklyMoveFromMediaPoolAutomatically; $WeeklyAppendToCurrentTape; $WeeklyMoveOfflineToVault")) $inObj.add('Monthly', ("$($TBkjob.FullBackupMediaPool.MonthlyMediaSetOptions.OverwritePeriod) days; $MonthlyMoveFromMediaPoolAutomatically; $MonthlyAppendToCurrentTape; $MonthlyMoveOfflineToVault")) $inObj.add('Quarterly', ("$($TBkjob.FullBackupMediaPool.QuarterlyMediaSetOptions.OverwritePeriod) days; $QuarterlyMoveFromMediaPoolAutomatically; $QuarterlyAppendToCurrentTape; $QuarterlyMoveOfflineToVault")) $inObj.add('Yearly', ("$($TBkjob.FullBackupMediaPool.YearlyMediaSetOptions.OverwritePeriod) days; $YearlyMoveFromMediaPoolAutomatically; $YearlyAppendToCurrentTape; $YearlyMoveOfflineToVault")) } if ($BackupMediaPool.Type -eq "Custom") { $Vault = Switch (($TBkjob.FullBackupMediaPool.Vault).count) { 0 { "Disabled" } default { $TBkjob.FullBackupMediaPool.Vault } } $Retention = Switch ($TBkjob.FullBackupMediaPool.RetentionPolicy.Type) { $Null { "Disabled" } 'Period' { "Protect data for $($TBkjob.FullBackupMediaPool.RetentionPolicy.Value) $($TBkjob.FullBackupMediaPool.RetentionPolicy.Period)" } 'Cyclic' { 'Do not protect data (cyclically overwrite tape as required)' } 'Never' { 'Never Overwrite Data' } } $MediaSetPolicy = Switch ($TBkjob.FullBackupMediaPool.MediaSetCreationPolicy.Type) { $Null { "Disabled" } 'Always' { "Create new media set for every backup session" } 'Daily' { "Daily at $($TBkjob.FullBackupMediaPool.MediaSetCreationPolicy.DailyOptions.Period), $($TBkjob.FullBackupMediaPool.MediaSetCreationPolicy.DailyOptions.Type)" } 'Never' { 'Do not create, always continue using current media set' } } $inObj.add('Retention', ($Retention)) $inObj.add('Export to Vault', (ConvertTo-TextYN $TBkjob.FullBackupMediaPool.MoveOfflineToVault)) $inObj.add('Vault', ($Vault)) $inObj.add('Media Set Name', ($TBkjob.FullBackupMediaPool.MediaSetName)) $inObj.add('Automatically create new media set', ($MediaSetPolicy)) if ($TBkjob.FullBackupMediaPool.MediaSetCreationPolicy.Type -eq 'Daily') { $inObj.add('On these days', ($TBkjob.FullBackupMediaPool.MediaSetCreationPolicy.DailyOptions.DayOfWeek -join ", ")) } if ($TBkjob.FullBackupPolicy.Type -eq 'WeeklyOnDays') { $DayOfWeek = Switch (($TBkjob.FullBackupPolicy.WeeklyOnDays).count) { 7 { 'Everyday' } default { $TBkjob.FullBackupPolicy.WeeklyOnDays -join ", " } } $inObj.add('Full Backup Schedule', ("Weekly on selected days: $DayOfWeek")) } else { $Months = Switch (($TBkjob.FullBackupPolicy.MonthlyOptions.Months).count) { 12 { 'Every Month' } default { $TBkjob.FullBackupPolicy.MonthlyOptions.Months -join ", " } } $inObj.add('Full Backup Schedule', ("Monthly on: $($TBkjob.FullBackupPolicy.MonthlyOptions.DayNumberInMonth), $($TBkjob.FullBackupPolicy.MonthlyOptions.DayOfWeek) of $Months")) } } $OutObj += [pscustomobject]$inobj } catch { Write-PScriboMessage -IsWarning "Media Pool - $($TBkjob.Name) Section: $($_.Exception.Message)" } } $TableParams = @{ Name = "Media Pool - $($TBkjob.Name)" List = $True ColumnWidths = 40, 60 } if ($Report.ShowTableCaptions) { $TableParams['Caption'] = "- $($TableParams.Name)" } $OutObj | Sort-Object -Property 'Name' | Table @TableParams } } catch { Write-PScriboMessage -IsWarning "Media Pool Section: $($_.Exception.Message)" } } if ($TBkjob.ProcessIncrementalBackup -and $TBkjob.FullBackupMediaPool.Type -eq 'Custom') { try { Section -Style NOTOCHeading5 -ExcludeFromTOC 'Incremental Backup' { $OutObj = @() foreach ($BackupMediaPool in $TBkjob.IncrementalBackupMediaPool) { try { Write-PScriboMessage "Discovered $($TBkjob.Name) incremental backup." #Todo Fix this mess! if ($BackupMediaPool.Type -eq "Gfs") { if ($BackupMediaPool.DailyMediaSetOptions.MediaSetPolicy.MoveFromMediaPoolAutomatically) { $MoveFromMediaPoolAutomatically = 'Use any available media' } else { $MoveFromMediaPoolAutomatically = "Use $(($BackupMediaPool.DailyMediaSetOptions.MediaSetPolicy.Medium).count) selected" } if ($BackupMediaPool.DailyMediaSetOptions.MediaSetPolicy.AppendToCurrentTape) { $AppendToCurrentTape = 'append' } else { $AppendToCurrentTape = "do not append" } if ($BackupMediaPool.DailyMediaSetOptions.MediaSetPolicy.MoveOfflineToVault) { $MoveOfflineToVault = "export to vault $($BackupMediaPool.DailyMediaSetOptions.MediaSetPolicy.Vault.Name)" } else { $MoveOfflineToVault = "do not export" } if ($BackupMediaPool.WeeklyMediaSetOptions.MediaSetPolicy.MoveFromMediaPoolAutomatically) { $WeeklyMoveFromMediaPoolAutomatically = 'Use any available media' } else { $WeeklyMoveFromMediaPoolAutomatically = "Use $(($BackupMediaPool.WeeklyMediaSetOptions.MediaSetPolicy.Medium).count) selected" } if ($BackupMediaPool.WeeklyMediaSetOptions.MediaSetPolicy.AppendToCurrentTape) { $WeeklyAppendToCurrentTape = 'append' } else { $WeeklyAppendToCurrentTape = "do not append" } if ($BackupMediaPool.WeeklyMediaSetOptions.MediaSetPolicy.MoveOfflineToVault) { $WeeklyMoveOfflineToVault = "export to vault $($BackupMediaPool.WeeklyMediaSetOptions.MediaSetPolicy.Vault.Name)" } else { $WeeklyMoveOfflineToVault = "do not export" } if ($BackupMediaPool.MonthlyMediaSetOptions.MediaSetPolicy.MoveFromMediaPoolAutomatically) { $MonthlyMoveFromMediaPoolAutomatically = 'Use any available media' } else { $MonthlyMoveFromMediaPoolAutomatically = "Use $(($BackupMediaPool.MonthlyMediaSetOptions.MediaSetPolicy.Medium).count) selected" } if ($BackupMediaPool.MonthlyMediaSetOptions.MediaSetPolicy.AppendToCurrentTape) { $MonthlyAppendToCurrentTape = 'append' } else { $MonthlyAppendToCurrentTape = "do not append" } if ($BackupMediaPool.MonthlyMediaSetOptions.MediaSetPolicy.MoveOfflineToVault) { $MonthlyMoveOfflineToVault = "export to vault $($BackupMediaPool.MonthlyMediaSetOptions.MediaSetPolicy.Vault.Name)" } else { $MonthlyMoveOfflineToVault = "do not export" } if ($BackupMediaPool.QuarterlyMediaSetOptions.MediaSetPolicy.MoveFromMediaPoolAutomatically) { $QuarterlyMoveFromMediaPoolAutomatically = 'Use any available media' } else { $QuarterlyMoveFromMediaPoolAutomatically = "Use $(($BackupMediaPool.QuarterlyMediaSetOptions.MediaSetPolicy.Medium).count) selected" } if ($BackupMediaPool.QuarterlyMediaSetOptions.MediaSetPolicy.AppendToCurrentTape) { $QuarterlyAppendToCurrentTape = 'append' } else { $QuarterlyAppendToCurrentTape = "do not append" } if ($BackupMediaPool.QuarterlyMediaSetOptions.MediaSetPolicy.MoveOfflineToVault) { $QuarterlyMoveOfflineToVault = "export to vault $($BackupMediaPool.QuarterlyMediaSetOptions.MediaSetPolicy.Vault.Name)" } else { $QuarterlyMoveOfflineToVault = "do not export" } if ($BackupMediaPool.YearlyMediaSetOptions.MediaSetPolicy.MoveFromMediaPoolAutomatically) { $YearlyMoveFromMediaPoolAutomatically = 'Use any available media' } else { $YearlyMoveFromMediaPoolAutomatically = "Use $(($BackupMediaPool.YearlyMediaSetOptions.MediaSetPolicy.Medium).count) selected" } if ($BackupMediaPool.YearlyMediaSetOptions.MediaSetPolicy.AppendToCurrentTape) { $YearlyAppendToCurrentTape = 'append' } else { $YearlyAppendToCurrentTape = "do not append" } if ($BackupMediaPool.YearlyMediaSetOptions.MediaSetPolicy.MoveOfflineToVault) { $YearlyMoveOfflineToVault = "export to vault $($BackupMediaPool.YearlyMediaSetOptions.MediaSetPolicy.Vault.Name)" } else { $YearlyMoveOfflineToVault = "do not export" } } $inObj = [ordered] @{ 'Media Pool' = $BackupMediaPool.Name 'Pool Type' = $BackupMediaPool.Type 'Tape Count' = (Get-VBRTapeMedium -MediaPool $BackupMediaPool.Name).count 'Free Space' = ConvertTo-FileSizeString ((Get-VBRTapeMedium -MediaPool $BackupMediaPool.Name).Free | Measure-Object -Sum).Sum 'Encryption Enabled' = ConvertTo-TextYN $BackupMediaPool.EncryptionOptions.Enabled 'Encryption Key' = Switch ($BackupMediaPool.EncryptionOptions.Enabled) { 'True' { (Get-VBREncryptionKey | Where-Object { $_.Id -eq $BackupMediaPool.EncryptionOptions.Key.Id }).Description } 'False' { 'Disabled' } default { $BackupMediaPool.EncryptionOptions.Key.Id } } 'Parallel Processing' = "$(ConvertTo-TextYN $BackupMediaPool.MultiStreamingOptions.NumberOfStreams) drives; Multiple Backup Chains: $(ConvertTo-TextYN $BackupMediaPool.MultiStreamingOptions.SplitJobFilesBetweenDrives)" 'Is WORM' = ConvertTo-TextYN $BackupMediaPool.Worm } if ($BackupMediaPool.Type -eq "Gfs") { $inObj.add('Daily', ("$($TBkjob.IncrementalBackupMediaPool.DailyMediaSetOptions.OverwritePeriod) days; $MoveFromMediaPoolAutomatically; $AppendToCurrentTape; $MoveOfflineToVault")) $inObj.add('Weekly', ("$($TBkjob.IncrementalBackupMediaPool.WeeklyMediaSetOptions.OverwritePeriod) days; $WeeklyMoveFromMediaPoolAutomatically; $WeeklyAppendToCurrentTape; $WeeklyMoveOfflineToVault")) $inObj.add('Monthly', ("$($TBkjob.IncrementalBackupMediaPool.MonthlyMediaSetOptions.OverwritePeriod) days; $MonthlyMoveFromMediaPoolAutomatically; $MonthlyAppendToCurrentTape; $MonthlyMoveOfflineToVault")) $inObj.add('Quarterly', ("$($TBkjob.IncrementalBackupMediaPool.QuarterlyMediaSetOptions.OverwritePeriod) days; $QuarterlyMoveFromMediaPoolAutomatically; $QuarterlyAppendToCurrentTape; $QuarterlyMoveOfflineToVault")) $inObj.add('Yearly', ("$($TBkjob.IncrementalBackupMediaPool.YearlyMediaSetOptions.OverwritePeriod) days; $YearlyMoveFromMediaPoolAutomatically; $YearlyAppendToCurrentTape; $YearlyMoveOfflineToVault")) } if ($BackupMediaPool.Type -eq "Custom") { $Vault = Switch (($TBkjob.IncrementalBackupMediaPool.Vault).count) { 0 { "Disabled" } default { $TBkjob.IncrementalBackupMediaPool.Vault } } $Retention = Switch ($TBkjob.IncrementalBackupMediaPool.RetentionPolicy.Type) { $Null { "Disabled" } 'Period' { "Protect data for $($TBkjob.IncrementalBackupMediaPool.RetentionPolicy.Value) $($TBkjob.IncrementalBackupMediaPool.RetentionPolicy.Period)" } 'Cyclic' { 'Do not protect data (cyclically overwrite tape as required)' } 'Never' { 'Never Overwrite Data' } } $MediaSetPolicy = Switch ($TBkjob.IncrementalBackupMediaPool.MediaSetCreationPolicy.Type) { $Null { "Disabled" } 'Always' { "Create new media set for every backup session" } 'Daily' { "Daily at $($TBkjob.IncrementalBackupMediaPool.MediaSetCreationPolicy.DailyOptions.Period), $($TBkjob.IncrementalBackupMediaPool.MediaSetCreationPolicy.DailyOptions.Type)" } 'Never' { 'Do not create, always continue using current media set' } } $inObj.add('Retention', ($Retention)) $inObj.add('Export to Vault', (ConvertTo-TextYN $TBkjob.IncrementalBackupMediaPool.MoveOfflineToVault)) $inObj.add('Vault', ($Vault)) $inObj.add('Media Set Name', ($TBkjob.IncrementalBackupMediaPool.MediaSetName)) $inObj.add('Automatically create new media set', ($MediaSetPolicy)) if ($TBkjob.IncrementalBackupMediaPool.MediaSetCreationPolicy.Type -eq 'Daily') { $inObj.add('On these days', ($TBkjob.IncrementalBackupMediaPool.MediaSetCreationPolicy.DailyOptions.DayOfWeek -join ", ")) } } $OutObj += [pscustomobject]$inobj } catch { Write-PScriboMessage -IsWarning "Incremental Backup - $($TBkjob.Name) Section: $($_.Exception.Message)" } } $TableParams = @{ Name = "Incremental Backup - $($TBkjob.Name)" List = $True ColumnWidths = 40, 60 } if ($Report.ShowTableCaptions) { $TableParams['Caption'] = "- $($TableParams.Name)" } $OutObj | Sort-Object -Property 'Name' | Table @TableParams } } catch { Write-PScriboMessage -IsWarning "Incremental Backup Section: $($_.Exception.Message)" } } try { Section -Style NOTOCHeading5 -ExcludeFromTOC 'Options' { $OutObj = @() try { Write-PScriboMessage "Discovered $($TBkjob.Name) options." $inObj = [ordered] @{ 'Eject Tape Media Upon Job Completion' = ConvertTo-TextYN $TBkjob.EjectCurrentMedium 'Export the following MediaSet Upon Job Completion' = ConvertTo-TextYN $TBkjob.ExportCurrentMediaSet 'Limit the number of drives this job can use' = "Enabled: $(ConvertTo-TextYN $TBkjob.ParallelDriveOptions.IsEnabled); Tape Drives Limit: $($TBkjob.ParallelDriveOptions.DrivesLimit)" } $OutObj += [pscustomobject]$inobj } catch { Write-PScriboMessage -IsWarning "Options - $($TBkjob.Name) Section: $($_.Exception.Message)" } $TableParams = @{ Name = "Options - $($TBkjob.Name)" List = $True ColumnWidths = 40, 60 } if ($Report.ShowTableCaptions) { $TableParams['Caption'] = "- $($TableParams.Name)" } $OutObj | Sort-Object -Property 'Name' | Table @TableParams if ($InfoLevel.Jobs.Tape -ge 2 -and $TBkjob.NotificationOptions.EnableAdditionalNotification) { try { Section -Style NOTOCHeading6 -ExcludeFromTOC 'Advanced Settings (Notifications)' { $OutObj = @() try { Write-PScriboMessage "Discovered $($TBkjob.Name) notification options." $inObj = [ordered] @{ 'Send Email Notification' = ConvertTo-TextYN $TBkjob.NotificationOptions.EnableAdditionalNotification 'Email Notification Additional Recipients' = $TBkjob.NotificationOptions.AdditionalAddress -join "," } if (!$TBkjob.NotificationOptions.UseNotificationOptions) { $inObj.add('Use Global Notification Settings', (ConvertTo-TextYN $TBkjob.NotificationOptions.UseNotificationOptions)) } elseif ($TBkjob.NotificationOptions.UseNotificationOptions) { $inObj.add('Use Custom Notification Settings', ('Yes')) $inObj.add('Subject', ($TBkjob.NotificationOptions.NotificationSubject)) $inObj.add('Notify On Success', (ConvertTo-TextYN $TBkjob.NotificationOptions.NotifyOnSuccess)) $inObj.add('Notify On Warning', (ConvertTo-TextYN $TBkjob.NotificationOptions.NotifyOnWarning)) $inObj.add('Notify On Error', (ConvertTo-TextYN $TBkjob.NotificationOptions.NotifyOnError)) $inObj.add('Notify On Last Retry Only', (ConvertTo-TextYN $TBkjob.NotificationOptions.NotifyOnLastRetryOnly)) $inObj.add('Notify When Waiting For Tape', (ConvertTo-TextYN $TBkjob.NotificationOptions.NotifyWhenWaitingForTape)) } $OutObj += [pscustomobject]$inobj } catch { Write-PScriboMessage -IsWarning "Advanced Settings (Notifications) - $($TBkjob.Name) Section: $($_.Exception.Message)" } $TableParams = @{ Name = "Advanced Settings (Notifications) - $($TBkjob.Name)" List = $True ColumnWidths = 40, 60 } if ($Report.ShowTableCaptions) { $TableParams['Caption'] = "- $($TableParams.Name)" } $OutObj | Sort-Object -Property 'Name' | Table @TableParams } } catch { Write-PScriboMessage -IsWarning "Advanced Settings (Notifications) Section: $($_.Exception.Message)" } } if ($InfoLevel.Jobs.Tape -ge 2 -and $TBkjob.NotificationOptions.EnableAdditionalNotification) { try { Section -Style NOTOCHeading6 -ExcludeFromTOC 'Advanced Settings (Advanced)' { $OutObj = @() try { Write-PScriboMessage "Discovered $($TBkjob.Name) advanced options." $inObj = [ordered] @{ 'Process the most recent Restore Point instead of waiting' = ConvertTo-TextYN $TBkjob.AlwaysCopyFromLatestFull 'Use Hardware Compression when available' = ConvertTo-TextYN $TBkjob.UseHardwareCompression } if (!$TBkjob.JobScriptOptions.PreScriptEnabled) { $inObj.add('Pre Job Script Enabled', (ConvertTo-TextYN $TBkjob.JobScriptOptions.PreScriptEnabled)) } elseif ($TBkjob.JobScriptOptions.PreScriptEnabled) { $inObj.add('Run the following script before job', ($TBkjob.JobScriptOptions.PreCommand)) } if (!$TBkjob.JobScriptOptions.PostScriptEnabled) { $inObj.add('Post Job Script Enabled', (ConvertTo-TextYN $TBkjob.JobScriptOptions.PostScriptEnabled)) } elseif ($TBkjob.JobScriptOptions.PostScriptEnabled) { $inObj.add('Run the following script after job', ($TBkjob.JobScriptOptions.PostCommand)) } if ($TBkjob.JobScriptOptions.PreScriptEnabled -or $TBkjob.JobScriptOptions.PostScriptEnabled) { if ($TBkjob.JobScriptOptions.Periodicity -eq 'Days') { $FrequencyValue = $TBkjob.JobScriptOptions.Day -join ", " $FrequencyText = 'Run Script on the Selected Days' } elseif ($TBkjob.JobScriptOptions.Periodicity -eq 'Cycles') { $FrequencyValue = "Every $($TBkjob.JobScriptOptions.Frequency) backup session" $FrequencyText = 'Run Script Every Backup Session' } $inObj.add($FrequencyText, ($FrequencyValue)) } $OutObj += [pscustomobject]$inobj } catch { Write-PScriboMessage -IsWarning "Advanced Settings (Advanced) - $($TBkjob.Name) Section: $($_.Exception.Message)" } $TableParams = @{ Name = "Advanced Settings (Advanced) - $($TBkjob.Name)" List = $True ColumnWidths = 40, 60 } if ($Report.ShowTableCaptions) { $TableParams['Caption'] = "- $($TableParams.Name)" } $OutObj | Sort-Object -Property 'Name' | Table @TableParams } } catch { Write-PScriboMessage -IsWarning "Advanced Settings (Advanced) Section: $($_.Exception.Message)" } } } } catch { Write-PScriboMessage -IsWarning "Options Section: $($_.Exception.Message)" } try { Section -Style NOTOCHeading5 -ExcludeFromTOC 'Schedule' { $OutObj = @() try { Write-PScriboMessage "Discovered $($TBkjob.Name) schedule options." $inObj = [ordered] @{ 'Prevent this job from being interrupted by source backup job' = ConvertTo-TextYN $TBkjob.WaitForBackupJobs } if ($TBkjob.GFSScheduleOptions) { $inObj.add('Perform GFS scan daily at', ($TBkjob.GFSScheduleOptions.DailyOptions)) $inObj.add('Daily backup', ($TBkjob.ScheduleOptions.DailyOptions.Type)) $inObj.add('Weekly backup', ($TBkjob.GFSScheduleOptions.WeeklyOptions.ToString())) $inObj.add('Monthly backup', ($TBkjob.GFSScheduleOptions.MonthlyOptions.ToString())) $inObj.add('Quarterly backup', ($TBkjob.GFSScheduleOptions.QuarterlyOptions.ToString())) $inObj.add('Yearly backup', ($TBkjob.GFSScheduleOptions.YearlyOptions.ToString())) } if ($TBkjob.ScheduleOptions.Enabled -and !$TBkjob.GFSScheduleOptions) { if ($TBkjob.ScheduleOptions.Type -eq "Daily") { $Schedule = "Daily at this time: $($TBkjob.ScheduleOptions.DailyOptions.Period),`r`nDays: $($TBkjob.ScheduleOptions.DailyOptions.Type),`r`nDay Of Week: $($TBkjob.ScheduleOptions.DailyOptions.DayOfWeek)" } elseif ($TBkjob.ScheduleOptions.Type -eq "Monthly") { if ($TBkjob.ScheduleOptions.MonthlyOptions.DayNumberInMonth -eq 'OnDay') { $Schedule = "Monthly at this time: $($TBkjob.ScheduleOptions.MonthlyOptions.Period),`r`nThis Day: $($TBkjob.ScheduleOptions.MonthlyOptions.DayOfMonth),`r`nMonths: $($TBkjob.ScheduleOptions.MonthlyOptions.Months)" } else { $Schedule = "Monthly at this time: $($TBkjob.ScheduleOptions.MonthlyOptions.Period),`r`nDays Number of Month: $($TBkjob.ScheduleOptions.MonthlyOptions.DayNumberInMonth),`r`nDay Of Week: $($TBkjob.ScheduleOptions.MonthlyOptions.DayOfWeek),`r`nMonth: $($TBkjob.ScheduleOptions.MonthlyOptions.Months)" } } elseif ($TBkjob.ScheduleOptions.Type -eq "AfterJob") { $Schedule = Switch ($TBkjob.ScheduleOptions.JobId) { $Null { 'Unknown' } default { " After Job: $((Get-VBRJob -WarningAction SilentlyContinue | Where-Object {$_.Id -eq $TBkjob.ScheduleOptions.JobId}).Name)" } } } elseif ($TBkjob.ScheduleOptions.Type -eq "AfterNewBackup") { $Schedule = 'After New Backup File Appears' } $inObj.add("Run Automatically", ($Schedule)) } if ($TBkjob.WaitForBackupJobs -and !$TBkjob.GFSScheduleOptions) { $inObj.add('Wait for Backup Job', ("$($TBkjob.WaitPeriod.ToString()) hours")) } $OutObj += [pscustomobject]$inobj } catch { Write-PScriboMessage -IsWarning "Schedule - $($TBkjob.Name) Section: $($_.Exception.Message)" } $TableParams = @{ Name = "Schedule - $($TBkjob.Name)" List = $True ColumnWidths = 40, 60 } if ($Report.ShowTableCaptions) { $TableParams['Caption'] = "- $($TableParams.Name)" } $OutObj | Sort-Object -Property 'Name' | Table @TableParams } } catch { Write-PScriboMessage -IsWarning "Schedule Section: $($_.Exception.Message)" } } } } } } } catch { Write-PScriboMessage -IsWarning "Backup To Tape Job Configuration Section: $($_.Exception.Message)" } } end {} } |