Public/monitor/firewall/session.ps1

#
# Copyright 2022, Alexis La Goutte <alexis dot lagoutte at gmail dot com>
#
# SPDX-License-Identifier: Apache-2.0
#
function Get-FGTMonitorFirewallSession {

    <#
        .SYNOPSIS
        Get Monitor Firewall Session

        .DESCRIPTION
        Get Monitor Firewall Session (proto, source/destination IP/Port, policyid ...)

        .EXAMPLE
        Get-FGTMonitorFirewallSession

        Get ALL Firewall Policy session (by default 20 first session)

        .EXAMPLE
        Get-FGTMonitorFirewallSession -count 1000

        Get 1000 Firewall Session monitor

        .EXAMPLE
        Get-FGTMonitorFirewallSession -policyid 23

        Get Firewall Session monitor with id 23

        .EXAMPLE
        Get-FGTMonitorFirewallSession -vdom vdomX

        Get Firewall Session monitor of vdomX

    #>


    Param(
        [Parameter (Mandatory = $false)]
        [switch]$summary,
        [Parameter (Mandatory = $false)]
        [int]$policyid,
        [Parameter (Mandatory = $false)]
        [int]$count = 20,
        [Parameter (Mandatory = $false)]
        [switch]$skip,
        [Parameter(Mandatory = $false)]
        [String[]]$vdom,
        [Parameter(Mandatory = $false)]
        [psobject]$connection = $DefaultFGTConnection
    )

    Begin {
    }

    Process {

        $invokeParams = @{ }
        if ( $PsBoundParameters.ContainsKey('skip') ) {
            $invokeParams.add( 'skip', $skip )
        }
        if ( $PsBoundParameters.ContainsKey('vdom') ) {
            $invokeParams.add( 'vdom', $vdom )
        }

        $c = $count
        if ($count -gt 1000) {
            $count = 1000
        }

        #before 7.6.x, it is session (and not sessions) (already available with 7.4.x) but session drop with 7.6.)
        if ($connection.version -lt "7.6.0") {
            $uri = "api/v2/monitor/firewall/session?count=${count}"
        }
        else {
            $uri = "api/v2/monitor/firewall/sessions?count=${count}"
        }

        if ( $PsBoundParameters.ContainsKey('summary') ) {
            $uri += "&summary=$true"
        }
        if ( $PsBoundParameters.ContainsKey('policyid') ) {
            $uri += "&policyid=$policyid"
        }

        $results = @()
        $i = 0
        while ($i -lt $c) {
            $uri2 = $uri + "&start=$($i)"
            $response = Invoke-FGTRestMethod -uri $uri2 -method 'GET' -connection $connection @invokeParams

            $i += 1024
            $results += $response.results.details
        }
        $output = new-Object -TypeName PSObject
        if ( $PsBoundParameters.ContainsKey('summary') ) {
            $output | add-member -name "summary" -membertype NoteProperty -Value $response.summary
        }
        $output | add-member -name "details" -membertype NoteProperty -Value $results
        $output
    }

    End {
    }
}