Public/Invoke-LMUserLogoff.ps1

<#
.SYNOPSIS
Forces user logoff in LogicMonitor.

.DESCRIPTION
The Invoke-LMUserLogoff function forces one or more users to be logged out of their LogicMonitor sessions.

.PARAMETER Usernames
An array of usernames to log off.

.EXAMPLE
#Log off multiple users
Invoke-LMUserLogoff -Usernames "user1", "user2"

.NOTES
You must run Connect-LMAccount before running this command.

.INPUTS
None. You cannot pipe objects to this command.

.OUTPUTS
Returns a success message if the logoff is completed successfully.
#>

Function Invoke-LMUserLogoff {

    [CmdletBinding()]
    Param (
        [Parameter(Mandatory)]
        [String[]]$Usernames
    )
    #Check if we are logged in and have valid api creds
    Begin {}
    Process {
        If ($Script:LMAuth.Valid) {
            
            #Build header and uri
            $ResourcePath = "/setting/admins/services/logoffUsers"

            $Data = @{
                userNames = $Usernames
            }

            $Data = ($Data | ConvertTo-Json)
            
            Try {

                $Headers = New-LMHeader -Auth $Script:LMAuth -Method "POST" -ResourcePath $ResourcePath -Data $Data
                $Uri = "https://$($Script:LMAuth.Portal).logicmonitor.com/santaba/rest" + $ResourcePath

                Resolve-LMDebugInfo -Url $Uri -Headers $Headers[0] -Command $MyInvocation -Payload $Data

                #Issue request
                $Response = Invoke-RestMethod -Uri $Uri -Method "POST" -Headers $Headers[0] -WebSession $Headers[1] -Body $Data

                Return "Invoke session logoff for username(s): $($Usernames -Join ",")."
            }
            Catch [Exception] {
                $Proceed = Resolve-LMException -LMException $PSItem
                If (!$Proceed) {
                    Return
                }
            }
        }
        Else {
            Write-Error "Please ensure you are logged in before running any commands, use Connect-LMAccount to login and try again."
        }
    }
    End {}
}