dfabulich
(Dan Fabulich)
1
meta.discourse.org のメタサイトで、Facebookソーシャルログインが削除され、Discourse IDへの切り替えが推奨されているというバナーを見ました。そこで、Discourse IDへのリンクをクリックし、Facebookでサインインを試みましたが、失敗しました。
Facebookの設定が正しくないようです。Facebookログインはまだ機能しないため、11月30日の締め切りを延長すべきだと思います。
機能が利用できません
このアプリでは、追加の詳細情報を更新中のため、現在Facebookログインは利用できません。後でもう一度お試しください。
「いいね!」 2
pmusaraj
(Penar Musaraj)
2
ダン、レポートありがとうございます。Facebookアカウントでログインできましたが、App Reviewプロセスが変更されていることに気づいたため、レビューのリクエストを提出しました。Facebookアプリは特別なことは何もせず、Facebook経由でのログインを有効にするだけですが、それでもMeta(Facebook)によるレビューが必要です。できるだけ早くレビューされることを願っています。
レビューがどれだけ早く進むかによって、ここでMetaの締め切りを延長することを検討します。
「いいね!」 2
dfabulich
(Dan Fabulich)
3
Facebookログインでよくある落とし穴は、Facebookアプリの「開発者」としてFacebookの管理設定に記載されているユーザーでは機能するのに、一般ユーザーでは機能しないことです。
Facebookログインのテストに関するFacebookのガイドに従うことで、問題を再現できると思います。
「いいね!」 1
pmusaraj
(Penar Musaraj)
4
良い提案、ありがとうございます。ちょうどそれを実行し、アプリの管理者または開発者ではない使い捨てアカウントでログインしました。この画面が表示されました。
「いいね!」 1
dfabulich
(Dan Fabulich)
5
今は少し改善されましたが、まだ完全に機能していません。リダイレクトURLが間違ったURLに設定されていると思います。
再現手順:
pmusaraj
(Penar Musaraj)
6
それらの手順に従うと、id.discourse.com のホームページにリダイレクトされます。メタにはリダイレクトされません。ID にログインし、ID のホームページが表示されます。
ただし、
以前のメタログイン試行から何か残っている可能性があります… 別のブラウザで再現できますか?
pmusaraj
(Penar Musaraj)
9
ありがとうございます。特定の条件下で再現できることがわかりました。何が起こっているのか理解できたと思います。
ユーザーがメタから認証を開始すると、IDインスタンスに destination_url の値を保存し、認証後にユーザーを元の場所に戻せるようにします。しかし、認証が短時間で完了しない場合(失敗するか、ユーザーが認証を中止した場合)、その destination_url はクリーンアップされず、ユーザーのブラウザセッションに残ります。次にユーザーがログインしようとすると、IDはそのURLにリダイレクトしようとしますが、元の認証フローからの古いコード/状態の組み合わせがあるため、リダイレクトは「申し訳ありませんが、承認がタイムアウトしました」というエラーになります。
短時間経過後にリダイレクトしないようにする必要があります。destination_url の値が10分後にクリーンアップされるようにする必要があります。認証のコード/状態の組み合わせは10分間しか有効ではないと思いますが、確認が必要です。
「いいね!」 3