src/Client/Protect-XrmCommand.ps1

<#
    .SYNOPSIS
    Protect command from API Limit issues.
     
    .Description
    This cmdlet provide a core method for all API calls to Microsoft Dataverse.
    The aim is to provide a retry pattern to prevent technical issues as API Limits or network connectivity
     
    .PARAMETER ScriptBlock
    Command to run against Microsoft Dataverse API.
 
    .PARAMETER Maximum
    Maximum tries below raising an error.
#>

function Protect-XrmCommand {
    [CmdletBinding()]
    param
    (        
        [Parameter(Mandatory = $true)]
        [scriptblock] 
        $ScriptBlock,

        [Parameter(Mandatory = $false)]
        [int]
        $Maximum = 0
    )
    begin {       
        $retryCount = 0

        $StopWatch = [System.Diagnostics.Stopwatch]::StartNew(); 
        Trace-XrmFunction -Name $MyInvocation.MyCommand.Name -Stage Start -Parameters ($MyInvocation.MyCommand.Parameters); 
    }    
    process {

        $result = Invoke-Command -ScriptBlock $ScriptBlock;      
        return $result;    

        # TODO : Retry mechanism to be reviewed
        # do {
        # $retryCount++;
        # try {
        # $result = $ScriptBlock.Invoke();
        # return $result;
        # }
        # catch {
        # $delay = [Random]::new().Next(50 * $retryCount);
        #
        # # TODO : Exit if error is not a API limit or lock issue
        #
        # Write-Error $_.Exception.InnerException.Message -ErrorAction Continue;
        # Start-Sleep -Seconds ($delay);
        # }
        # } while ($retryCount -lt $Maximum)
        #
        # # Throw an error after $Maximum unsuccessful invocations.
        # # Doesn't need a condition, since the function returns upon successful invocation.
        # throw "Execution failed.";
    }
    end {
        $StopWatch.Stop();
        Trace-XrmFunction -Name $MyInvocation.MyCommand.Name -Stage Stop -StopWatch $StopWatch;
    }    
}

Export-ModuleMember -Function Protect-XrmCommand -Alias *;