SSO リダイレクトループ

Hey there,

we’re using Discourse [v2.3.0.beta2 +130] with SSO. For a few months now (sorry that I can’t pinpoint the exact update that caused the issue) collegues are reporting SSO redirect loops (followed by 429 errors which is ok) when clicking on discourse links in webmail clients. This only happens, if one is already logged in. We can reproduce in Firefox and Chrome on Windows and Linux. Steps to reproduce:

  • When logged out of discourse (all cookies cleaned etc)
  • Click on a Disourse link in Gmail or Zimbra
  • A new tab opens with the Discourse URL
  • After getting redirected to our SSO login enter your credencials
  • You get successfully logged in
  • Click on another Discourse link in Gmail or Zimbra
  • A new tab opens with the Discourse URL
  • You get redirected to the SSO login
  • Then you get redirected back to Disrourse with the token in the URL
  • Then Discourse redirects you back to the SSO login
  • and so on …

Strangly this doesn’t happen if the link is copy/pasted instead of clicked on. This strikes me as weird.

These are the URLs in the loop

  • https:// forum.our.tld/
  • https:// forum.our.tld/session/sso
  • https:// sso.our.tld/sso/discourse?sso=bm9u…%3D%3D&sig=3944…
  • https:// forum.our.tld/session/sso_login?sso=bm9uY…1B%0AbmRyZWFz…Vhc19sYXV0X…JTQwZ2…dHAlM0ElMkYl…BBKitodHRw…pdG9y…rJTI4ZW…Vu%0AZGUr…9fdXJs%0APWh0…Nlc3Npb2…3D%0A&sig=13f4…

I found similar topics here but none of them is matching my exact problem:

Any ideas what might be wrong here?

I’d be interested to check the email provider responsible for sending emails on behalf of your discourse install, I’ve seen similar behaviour on a client when they accidentally enabled email tracking (which essentially rewrites the links) on the discourse emails.

There can be other potential candidates too which may need the forum link for identification.

Discourse is sending mails via our own mailservers. There’s no link rewriting or tracking involved.

I also suspected Gmail at first, but the issue is the same with Zimbra.

Did you check the email raw? Maybe something interesting can be found there.

But before I row this to the wrong bank, are those links actually being opened in a real browser or some sort of web-view

It’s a real desktop browser. Right-click → copy link location → paste works. A simple left-click opens a new tab and then hangs in the loop. I don’t know if some Javascript is interfering with what’s actually happening or if it’s just a target=blank.

I think You really need to check the email RAW for possible issues since the link being sent is correct.

I can even reproduce with this page:

<!doctype html>
<html>
  <head><title>foo</title></head>
  <body>
    <a href="https://forum.our.tld/t/title/3940/551">https://forum.our.tld/t/title/3940/551</a>
  </body>
</html>

When clicking on the link I’m in the redirect loop, if I copy/paste it it works.
I’m … puzzeled.
The only thing I can think of that’s different in a browser when clicking on a link vs. copy/pasting the link is the referrer.

もしかすると最も自明なことを言っているかもしれませんが、この問題の発生源は WebKit WebView にあると考えています。
Discourse フォーラムのこちら に記載されている回避策を試してみましたが、成功しませんでした。

同僚の一人(私はウェブプログラマーではありませんが、彼はウェブプログラマーです)は、SSO プロバイダー側(myforum.com/session/sso_provider ではない方)で何らかの変更を加えることを提案しました。具体的には、SSO プロバイダーがフォーラムにリクエストを送る際に、URL クエリ文字列に login=mylogin という追加パラメータを含めるようにするものです。
おそらく、トークン作成の呼び出しは以下のように変更されるはずです。

myssoprovider.com/sso?sso=xxxxx&sig=xxxxx

myssoprovider.com/sso?sso=xxxxx&sig=xxxxx&login=mylogin

ただし、Discourse 側の設定パネルからこのような実装を行うことはできないと認識しています。これはより深い部分への改修が必要であり、問題を引き起こしたり、アップデートで失われたりする可能性があります。

ご提案をいただければ幸いです。

それについて、Apple が修正するのを待つしかないという考えはありますか?

@nikod さん、弊社でも同様の問題が発生しましたが、「same site cookies」の設定を「strict」から「lax」に変更することで解決しました:

「いいね!」 1