Facebook Android: java.lang.UnsupportedOperationException: сеанс: была сделана попытка запросить новый запрос, ожидающий рассмотрения

Я отправляю сообщение на фан-страницу Facebook в своем приложении, но получаю сообщение об ошибке, которое я не могу понять.

Ошибка:

java.lang.UnsupportedOperationException: Session: была сделана попытка запросить новые разрешения для сеанса с ожидающим запросом.

Я могу опубликовать данные на своей стене, но когда я хочу опубликовать данные на фан-странице Facebook в моем приложении, я получаю вышеуказанную ошибку.
Фрагменты кода:

public class FacebookShareFragment extends Fragment {

    private ProgressDialog progressDialog;
    private UiLifecycleHelper uiHelper;
    private static final List<String> PERMISSIONS = Arrays.asList("publish_actions","manage_pages","publish_stream");
    private static final String PENDING_PUBLISH_KEY = "pendingPublishReauthorization";
    private boolean pendingPublishReauthorization = false;

    private Session.StatusCallback callback = new Session.StatusCallback() {
        @Override
        public void call(final Session session,
                         final SessionState state,
                         final Exception exception) {
            onSessionStateChange(session, state, exception);
        }
    };

 @Override
    public View onCreateView(LayoutInflater inflater,
                             ViewGroup container,
                             Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.facebook_share_fragment, container, false);
        if (savedInstanceState != null) {
            pendingPublishReauthorization =
                    savedInstanceState.getBoolean(PENDING_PUBLISH_KEY, false);
        }
 shareOnFanPage();
 return view;
}

 @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        uiHelper = new UiLifecycleHelper(getActivity(), callback);
        uiHelper.onCreate(savedInstanceState);
    }
@Override
    public void onResume() {
        super.onResume();
        Session session = Session.getActiveSession();
        if (session != null &&
                (session.isOpened() || session.isClosed()) ) {
            onSessionStateChange(session, session.getState(), null);
        }

        uiHelper.onResume();
    }

 @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        uiHelper.onActivityResult(requestCode, resultCode, data);
    }

    @Override
    public void onPause() {
        super.onPause();
        uiHelper.onPause();
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
        uiHelper.onDestroy();
    }

    @Override
    public void onSaveInstanceState(Bundle outState) {
        super.onSaveInstanceState(outState);
        outState.putBoolean(PENDING_PUBLISH_KEY, pendingPublishReauthorization);
        uiHelper.onSaveInstanceState(outState);
    }

    private void onSessionStateChange(Session session, SessionState state, Exception exception) {
        if (state.isOpened()) {
            if (pendingPublishReauthorization &&
                    state.equals(SessionState.OPENED_TOKEN_UPDATED)) {
                pendingPublishReauthorization = false;
       //         publishStory();
                shareOnFanPage();
            }
        } else if (state.isClosed()) {
        }
    }

    /**
     *  Method to publish on the fan page
     */
    public void shareOnFanPage(){
        Session session = Session.getActiveSession();
        if (session != null) {
            List<String> permissions = session.getPermissions();
            if (!isSubsetOf(PERMISSIONS, permissions)) {
                pendingPublishReauthorization = true;
                Session.NewPermissionsRequest newPermissionsRequest = new Session
                        .NewPermissionsRequest(this, PERMISSIONS);
                session.requestNewPublishPermissions(newPermissionsRequest); // AT THIS POINT I AM GETTING THE ERROR.
                return;
            }

            // Show a progress dialog because the batch request could take a while.
            progressDialog = ProgressDialog.show(getActivity(), "",
                    getActivity().getResources().getString(R.string.progress_dialog_text), true);

            try {
                final RequestBatch requestBatch = new RequestBatch();
                requestBatch.add(fbFan());
                requestBatch.executeAsync();
            }catch(Exception e){
                    e.printStackTrace();
            }
        }
    }

Сначала я смог выполнить публикацию данных на моей стене FB. Но позже, в соответствии с требованием, я добавил новые разрешения "manage_pages" и "publish_stream", но не знаю, почему я получаю сообщение об ошибке, даже когда я комментировал метод publishStory(), который опубликовать данные на моей стене FB.

Я прочитал много постов, но не смог понять...

1 ответ

Я полагаю, что onCreateView вызывается перед onActivityResult. В этом случае, если ваша деятельность хостинга была прервана до того, как запрос разрешений завершится (или если у вас включена опция dev "Не сохранять действия"), этот метод всегда будет вызываться перед onActivityResult.

Поскольку вы также вызываете shareOnFanPage в своем onCreateView, вы, по сути, собираетесь сделать еще один запрос разрешений до того, как завершится предыдущий (так как он завершается в onActivityResult при передаче его в uiLifecycleHelper).

Я бы вместо этого переместил вызов shareOnFanPage() на onResume или просто удалил его вообще, так как не думаю, что он вам нужен, поскольку вы уже собираетесь вызывать onSessionStateChanged в своем методе onResume.

Другие вопросы по тегам