Public/Remove-LMAPIToken.ps1
Function Remove-LMAPIToken { [CmdletBinding(DefaultParameterSetName = 'Id')] Param ( [Parameter(Mandatory, ParameterSetName = 'Id', ValueFromPipelineByPropertyName)] [Int]$UserId, [Parameter(Mandatory, ParameterSetName = 'Name')] [String]$UserName, [Parameter(Mandatory)] [Int]$APITokenId ) Begin{} Process{ #Check if we are logged in and have valid api creds If ($Script:LMAuth.Valid) { #Lookup UserName Id if supplying username If ($UserName) { $LookupResult = (Get-LMUser -Name $UserName).Id If (Test-LookupResult -Result $LookupResult -LookupString $UserName) { return } $UserId = $LookupResult } #Build header and uri $ResourcePath = "/setting/admins/$UserId/apitokens/$APITokenId" Try { $Headers = New-LMHeader -Auth $Script:LMAuth -Method "DELETE" -ResourcePath $ResourcePath $Uri = "https://$($Script:LMAuth.Portal).logicmonitor.com/santaba/rest" + $ResourcePath + $QueryParams #Issue request $Response = Invoke-RestMethod -Uri $Uri -Method "DELETE" -Headers $Headers[0] -WebSession $Headers[1] Write-LMHost "Successfully removed id ($APITokenId)" -ForegroundColor Green Return } 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{} } |