Public/Remove-GSUserToken.ps1
function Remove-GSUserToken { [cmdletbinding(SupportsShouldProcess=$true,ConfirmImpact="High")] Param ( [parameter(Mandatory=$false,ValueFromPipelineByPropertyName=$true)] [Alias("primaryEmail")] [ValidateNotNullOrEmpty()] [String] $User=$Script:PSGSuite.AdminEmail, [parameter(Mandatory=$true,ValueFromPipelineByPropertyName=$true)] [String] $ClientID, [parameter(Mandatory=$false)] [String] $AccessToken, [parameter(Mandatory=$false)] [ValidateNotNullOrEmpty()] [String] $P12KeyPath = $Script:PSGSuite.P12KeyPath, [parameter(Mandatory=$false)] [ValidateNotNullOrEmpty()] [String] $AppEmail = $Script:PSGSuite.AppEmail, [parameter(Mandatory=$false)] [ValidateNotNullOrEmpty()] [string] $AdminEmail=$Script:PSGSuite.AdminEmail ) Begin { if (!$AccessToken) { $AccessToken = Get-GSToken -P12KeyPath $P12KeyPath -Scopes "https://www.googleapis.com/auth/admin.directory.user.security" -AppEmail $AppEmail -AdminEmail $AdminEmail } $header = @{ Authorization="Bearer $AccessToken" } $user = $user } Process { $URI = "https://www.googleapis.com/admin/directory/v1/users/$User/tokens/$ClientID" if ($PSCmdlet.ShouldProcess("Removing token for Client ID '$ClientID' from $User")) { try { $response = Invoke-RestMethod -Method Delete -Uri $URI -Headers $header -ContentType "application/json" if (!$response){Write-Host "Token for Client ID '$ClientID' successfully removed from $User"} } catch { try { $result = $_.Exception.Response.GetResponseStream() $reader = New-Object System.IO.StreamReader($result) $reader.BaseStream.Position = 0 $reader.DiscardBufferedData() $resp = $reader.ReadToEnd() $response = $resp | ConvertFrom-Json | Select-Object @{N="Error";E={$Error[0]}},@{N="Code";E={$_.error.Code}},@{N="Message";E={$_.error.Message}},@{N="Domain";E={$_.error.errors.domain}},@{N="Reason";E={$_.error.errors.reason}} Write-Error "$(Get-HTTPStatus -Code $response.Code): $($response.Domain) / $($response.Message) / $($response.Reason)" break } catch { Write-Error $resp break } } } } End { return $response } } |