Package org.springframework.social.oauth2

Examples of org.springframework.social.oauth2.OAuth2RequestInterceptor


  @Test
  public void test() throws Exception {
    @SuppressWarnings("unchecked")
    final OAuth2ConnectionFactory<Object> factory = mock(OAuth2ConnectionFactory.class);
    final OAuth2Operations operations = mock(OAuth2Operations.class);
    final String serverName = "example.com";
    final AccessGrant accessGrant = new AccessGrant("my_token");
    final String code = "code";
    final Connection<Object> connection = DummyConnection.dummy("provider", "user");

    final OAuth2AuthenticationService<Object> authSvc = new OAuth2AuthenticationService<Object>(factory);
    authSvc.getReturnToUrlParameters().add("param");
    authSvc.afterPropertiesSet();

    final MockServletContext context = new MockServletContext();
    final MockHttpSession session = new MockHttpSession(context);

    // mock definitions
    when(factory.getProviderId()).thenReturn(connection.getKey().getProviderId());
    when(factory.getOAuthOperations()).thenReturn(operations);
    when(factory.createConnection(accessGrant)).thenReturn(connection);

    when(
        operations.buildAuthenticateUrl(oAuth2Parameters("http://example.com/auth/foo?param=param_value"))).thenReturn(
        "http://facebook.com/auth");
    when(operations.exchangeForAccess(code, "http://example.com/auth/foo", null)).thenReturn(accessGrant);

    // first phase
    MockHttpServletRequest request = new MockHttpServletRequest(context, "GET", "/auth/foo");
    request.setServerName(serverName);
    request.setSession(session);
View Full Code Here


  }
 
  private static class TestOAuth2ServiceProvider implements OAuth2ServiceProvider<TestApi> {

    public OAuth2Operations getOAuthOperations() {
      return new OAuth2Operations() {
        public String buildAuthorizeUrl(GrantType grantType, OAuth2Parameters params) {
          return "https://serviceprovider.com/oauth/authorize" + additionalParametersQuery(params, false);
        }
        public String buildAuthenticateUrl(GrantType grantType, OAuth2Parameters params) {
          return "https://serviceprovider.com/oauth/authenticate" + additionalParametersQuery(params, false);
View Full Code Here

  }

  private static class TestFacebookServiceProvider implements OAuth2ServiceProvider<TestFacebookApi> {

    public OAuth2Operations getOAuthOperations() {
      return new OAuth2Operations() {
        public String buildAuthorizeUrl(GrantType grantType, OAuth2Parameters params) {
          return null;
        }
        public String buildAuthenticateUrl(GrantType grantType, OAuth2Parameters params) {
          return null;
View Full Code Here

  }

  private static class TestFacebookServiceProvider implements OAuth2ServiceProvider<TestFacebookApi> {

    public OAuth2Operations getOAuthOperations() {
      return new OAuth2Operations() {
        public String buildAuthorizeUrl(GrantType grantType, OAuth2Parameters params) {
          return null;
        }
        public String buildAuthenticateUrl(GrantType grantType, OAuth2Parameters params) {
          return null;
View Full Code Here

  }

  private String buildOAuth2Url(OAuth2ConnectionFactory<?> connectionFactory, NativeWebRequest request, MultiValueMap<String, String> additionalParameters) {
    OAuth2Operations oauthOperations = connectionFactory.getOAuthOperations();
    String defaultScope = connectionFactory.getScope();
    OAuth2Parameters parameters = getOAuth2Parameters(request, defaultScope, additionalParameters);
    String state = connectionFactory.generateState();
    parameters.add("state", state);
    sessionStrategy.setAttribute(request, OAUTH2_STATE_ATTRIBUTE, state);
    if (useAuthenticateUrl) {
      return oauthOperations.buildAuthenticateUrl(parameters);
    } else {
      return oauthOperations.buildAuthorizeUrl(parameters);
View Full Code Here

      return oauthOperations.buildAuthorizeUrl(parameters);
    }
  }

  private OAuth2Parameters getOAuth2Parameters(NativeWebRequest request, String defaultScope, MultiValueMap<String, String> additionalParameters) {
    OAuth2Parameters parameters = new OAuth2Parameters(additionalParameters);
    parameters.putAll(getRequestParameters(request, "scope"));
    parameters.setRedirectUri(callbackUrl(request));
    String scope = request.getParameter("scope");
    if (scope != null) {
      parameters.setScope(scope);
    } else if (defaultScope != null) {
      parameters.setScope(defaultScope);
    }
    return parameters;
  }
View Full Code Here

  public static OAuth2Parameters oAuth2Parameters(final String redirectUri, final String scope, final String state) {
    return Matchers.argThat(new ArgumentMatcher<OAuth2Parameters>() {

      public boolean matches(Object item) {
        if (item instanceof OAuth2Parameters) {
          OAuth2Parameters params = (OAuth2Parameters) item;
          return eq(state, params.getState()) && eq(scope, params.getScope())
              && eq(redirectUri, params.getRedirectUri());
        }
        return false;
      }

    });
View Full Code Here

  }

  public SocialAuthenticationToken getAuthToken(HttpServletRequest request, HttpServletResponse response) throws SocialAuthenticationRedirectException {
    String code = request.getParameter("code");
    if (!StringUtils.hasText(code)) {
      OAuth2Parameters params =  new OAuth2Parameters();
      params.setRedirectUri(buildReturnToUrl(request));
      setScope(request, params);
      params.add("state", connectionFactory.generateState()); // TODO: Verify the state value after callback
      throw new SocialAuthenticationRedirectException(getConnectionFactory().getOAuthOperations().buildAuthenticateUrl(params));
    } else if (StringUtils.hasText(code)) {
      try {
        String returnToUrl = buildReturnToUrl(request);
        AccessGrant accessGrant = getConnectionFactory().getOAuthOperations().exchangeForAccess(code, returnToUrl, null);
View Full Code Here

    private static void authenticate()
        throws MalformedURLException
    {
        connectionFactory = new AlfrescoConnectionFactory(CONSUMER_KEY, CONSUMER_SECRET);

        OAuth2Parameters parameters = new OAuth2Parameters();
        parameters.setRedirectUri(REDIRECT_URI);
        parameters.setScope(Alfresco.DEFAULT_SCOPE);
        parameters.setState(STATE);

        authUrlObject = new AuthUrl(connectionFactory.getOAuthOperations().buildAuthenticateUrl(GrantType.AUTHORIZATION_CODE, parameters));
    }
View Full Code Here

    return appSecret;
  }
 
  public static final class FakeServiceProvider extends AbstractOAuth2ServiceProvider<Fake> {
    public FakeServiceProvider(String appId, String appSecret) {
      super(new OAuth2Template(appId, appSecret, "http://fake.com/auth", "http://fake.com/token"));
    }
View Full Code Here

TOP

Related Classes of org.springframework.social.oauth2.OAuth2RequestInterceptor

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.