Search code examples
javaspringspring-social

Spring social - Exception while completing OAuth 2 connection: Authorization is required for the operation,


I am composing spring-social. When I click the / signin / facebook button:

Exception while completing OAuth 2 connection: Org.springframework.social.MissingAuthorizationException: Authorization is required for the operation, but the API was created without authorization.

I have encountered this error.
As a result of debugging, facebook access token seems to be well received.

An error occurs in this part after normal login of Facebook.
ConnectSupport class:

AccessGrant accessGrant = connectionFactory.getOAuthOperations().exchangeForAccess(code, callbackUrl(request), null);

This is my composition.

SocialConfig:

@Inject
private DataSource dataSource;

@Autowired
UserRepository userRepository;

@Autowired
PostSocialSignInAdapter postSocialSignInAdapter;

@Override
public UserIdSource getUserIdSource() {
    return new CUserIdSource();
}

@Override
public void addConnectionFactories(ConnectionFactoryConfigurer cfConfig, Environment env) {
    String appKey = "4123213121231231212331";
    String appSecret = "512312312lkjj1232kj3l1jl213";

    cfConfig.addConnectionFactory(new FacebookConnectionFactory(appKey, appSecret));
}

@Override
public UsersConnectionRepository getUsersConnectionRepository(ConnectionFactoryLocator connectionFactoryLocator) {
    JdbcUsersConnectionRepository repository = new JdbcUsersConnectionRepository(dataSource,
            connectionFactoryLocator, Encryptors.noOpText());
    repository.setConnectionSignUp(new SocialImplicitSignUp(userRepository));
    return repository;
}

@Bean
@Scope(value = "request", proxyMode = ScopedProxyMode.INTERFACES)
public Facebook facebook(ConnectionRepository repository) {
    Connection<Facebook> connection = repository.findPrimaryConnection(Facebook.class);
    return connection != null ? connection.getApi() : null;
}

@Bean
public ProviderSignInController providerSignInController(ConnectionFactoryLocator connectionFactoryLocator,
        UsersConnectionRepository usersConnectionRepository) {
    ProviderSignInController providerSignInController = new ProviderSignInController(connectionFactoryLocator,
            usersConnectionRepository, postSocialSignInAdapter);
    providerSignInController.setSignUpUrl("/");
    return providerSignInController;
}

UserRepository interface

public interface UserRepository extends JpaRepository<User, String> {
   public User findByusername(String username);
}

error log

ERROR: org.springframework.social.connect.web.ProviderSignInController - Exception while completing OAuth 2 connection: 
org.springframework.social.MissingAuthorizationException: Authorization is required for the operation, but the API binding was created without authorization.

    at org.springframework.social.facebook.api.impl.AbstractFacebookOperations.requireAuthorization(AbstractFacebookOperations.java:30)
at org.springframework.social.facebook.api.impl.UserTemplate.getUserProfile(UserTemplate.java:48)
at org.springframework.social.facebook.connect.FacebookAdapter.setConnectionValues(FacebookAdapter.java:42)
at org.springframework.social.facebook.connect.FacebookAdapter.setConnectionValues(FacebookAdapter.java:30)
at org.springframework.social.connect.support.AbstractConnection.setValues(AbstractConnection.java:175)
at org.springframework.social.connect.support.AbstractConnection.initKey(AbstractConnection.java:137)
at org.springframework.social.connect.support.OAuth2Connection.<init>(OAuth2Connection.java:75)

I do not know how to do this. Please help me.


Solution

  • This can be related to many causes but at first you should check your spring-social-facebook version. Since Facebook graph api 2.2 deprecation, Spring recommendation is to change the version to 2.0.3.RELEASE. Someone else was talking about a similar issue here "similar post

    Don't try the 2.0.2.RELEASE, AFAIK there is an issue with inconsistent property type unmapped on json call.