Retry.psm1
| [Diagnostics.CodeAnalysis.SuppressMessageAttribute( 'PSAvoidAssignmentToAutomaticVariable', 'IsWindows', Justification = 'IsWindows doesnt exist in PS5.1' )] [Diagnostics.CodeAnalysis.SuppressMessageAttribute( 'PSUseDeclaredVarsMoreThanAssignments', 'IsWindows', Justification = 'IsWindows doesnt exist in PS5.1' )] [CmdletBinding()] param() $baseName = [System.IO.Path]::GetFileNameWithoutExtension($PSCommandPath) $script:PSModuleInfo = Import-PowerShellDataFile -Path "$PSScriptRoot\$baseName.psd1" $script:PSModuleInfo | Format-List | Out-String -Stream | ForEach-Object { Write-Debug $_ } $scriptName = $script:PSModuleInfo.Name Write-Debug "[$scriptName] - Importing module" if ($PSEdition -eq 'Desktop') { $IsWindows = $true } #region [functions] - [public] Write-Debug "[$scriptName] - [functions] - [public] - Processing folder" #region [functions] - [public] - [Invoke-Retry] Write-Debug "[$scriptName] - [functions] - [public] - [Invoke-Retry] - Importing" function Invoke-Retry { <# .SYNOPSIS Runs a scriptblock with a retry mechanism. .DESCRIPTION Runs a scriptblock with a retry mechanism. If the scriptblock fails, it will retry the scriptblock a number of times with a delay between each try. If a catch scriptblock is provided, it will run that scriptblock if the scriptblock fails. .EXAMPLE ```pwsh Retry -Count 5 -Delay 5 -Run { Invoke-RestMethod -Uri 'https://api.myip.com/' } ``` Retries an API call 5 times with 5 reconds delay. #> [CmdletBinding()] [Alias('Retry')] param( # The scriptblock to run [Parameter(Mandatory)] [scriptblock] $Run, # The number of tries to make [Parameter()] [int] $Count = 3, # The delay between tries in seconds [Parameter()] [int] $Delay = 5, # A scriptblock to run if it fails [Parameter()] [scriptblock] $Catch = {}, # A scriptblock to run after the scriptblock has run [Parameter()] [scriptblock] $Finally = {} ) $ErrorActionPreference = 'Stop' for ($i = 0; $i -lt $Count; $i++) { try { & $Run break } catch { Write-Warning "The command:" Write-Warning $Run.ToString() Write-Warning "failed with error: $_" & $Catch if ($i -eq $Count - 1) { throw } Write-Warning "Retrying in $Delay seconds..." Start-Sleep -Seconds $Delay } } & $Finally } Write-Debug "[$scriptName] - [functions] - [public] - [Invoke-Retry] - Done" #endregion [functions] - [public] - [Invoke-Retry] Write-Debug "[$scriptName] - [functions] - [public] - Done" #endregion [functions] - [public] #region Member exporter $exports = @{ Alias = '*' Cmdlet = '' Function = 'Invoke-Retry' Variable = '' } Export-ModuleMember @exports #endregion Member exporter |