public class AuthorizationCodeTokenRequest extends TokenRequest
Use Credential
to access protected resources from the resource server using the TokenResponse
returned by TokenRequest.execute()
. On error, it will instead throw TokenResponseException
.
Sample usage:
static void requestAccessToken() throws IOException { try { TokenResponse response = new AuthorizationCodeTokenRequest(new NetHttpTransport(), new GsonFactory(), new GenericUrl("https://server.example.com/token"), "SplxlOBeZQQYbYS6WxSbIA") .setRedirectUri("https://client.example.com/rd") .setClientAuthentication( new BasicAuthentication("s6BhdRkqt3", "7Fjfp0ZBr1KtDRbnfVdmIw")).execute(); System.out.println("Access token: " + response.getAccessToken()); } catch (TokenResponseException e) { if (e.getDetails() != null) { System.err.println("Error: " + e.getDetails().getError()); if (e.getDetails().getErrorDescription() != null) { System.err.println(e.getDetails().getErrorDescription()); } if (e.getDetails().getErrorUri() != null) { System.err.println(e.getDetails().getErrorUri()); } } else { System.err.println(e.getMessage()); } } }
Some OAuth 2.0 providers don't support BasicAuthentication
but instead support ClientParametersAuthentication
. In the above sample code, simply replace the class name and it
will work the same way.
Implementation is not thread-safe.
GenericData.Flags
AbstractMap.SimpleEntry<K,V>, AbstractMap.SimpleImmutableEntry<K,V>
responseClass
Constructor and Description |
---|
AuthorizationCodeTokenRequest(HttpTransport transport,
JsonFactory jsonFactory,
GenericUrl tokenServerUrl,
String code) |
Modifier and Type | Method and Description |
---|---|
String |
getCode()
Returns the authorization code generated by the authorization server.
|
String |
getRedirectUri()
Returns the redirect URI parameter matching the redirect URI parameter in the authorization
request or
null for none. |
AuthorizationCodeTokenRequest |
set(String fieldName,
Object value) |
AuthorizationCodeTokenRequest |
setClientAuthentication(HttpExecuteInterceptor clientAuthentication)
Sets the client authentication or
null for none. |
AuthorizationCodeTokenRequest |
setCode(String code)
Sets the authorization code generated by the authorization server.
|
AuthorizationCodeTokenRequest |
setGrantType(String grantType)
Sets the grant type (
"authorization_code" , "password" , "client_credentials" , "refresh_token" or absolute URI of the extension grant type). |
AuthorizationCodeTokenRequest |
setRedirectUri(String redirectUri)
Sets the redirect URI parameter matching the redirect URI parameter in the authorization
request or
null for none. |
AuthorizationCodeTokenRequest |
setRequestInitializer(HttpRequestInitializer requestInitializer)
Sets the HTTP request initializer or
null for none. |
AuthorizationCodeTokenRequest |
setResponseClass(Class<? extends TokenResponse> responseClass)
Sets the TokenResponse class to allow specifying object parsing.
|
AuthorizationCodeTokenRequest |
setScopes(Collection<String> scopes)
Sets the list of scopes (as specified in Access Token Scope) or
null
for none. |
AuthorizationCodeTokenRequest |
setTokenServerUrl(GenericUrl tokenServerUrl)
Sets the token server URL.
|
execute, executeUnparsed, getClientAuthentication, getGrantType, getJsonFactory, getRequestInitializer, getResponseClass, getScopes, getTokenServerUrl, getTransport
clone, entrySet, equals, get, getClassInfo, getUnknownKeys, hashCode, put, putAll, remove, setUnknownKeys, toString
clear, containsKey, containsValue, isEmpty, keySet, size, values
finalize, getClass, notify, notifyAll, wait, wait, wait
compute, computeIfAbsent, computeIfPresent, forEach, getOrDefault, merge, putIfAbsent, remove, replace, replace, replaceAll
public AuthorizationCodeTokenRequest(HttpTransport transport, JsonFactory jsonFactory, GenericUrl tokenServerUrl, String code)
transport
- HTTP transportjsonFactory
- JSON factorytokenServerUrl
- token server URLcode
- authorization code generated by the authorization serverpublic AuthorizationCodeTokenRequest setRequestInitializer(HttpRequestInitializer requestInitializer)
TokenRequest
null
for none.
Overriding is only supported for the purpose of calling the super implementation and changing the return type, but nothing else.
setRequestInitializer
in class TokenRequest
public AuthorizationCodeTokenRequest setTokenServerUrl(GenericUrl tokenServerUrl)
TokenRequest
Overriding is only supported for the purpose of calling the super implementation and changing the return type, but nothing else.
setTokenServerUrl
in class TokenRequest
public AuthorizationCodeTokenRequest setScopes(Collection<String> scopes)
TokenRequest
null
for none.
Overriding is only supported for the purpose of calling the super implementation and changing the return type, but nothing else.
setScopes
in class TokenRequest
scopes
- collection of scopes to be joined by a space separator (or a single value
containing multiple space-separated scopes)public AuthorizationCodeTokenRequest setGrantType(String grantType)
TokenRequest
"authorization_code"
, "password"
, "client_credentials"
, "refresh_token"
or absolute URI of the extension grant type).
Overriding is only supported for the purpose of calling the super implementation and changing the return type, but nothing else.
setGrantType
in class TokenRequest
public AuthorizationCodeTokenRequest setClientAuthentication(HttpExecuteInterceptor clientAuthentication)
TokenRequest
null
for none.
The recommended initializer by the specification is BasicAuthentication
. All
authorization servers must support that. A common alternative is ClientParametersAuthentication
. An alternative client authentication method may be provided
that implements HttpRequestInitializer
.
This HTTP request execute interceptor is guaranteed to be the last execute interceptor
before the request is executed, and after any execute interceptor set by the TokenRequest.getRequestInitializer()
.
Overriding is only supported for the purpose of calling the super implementation and changing the return type, but nothing else.
setClientAuthentication
in class TokenRequest
public AuthorizationCodeTokenRequest setResponseClass(Class<? extends TokenResponse> responseClass)
TokenRequest
setResponseClass
in class TokenRequest
responseClass
- The response class returned by TokenRequest.execute()
.public final String getCode()
public AuthorizationCodeTokenRequest setCode(String code)
Overriding is only supported for the purpose of calling the super implementation and changing the return type, but nothing else.
public final String getRedirectUri()
null
for none.public AuthorizationCodeTokenRequest setRedirectUri(String redirectUri)
null
for none.
Overriding is only supported for the purpose of calling the super implementation and changing the return type, but nothing else.
public AuthorizationCodeTokenRequest set(String fieldName, Object value)
set
in class TokenRequest
Copyright © 2011–2021 Google. All rights reserved.