diff options
author | Lauris BH <lauris@nix.lv> | 2018-04-29 09:09:24 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-04-29 09:09:24 +0300 |
commit | 5a62eb30df3a04e76e465824f525b4ffd920b562 (patch) | |
tree | c3410d159a14a6b6d36b2ffadebbfb7dd48617f9 /modules/auth/oauth2 | |
parent | 8d5f58d8347196fca04fdf3a22d021d09d15e37f (diff) | |
download | gitea-5a62eb30df3a04e76e465824f525b4ffd920b562.tar.gz gitea-5a62eb30df3a04e76e465824f525b4ffd920b562.zip |
Store OAuth2 session data in database (#3660)
* Store OAuth2 session data in database
* Rename table to `oauth2_session` and do not skip xormstorage initialization error
Diffstat (limited to 'modules/auth/oauth2')
-rw-r--r-- | modules/auth/oauth2/oauth2.go | 19 |
1 files changed, 10 insertions, 9 deletions
diff --git a/modules/auth/oauth2/oauth2.go b/modules/auth/oauth2/oauth2.go index 4584c48db7..89286a1bd6 100644 --- a/modules/auth/oauth2/oauth2.go +++ b/modules/auth/oauth2/oauth2.go @@ -7,13 +7,12 @@ package oauth2 import ( "math" "net/http" - "os" - "path/filepath" "code.gitea.io/gitea/modules/log" "code.gitea.io/gitea/modules/setting" - "github.com/gorilla/sessions" + "github.com/go-xorm/xorm" + "github.com/lafriks/xormstore" "github.com/markbates/goth" "github.com/markbates/goth/gothic" "github.com/markbates/goth/providers/bitbucket" @@ -41,13 +40,14 @@ type CustomURLMapping struct { } // Init initialize the setup of the OAuth2 library -func Init() { - sessionDir := filepath.Join(setting.AppDataPath, "sessions", "oauth2") - if err := os.MkdirAll(sessionDir, 0700); err != nil { - log.Fatal(4, "Fail to create dir %s: %v", sessionDir, err) - } +func Init(x *xorm.Engine) error { + store, err := xormstore.NewOptions(x, xormstore.Options{ + TableName: "oauth2_session", + }, []byte(sessionUsersStoreKey)) - store := sessions.NewFilesystemStore(sessionDir, []byte(sessionUsersStoreKey)) + if err != nil { + return err + } // according to the Goth lib: // set the maxLength of the cookies stored on the disk to a larger number to prevent issues with: // securecookie: the value is too long @@ -65,6 +65,7 @@ func Init() { return req.Header.Get(providerHeaderKey), nil } + return nil } // Auth OAuth2 auth service |