aboutsummaryrefslogtreecommitdiffstats
path: root/modules/auth/oauth2
diff options
context:
space:
mode:
authorLauris BH <lauris@nix.lv>2018-04-29 09:09:24 +0300
committerGitHub <noreply@github.com>2018-04-29 09:09:24 +0300
commit5a62eb30df3a04e76e465824f525b4ffd920b562 (patch)
treec3410d159a14a6b6d36b2ffadebbfb7dd48617f9 /modules/auth/oauth2
parent8d5f58d8347196fca04fdf3a22d021d09d15e37f (diff)
downloadgitea-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.go19
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