mirror of
https://github.com/volatiletech/authboss.git
synced 2025-01-08 04:03:53 +02:00
0754b965b1
- Fix #47: Remove ModuleAttrMeta from Storers. Rename to ModuleAttributes. - Add some additional deafult values to config.
74 lines
1.8 KiB
Go
74 lines
1.8 KiB
Go
/*
|
|
Package authboss is a modular authentication system for the web. It tries to
|
|
remove as much boilerplate and "hard things" as possible so that each time you
|
|
start a new web project in Go, you can plug it in, configure and be off to the
|
|
races without having to think about the hard questions like how to store
|
|
Remember Me tokens, or passwords.
|
|
*/
|
|
package authboss // import "gopkg.in/authboss.v0"
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
"strings"
|
|
)
|
|
|
|
// Init authboss and it's loaded modules.
|
|
func Init() error {
|
|
for name, mod := range modules {
|
|
fmt.Fprintf(Cfg.LogWriter, "%-10s Initializing\n", "["+name+"]")
|
|
if err := mod.Initialize(); err != nil {
|
|
return fmt.Errorf("[%s] Error Initializing: %v", name, err)
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// CurrentUser retrieves the current user from the session and the database.
|
|
func CurrentUser(w http.ResponseWriter, r *http.Request) (interface{}, error) {
|
|
ctx, err := ContextFromRequest(r)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
ctx.SessionStorer = clientStoreWrapper{Cfg.SessionStoreMaker(w, r)}
|
|
ctx.CookieStorer = clientStoreWrapper{Cfg.CookieStoreMaker(w, r)}
|
|
|
|
_, err = Cfg.Callbacks.FireBefore(EventGetUserSession, ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
key, ok := ctx.SessionStorer.Get(SessionKey)
|
|
if !ok {
|
|
return nil, nil
|
|
}
|
|
|
|
err = ctx.LoadUser(key)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
_, err = Cfg.Callbacks.FireBefore(EventGet, ctx)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if index := strings.IndexByte(key, ';'); index > 0 {
|
|
return Cfg.OAuth2Storer.GetOAuth(key[:index], key[index+1:])
|
|
}
|
|
|
|
return Cfg.Storer.Get(key)
|
|
}
|
|
|
|
// CurrentUserP retrieves the current user but panics if it's not available for
|
|
// any reason.
|
|
func CurrentUserP(w http.ResponseWriter, r *http.Request) interface{} {
|
|
i, err := CurrentUser(w, r)
|
|
if err != nil {
|
|
panic(err.Error())
|
|
}
|
|
return i
|
|
}
|