Public/Videos/Wait-Video.ps1

function Wait-Video {
    [CmdletBinding()]
    [OutputType([pscustomobject])]
    param (
        [Parameter(Mandatory, Position = 0, ValueFromPipeline, ValueFromPipelineByPropertyName)]
        [ValidateNotNullOrEmpty()]
        [Alias('video_id')]
        [Alias('Id')]
        [string][UrlEncodeTransformation()]$VideohId,

        [Parameter()]
        [int]$TimeoutSec = 0,

        [Parameter()]
        [ValidateRange(0, 100)]
        [int]$MaxRetryCount = 0,

        [Parameter()]
        [ValidateRange(0, 1000)]
        [float]$PollIntervalSec = 3.0,

        [Parameter()]
        [OpenAIApiType]$ApiType = [OpenAIApiType]::OpenAI,

        [Parameter()]
        [System.Uri]$ApiBase,

        [Parameter(DontShow)]
        [string]$ApiVersion,

        [Parameter()]
        [ValidateSet('openai', 'azure', 'azure_ad')]
        [string]$AuthType = 'openai',

        [Parameter()]
        [securestring][SecureStringTransformation()]$ApiKey,

        [Parameter()]
        [Alias('OrgId')]
        [string]$Organization,

        [Parameter()]
        [ValidateNotNullOrEmpty()]
        [Completions(
            'queued',
            'in_progress',
            'completed',
            'failed',
            'preprocessing',
            'running',
            'processing',
            'cancelled',
            'succeeded'
        )]
        [string[]]$StatusForWait = @('queued', 'in_progress', 'preprocessing', 'running', 'processing'),

        [Parameter()]
        [ValidateNotNullOrEmpty()]
        [Completions(
            'queued',
            'in_progress',
            'completed',
            'failed',
            'preprocessing',
            'running',
            'processing',
            'cancelled',
            'succeeded'
        )]
        [string[]]$StatusForExit,

        [Parameter()]
        [System.Collections.IDictionary]$AdditionalQuery,

        [Parameter()]
        [System.Collections.IDictionary]$AdditionalHeaders,

        [Parameter()]
        [object]$AdditionalBody
    )

    begin {
        # Parameter construction
        $innerStatusForWait = [System.Collections.Generic.HashSet[string]]::new($StatusForWait)
        if ($PSBoundParameters.ContainsKey('StatusForExit')) {
            $innerStatusForWait.ExceptWith([System.Collections.Generic.List[string]]$StatusForExit)
        }

        # Parse Common params
        $CommonParams = ParseCommonParams $PSBoundParameters
    }

    process {
        # Create cancellation token for timeout
        $Cancellation = [System.Threading.CancellationTokenSource]::new()
        if ($TimeoutSec -gt 0) {
            $Cancellation.CancelAfter([timespan]::FromSeconds($TimeoutSec))
        }

        try {
            [uint32]$PollCounter = 0
            [uint32]$PollIntervalMilliSec = $PollIntervalSec * 1000
            [uint32]$InitialPollIntervalMilliSec = $PollIntervalMilliSec / 3
            do {
                #Wait
                $innerJobObject = $null
                $WaitMilliSec = [System.Math]::Min(($InitialPollIntervalMilliSec * ($PollCounter++)), $PollIntervalMilliSec)
                Start-CancelableWait -Milliseconds $WaitMilliSec -CancellationToken $Cancellation.Token -ea Stop
                $innerJobObject = PSOpenAI\Get-Video -VideoId $VideoId @CommonParams
                $ProgressTitle = ("Waiting for completion... : Job ID '{0}'" -f $innerJobObject.id)
                if ($innerJobObject.progress) {
                    $PercentComplete = $innerJobObject.progress
                    $StatusMessage = ('Progress {0}%' -f $innerJobObject.progress)
                }
                else {
                    $PercentComplete = -1
                    $StatusMessage = ('Status: {0}' -f $innerJobObject.status)
                }
                Write-Progress -Activity $ProgressTitle -CurrentOperation $innerJobObject.status -Status $StatusMessage -PercentComplete $PercentComplete
            } while ($innerJobObject.status -and $innerJobObject.status -in $innerStatusForWait)
        }
        catch [OperationCanceledException] {
            Write-TimeoutError
            return
        }
        catch {
            Write-Error -Exception $_.Exception
            return
        }
        finally {
            Write-Progress -Activity ("The job with id '{0}' has {1}." -f $innerJobObject.id, $innerJobObject.status) -Completed
            if ($null -ne $Cancellation) {
                $Cancellation.Dispose()
            }
        }

        if (-not $innerJobObject.status) {
            Write-Error 'Could not retrieve the status of job.'
        }

        #Finished
        Write-Verbose ('The status of job with id "{0}" is "{1}"' -f $innerJobObject.id, $innerJobObject.status)
        $innerJobObject
        return
    }

    end {

    }
}