1
0
Fork 0
mirror of https://codeberg.org/forgejo/forgejo.git synced 2024-11-23 08:47:42 -05:00
forgejo/vendor/github.com/lafriks/xormstore
2018-05-13 13:10:50 +08:00
..
util Store OAuth2 session data in database (#3660) 2018-04-29 09:09:24 +03:00
Gopkg.lock Store OAuth2 session data in database (#3660) 2018-04-29 09:09:24 +03:00
Gopkg.toml Store OAuth2 session data in database (#3660) 2018-04-29 09:09:24 +03:00
LICENSE Store OAuth2 session data in database (#3660) 2018-04-29 09:09:24 +03:00
README.md Store OAuth2 session data in database (#3660) 2018-04-29 09:09:24 +03:00
test Store OAuth2 session data in database (#3660) 2018-04-29 09:09:24 +03:00
xormstore.go Update xormstore dependency to fix OAuth2 support for MySQL (#3955) 2018-05-13 13:10:50 +08:00

GoDoc Build Status codecov

XORM backend for gorilla sessions

go get github.com/lafriks/xormstore

Example

// initialize and setup cleanup
store := xormstore.New(engine, []byte("secret"))
// db cleanup every hour
// close quit channel to stop cleanup
quit := make(chan struct{})
go store.PeriodicCleanup(1*time.Hour, quit)
// in HTTP handler
func handlerFunc(w http.ResponseWriter, r *http.Request) {
  session, err := store.Get(r, "session")
  session.Values["user_id"] = 123
  store.Save(r, w, session)
  http.Error(w, "", http.StatusOK)
}

For more details see xormstore godoc documentation.

Testing

Just sqlite3 tests:

go test

All databases using docker:

./test

If docker is not local (docker-machine etc):

DOCKER_IP=$(docker-machine ip dev) ./test

License

xormstore is licensed under the MIT license. See LICENSE for the full license text.