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) $Headers = New-LMHeader -Auth $Script:LMAuth -Method "POST" -ResourcePath $ResourcePath -Data $Data $Uri = "https://$($Script:LMAuth.Portal).$(Get-LMPortalURI)" + $ResourcePath Resolve-LMDebugInfo -Url $Uri -Headers $Headers[0] -Command $MyInvocation -Payload $Data #Issue request Invoke-LMRestMethod -CallerPSCmdlet $PSCmdlet -Uri $Uri -Method "POST" -Headers $Headers[0] -WebSession $Headers[1] -Body $Data | Out-Null return "Invoke session logoff for username(s): $($Usernames -Join ",")." } else { Write-Error "Please ensure you are logged in before running any commands, use Connect-LMAccount to login and try again." } } end {} } |