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.