Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Duplicate continuity cookies cause requests to fail #2121

Closed
aeneasr opened this issue Jan 8, 2022 · 2 comments · Fixed by #2123
Closed

Duplicate continuity cookies cause requests to fail #2121

aeneasr opened this issue Jan 8, 2022 · 2 comments · Fixed by #2123
Assignees
Labels
bug Something is not working.

Comments

@aeneasr
Copy link
Member

aeneasr commented Jan 8, 2022

As experienced multiple times by @amorevino and just captured by @sashatalalasha

Google callback request:

curl 'https://project.console.ory.sh/api/kratos/public/self-service/methods/oidc/callback/google?....' \
  -H 'authority: project.console.ory.sh' \
  -H 'sec-ch-ua: " Not A;Brand";v="99", "Chromium";v="96", "Google Chrome";v="96"' \
  -H 'sec-ch-ua-mobile: ?0' \
  -H 'sec-ch-ua-platform: "macOS"' \
  -H 'upgrade-insecure-requests: 1' \
  -H 'user-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/96.0.4664.110 Safari/537.36' \
  -H 'accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9' \
  -H 'sec-fetch-site: cross-site' \
  -H 'sec-fetch-mode: navigate' \
  -H 'sec-fetch-user: ?1' \
  -H 'sec-fetch-dest: document' \
  -H 'referer: https://accounts.google.com/' \
  -H 'accept-language: en-US,en;q=0.9' \
  -H 'cookie: ory_kratos_continuity=1; __cfruid=eed8572e5941e594b11253131c2656bb86fe5533-1640599019; csrf_token_e9d6d5f4d737a26e1f7090a79427dd512f6=1=; __cflb=; sticky=; ory_kratos_continuity=2' \
  --compressed

Google callback response headers:

    :authority: project.console.ory.sh
    :method: GET
    :path: /api/kratos/public/self-service/methods/oidc/callback/google?state=...
    :scheme: https
    accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
    accept-encoding: gzip, deflate, br
    accept-language: en-US,en;q=0.9
    cookie: ory_kratos_continuity=1; __cfruid=...-1640599019; ...=...=; __cflb=...; sticky=...; ory_kratos_continuity=2--VTVmGZlj1Iuziui62qXHY_p
    referer: https://accounts.google.com/
    sec-ch-ua: " Not A;Brand";v="99", "Chromium";v="96", "Google Chrome";v="96"
    sec-ch-ua-mobile: ?0
    sec-ch-ua-platform: "macOS"
    sec-fetch-dest: document
    sec-fetch-mode: navigate
    sec-fetch-site: cross-site
    sec-fetch-user: ?1
    upgrade-insecure-requests: 1
    user-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/96.0.4664.110 Safari/537.36

redirects to error page with error:

{
  "id": "c7235a89-b79b-4db0-aa7f-0b8c0d565581",
  "error": {
    "code": 400,
    "debug": "Resumable ID from cookie could not be found in the datastore: id=\nrid=\nerror=Unable to locate the resource\nreason=\ndetails=map[]\ndebug=\n\ngithub.com/ory/x/sqlcon.HandleError\n\t/go/pkg/mod/github.com/ory/x@v0.0.310/sqlcon/error.go:68\ngithub.com/ory/kratos/persistence/sql.(*Persister).GetContinuitySession\n\t/go/pkg/mod/github.com/ory/kratos@v0.8.0-alpha.4.pre.0.0.20211116085910-648a7bb36ae8/persistence/sql/persister_continuity.go:28\ngithub.com/ory/kratos/continuity.(*ManagerCookie).container\n\t/go/pkg/mod/github.com/ory/kratos@v0.8.0-alpha.4.pre.0.0.20211116085910-648a7bb36ae8/continuity/manager_cookie.go:114\ngithub.com/ory/kratos/continuity.(*ManagerCookie).Continue\n\t/go/pkg/mod/github.com/ory/kratos@v0.8.0-alpha.4.pre.0.0.20211116085910-648a7bb36ae8/continuity/manager_cookie.go:64\ngithub.com/ory/kratos/selfservice/strategy/oidc.(*Strategy).validateCallback\n\t/go/pkg/mod/github.com/ory/kratos@v0.8.0-alpha.4.pre.0.0.20211116085910-648a7bb36ae8/selfservice/strategy/oidc/strategy.go:253\ngithub.com/ory/kratos/selfservice/strategy/oidc.(*Strategy).handleCallback\n\t/go/pkg/mod/github.com/ory/kratos@v0.8.0-alpha.4.pre.0.0.20211116085910-648a7bb36ae8/selfservice/strategy/oidc/strategy.go:297\ngithub.com/ory/kratos/selfservice/strategy.disabledWriter\n\t/go/pkg/mod/github.com/ory/kratos@v0.8.0-alpha.4.pre.0.0.20211116085910-648a7bb36ae8/selfservice/strategy/handler.go:25\ngithub.com/ory/kratos/selfservice/strategy.IsDisabled.func1\n\t/go/pkg/mod/github.com/ory/kratos@v0.8.0-alpha.4.pre.0.0.20211116085910-648a7bb36ae8/selfservice/strategy/handler.go:30\ngithub.com/ory/kratos/x.NoCacheHandler.func1\n\t/go/pkg/mod/github.com/ory/kratos@v0.8.0-alpha.4.pre.0.0.20211116085910-648a7bb36ae8/x/nocache.go:18\ngithub.com/julienschmidt/httprouter.(*Router).ServeHTTP\n\t/go/pkg/mod/github.com/julienschmidt/httprouter@v1.3.0/router.go:387\ngithub.com/ory/nosurf.(*CSRFHandler).handleSuccess\n\t/go/pkg/mod/github.com/ory/nosurf@v1.2.6-0.20211103120239-6dd721858902/handler.go:212\ngithub.com/ory/nosurf.(*CSRFHandler).ServeHTTP\n\t/go/pkg/mod/github.com/ory/nosurf@v1.2.6-0.20211103120239-6dd721858902/handler.go:169\ngithub.com/urfave/negroni.Wrap.func1\n\t/go/pkg/mod/github.com/urfave/negroni@v1.0.0/negroni.go:46\ngithub.com/urfave/negroni.HandlerFunc.ServeHTTP\n\t/go/pkg/mod/github.com/urfave/negroni@v1.0.0/negroni.go:29\ngithub.com/urfave/negroni.middleware.ServeHTTP\n\t/go/pkg/mod/github.com/urfave/negroni@v1.0.0/negroni.go:38\ngithub.com/ory/kratos/x.glob..func1\n\t/go/pkg/mod/github.com/ory/kratos@v0.8.0-alpha.4.pre.0.0.20211116085910-648a7bb36ae8/x/clean_url.go:12\ngithub.com/urfave/negroni.HandlerFunc.ServeHTTP\n\t/go/pkg/mod/github.com/urfave/negroni@v1.0.0/negroni.go:29\ngithub.com/urfave/negroni.middleware.ServeHTTP\n\t/go/pkg/mod/github.com/urfave/negroni@v1.0.0/negroni.go:38\nnet/http.HandlerFunc.ServeHTTP\n\t/usr/local/go/src/net/http/server.go:2050\ngithub.com/prometheus/client_golang/prometheus/promhttp.InstrumentHandlerResponseSize.func1\n\t/go/pkg/mod/github.com/prometheus/client_golang@v1.11.0/prometheus/promhttp/instrument_server.go:198\nnet/http.HandlerFunc.ServeHTTP\n\t/usr/local/go/src/net/http/server.go:2050\ngithub.com/prometheus/client_golang/prometheus/promhttp.InstrumentHandlerCounter.func1\n\t/go/pkg/mod/github.com/prometheus/client_golang@v1.11.0/prometheus/promhttp/instrument_server.go:101\nnet/http.HandlerFunc.ServeHTTP\n\t/usr/local/go/src/net/http/server.go:2050\ngithub.com/prometheus/client_golang/prometheus/promhttp.InstrumentHandlerDuration.func1\n\t/go/pkg/mod/github.com/prometheus/client_golang@v1.11.0/prometheus/promhttp/instrument_server.go:68\nnet/http.HandlerFunc.ServeHTTP\n\t/usr/local/go/src/net/http/server.go:2050\ngithub.com/prometheus/client_golang/prometheus/promhttp.InstrumentHandlerDuration.func2\n\t/go/pkg/mod/github.com/prometheus/client_golang@v1.11.0/prometheus/promhttp/instrument_server.go:76\nnet/http.HandlerFunc.ServeHTTP\n\t/usr/local/go/src/net/http/server.go:2050\ngithub.com/prometheus/client_golang/prometheus/promhttp.InstrumentHandlerRequestSize.func1\n\t/go/pkg/mod/github.com/prometheus/client_golang@v1.11.0/prometheus/promhttp/instrument_server.go:165\nnet/http.HandlerFunc.ServeHTTP\n\t/usr/local/go/src/net/http/server.go:2050\ngithub.com/ory/x/prometheusx.Metrics.instrumentHandlerStatusBucket.func1\n\t/go/pkg/mod/github.com/ory/x@v0.0.310/prometheusx/metrics.go:108\nnet/http.HandlerFunc.ServeHTTP\n\t/usr/local/go/src/net/http/server.go:2050\ngithub.com/ory/x/prometheusx.(*MetricsManager).ServeHTTP\n\t/go/pkg/mod/github.com/ory/x@v0.0.310/prometheusx/middleware.go:30",
    "message": "session is not resumable",
    "reason": "No resumable session could be found in the HTTP Header.",
    "status": "Bad Request"
  },
  "created_at": "2022-01-07T13:26:09.432572Z",
  "updated_at": "2022-01-07T13:26:09.432572Z"
}
@aeneasr aeneasr added the bug Something is not working. label Jan 8, 2022
@aeneasr aeneasr self-assigned this Jan 8, 2022
aeneasr added a commit to ory/nosurf that referenced this issue Jan 8, 2022
Resolves an issue where, when multiple CSRF cookies are set, a random one would be used to verify the CSRF token. Now, regardless of how many conflicting CSRF cookies exist, if one of them is valid, the request will pass and clean up the cookie store.

See ory/kratos#2121
See ory-corp/cloud#1786
aeneasr added a commit to ory/nosurf that referenced this issue Jan 8, 2022
Resolves an issue where, when multiple CSRF cookies are set, a random one would be used to verify the CSRF token. Now, regardless of how many conflicting CSRF cookies exist, if one of them is valid, the request will pass and clean up the cookie store.

See ory/kratos#2121
See ory-corp/cloud#1786
aeneasr added a commit that referenced this issue Jan 8, 2022
Resolves an issue where, when multiple CSRF cookies are set, a random one would be used to verify the CSRF token. Now, regardless of how many conflicting CSRF cookies exist, if one of them is valid, the request will pass and clean up the cookie store.

See #2121
See ory-corp/cloud#1786
aeneasr added a commit that referenced this issue Jan 8, 2022
Resolves an issue where, when multiple CSRF cookies are set, a random one would be used to verify the CSRF token. Now, regardless of how many conflicting CSRF cookies exist, if one of them is valid, the request will pass and clean up the cookie store.

See #2121
See ory-corp/cloud#1786
aeneasr added a commit that referenced this issue Jan 8, 2022
Resolves an issue where, when multiple CSRF cookies are set, a random one would be used to verify the CSRF token. Now, regardless of how many conflicting CSRF cookies exist, if one of them is valid, the request will pass and clean up the cookie store.

See #2121
See ory-corp/cloud#1786
@aeneasr
Copy link
Member Author

aeneasr commented Jan 8, 2022

I was able to reproduce this by changing the cookie's signature to something else which means, probably, that the signature will cause a mismatch. In this case, I am consistently able to reproduce this issue.

@aeneasr
Copy link
Member Author

aeneasr commented Jan 8, 2022

This would then also explain why, when two cookies are given, and the first one is always a dud, the error does not go away on a retry. That is because the cookie is never updated when there is a cookie match, but a signature mismatch.

aeneasr added a commit that referenced this issue Jan 8, 2022
Resolves several reports related to incorrect handling of invalid continuity issues.

Closes #2121
Closes ory-corp/cloud#1786
Closes #2016
Potentially #2108
aeneasr added a commit that referenced this issue Jan 8, 2022
Resolves several reports related to incorrect handling of invalid continuity issues.

Closes #2121
Closes ory-corp/cloud#1786
Closes #2016
Potentially #2108
aeneasr added a commit that referenced this issue Jan 8, 2022
Resolves several reports related to incorrect handling of invalid continuity issues.

Closes #2121
Closes ory-corp/cloud#1786
Closes #2016
Potentially #2108
peturgeorgievv pushed a commit to senteca/kratos-fork that referenced this issue Jun 30, 2023
Resolves an issue where, when multiple CSRF cookies are set, a random one would be used to verify the CSRF token. Now, regardless of how many conflicting CSRF cookies exist, if one of them is valid, the request will pass and clean up the cookie store.

See ory#2121
See ory-corp/cloud#1786
peturgeorgievv pushed a commit to senteca/kratos-fork that referenced this issue Jun 30, 2023
Resolves several reports related to incorrect handling of invalid continuity issues.

Closes ory#2121
Closes ory-corp/cloud#1786
Closes ory#2016
Potentially ory#2108
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something is not working.
Projects
None yet
Development

Successfully merging a pull request may close this issue.

1 participant