summaryrefslogtreecommitdiffstats
path: root/routers/routes/recovery.go
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2021-01-08 20:15:06 +0800
committerGitHub <noreply@github.com>2021-01-08 14:15:06 +0200
commitce43d38b4ffa40255cc8f859c5b31f59351f827c (patch)
treed309312f735491278abe31493e70370259d11002 /routers/routes/recovery.go
parent461406070c1fa8015d6dba17ae32bb43f78db3fc (diff)
downloadgitea-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.go13
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)
}