diff options
author | Lunny Xiao <xiaolunwen@gmail.com> | 2021-01-08 20:15:06 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-01-08 14:15:06 +0200 |
commit | ce43d38b4ffa40255cc8f859c5b31f59351f827c (patch) | |
tree | d309312f735491278abe31493e70370259d11002 /routers/routes/recovery.go | |
parent | 461406070c1fa8015d6dba17ae32bb43f78db3fc (diff) | |
download | gitea-ce43d38b4ffa40255cc8f859c5b31f59351f827c.tar.gz gitea-ce43d38b4ffa40255cc8f859c5b31f59351f827c.zip |
Fix session bug when introduce chi (#14287)
* Update go-chi session
Diffstat (limited to 'routers/routes/recovery.go')
-rw-r--r-- | routers/routes/recovery.go | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/routers/routes/recovery.go b/routers/routes/recovery.go index cf4b1a8d84..f392d1d553 100644 --- a/routers/routes/recovery.go +++ b/routers/routes/recovery.go @@ -14,7 +14,6 @@ import ( "code.gitea.io/gitea/modules/setting" "code.gitea.io/gitea/modules/templates" - "gitea.com/go-chi/session" "github.com/unrolled/render" ) @@ -64,7 +63,13 @@ func Recovery() func(next http.Handler) http.Handler { log.Error("%v", combinedErr) lc := middlewares.Locale(w, req) - sess := session.GetSession(req) + + // TODO: this should be replaced by real session after macaron removed totally + sessionStore, err := sessionManager.Start(w, req) + if err != nil { + // Just invoke the above recover catch + panic("session(start): " + err.Error()) + } var store = dataStore{ Data: templates.Vars{ @@ -75,7 +80,7 @@ func Recovery() func(next http.Handler) http.Handler { } // Get user from session if logged in. - user, _ := sso.SignedInUser(req, w, &store, sess) + user, _ := sso.SignedInUser(req, w, &store, sessionStore) if user != nil { store.Data["IsSigned"] = true store.Data["SignedUser"] = user @@ -92,7 +97,7 @@ func Recovery() func(next http.Handler) http.Handler { if setting.RunMode != "prod" { store.Data["ErrMsg"] = combinedErr } - err := rnd.HTML(w, 500, "status/500", templates.BaseVars().Merge(store.Data)) + err = rnd.HTML(w, 500, "status/500", templates.BaseVars().Merge(store.Data)) if err != nil { log.Error("%v", err) } |