Package io.meeds.oauth.twitter
Class TwitterProcessorImpl
java.lang.Object
io.meeds.oauth.twitter.TwitterProcessorImpl
- All Implemented Interfaces:
OAuthProviderProcessor<TwitterAccessTokenContext>,TwitterProcessor
-
Constructor Summary
ConstructorsConstructorDescriptionTwitterProcessorImpl(org.exoplatform.container.ExoContainerContext context, org.exoplatform.container.xml.InitParams params) -
Method Summary
Modifier and TypeMethodDescriptiongetAccessTokenFromUserProfile(org.exoplatform.services.organization.UserProfile userProfile, OAuthCodec codec) Obtain needed data from given userProfile and create accessToken from them<C> CgetAuthorizedSocialApiObject(TwitterAccessTokenContext accessToken, Class<C> socialApiObjectType) Return object, which can be used to call some operations on this Social network.twitter4j.TwittergetAuthorizedTwitterInstance(TwitterAccessTokenContext accessTokenContext) Obtain instance of twitter object for given access token.processOAuthInteraction(jakarta.servlet.http.HttpServletRequest request, jakarta.servlet.http.HttpServletResponse response) Process OAuth workflow for this OAuth provider (social network).processOAuthInteraction(jakarta.servlet.http.HttpServletRequest httpRequest, jakarta.servlet.http.HttpServletResponse httpResponse, String scope) Possibility to create new OAuth interaction with custom scope (not just the scope which is provided in configuration of this OAuth processor)voidremoveAccessTokenFromUserProfile(org.exoplatform.services.organization.UserProfile userProfile) Remove data about access token from this user profilevoidrevokeToken(TwitterAccessTokenContext accessToken) Revoke given access token on OAuth provider side, so application is removed from list of supported applications for given uservoidsaveAccessTokenAttributesToUserProfile(org.exoplatform.services.organization.UserProfile userProfile, OAuthCodec codec, TwitterAccessTokenContext accessToken) Save accessToken data to given userProfile.validateTokenAndUpdateScopes(TwitterAccessTokenContext accessToken) Send request to OAuth Provider to validate if given access token is valid and ask for scopes, which are available for given accessToken.
-
Constructor Details
-
TwitterProcessorImpl
public TwitterProcessorImpl(org.exoplatform.container.ExoContainerContext context, org.exoplatform.container.xml.InitParams params)
-
-
Method Details
-
processOAuthInteraction
public InteractionState<TwitterAccessTokenContext> processOAuthInteraction(jakarta.servlet.http.HttpServletRequest request, jakarta.servlet.http.HttpServletResponse response) throws IOException, OAuthException Description copied from interface:OAuthProviderProcessorProcess OAuth workflow for this OAuth provider (social network). Workflow is finished if returnedInteractionStateis in stateInteractionState.State.FINISHand in this case, InteractionState should also have accessToken filled. IfInteractionStateis in stateInteractionState.State.AUTH, then more redirections are needed. In this case, givenHttpServletResponseshould be already committed and prepared for redirection.- Specified by:
processOAuthInteractionin interfaceOAuthProviderProcessor<TwitterAccessTokenContext>- Parameters:
request-response-- Returns:
- InteractionState with state of OAuth interaction
- Throws:
IOException- if IO error occured (for example if httpResponse.sendRedirect failed)OAuthException- in case of some other error, which may be specific for this OAuth processor (Details are available in error code) Caller should be able to handle at leastOAuthExceptionCode.USER_DENIED_SCOPEwhich happens when user denied scope (authorization screen in web of given social network)
-
processOAuthInteraction
public InteractionState<TwitterAccessTokenContext> processOAuthInteraction(jakarta.servlet.http.HttpServletRequest httpRequest, jakarta.servlet.http.HttpServletResponse httpResponse, String scope) throws IOException, OAuthException Description copied from interface:OAuthProviderProcessorPossibility to create new OAuth interaction with custom scope (not just the scope which is provided in configuration of this OAuth processor)- Specified by:
processOAuthInteractionin interfaceOAuthProviderProcessor<TwitterAccessTokenContext>- Parameters:
httpRequest-httpResponse-scope- custom scope, which contains all scopes in single String divided byAccessTokenContext.DELIMITER- Returns:
- Throws:
IOExceptionOAuthException- See Also:
-
getAuthorizedSocialApiObject
public <C> C getAuthorizedSocialApiObject(TwitterAccessTokenContext accessToken, Class<C> socialApiObjectType) Description copied from interface:OAuthProviderProcessorReturn object, which can be used to call some operations on this Social network. For example "Plus" object for Google+ network- Specified by:
getAuthorizedSocialApiObjectin interfaceOAuthProviderProcessor<TwitterAccessTokenContext>- Parameters:
accessToken- access token used to initialize objectsocialApiObjectType- Type of object, which we wanted to return. Method will return null if this type is not supported by this processor- Returns:
- initialized object of required type or null if type wasn't found (supported) by this processor
-
getAuthorizedTwitterInstance
Description copied from interface:TwitterProcessorObtain instance of twitter object for given access token. This object can be used to call various operations with Twitter- Specified by:
getAuthorizedTwitterInstancein interfaceTwitterProcessor- Parameters:
accessTokenContext- twitter access token- Returns:
- twitter instance
-
saveAccessTokenAttributesToUserProfile
public void saveAccessTokenAttributesToUserProfile(org.exoplatform.services.organization.UserProfile userProfile, OAuthCodec codec, TwitterAccessTokenContext accessToken) Description copied from interface:OAuthProviderProcessorSave accessToken data to given userProfile. Note that we are not calling any DB save operations, just filling data into given userProfile- Specified by:
saveAccessTokenAttributesToUserProfilein interfaceOAuthProviderProcessor<TwitterAccessTokenContext>- Parameters:
userProfile- where data about access token will be filledcodec- to encode some attributes (sensitive data) before save them to user profileaccessToken- specific access token for this OAuth processor
-
getAccessTokenFromUserProfile
public TwitterAccessTokenContext getAccessTokenFromUserProfile(org.exoplatform.services.organization.UserProfile userProfile, OAuthCodec codec) Description copied from interface:OAuthProviderProcessorObtain needed data from given userProfile and create accessToken from them- Specified by:
getAccessTokenFromUserProfilein interfaceOAuthProviderProcessor<TwitterAccessTokenContext>- Parameters:
userProfile- where data from access token will be obtainedcodec- to decode data from userProfile- Returns:
- accesstoken or null if accessToken is not found in persistent storage
-
validateTokenAndUpdateScopes
public TwitterAccessTokenContext validateTokenAndUpdateScopes(TwitterAccessTokenContext accessToken) throws OAuthException Description copied from interface:OAuthProviderProcessorSend request to OAuth Provider to validate if given access token is valid and ask for scopes, which are available for given accessToken. Returned access token should be always valid and prepared for invoke other operations- Specified by:
validateTokenAndUpdateScopesin interfaceOAuthProviderProcessor<TwitterAccessTokenContext>- Parameters:
accessToken- accessToken which will be used to ask OAuthProvider about validation and for available scopes- Returns:
- accessTokenContext, which will be quite same as the one from accessToken parameter. It could have some info updated (like scopes)
- Throws:
OAuthException- usually with codes: -OAuthExceptionCode.ACCESS_TOKEN_ERRORif invalid access is used as argument -OAuthExceptionCode.IO_ERRORif IO error occurs
-
removeAccessTokenFromUserProfile
public void removeAccessTokenFromUserProfile(org.exoplatform.services.organization.UserProfile userProfile) Description copied from interface:OAuthProviderProcessorRemove data about access token from this user profile- Specified by:
removeAccessTokenFromUserProfilein interfaceOAuthProviderProcessor<TwitterAccessTokenContext>- Parameters:
userProfile- from which data will be removed
-
revokeToken
Description copied from interface:OAuthProviderProcessorRevoke given access token on OAuth provider side, so application is removed from list of supported applications for given user- Specified by:
revokeTokenin interfaceOAuthProviderProcessor<TwitterAccessTokenContext>- Parameters:
accessToken- access token to revoke
-