2015-01-03 12:03:57 -08:00
|
|
|
package authboss
|
|
|
|
|
2015-01-05 00:18:41 -08:00
|
|
|
import (
|
2015-02-01 14:17:18 -08:00
|
|
|
"html/template"
|
2015-01-05 00:18:41 -08:00
|
|
|
"io"
|
|
|
|
"io/ioutil"
|
2015-02-24 14:45:37 -08:00
|
|
|
"net/http"
|
2015-01-25 15:40:57 -08:00
|
|
|
"net/smtp"
|
2015-01-23 16:25:12 -08:00
|
|
|
"time"
|
2015-01-30 15:38:28 -08:00
|
|
|
|
|
|
|
"golang.org/x/crypto/bcrypt"
|
2015-02-08 23:08:33 -08:00
|
|
|
)
|
|
|
|
|
2015-02-15 20:07:36 -08:00
|
|
|
// Cfg is the singleton instance of Config
|
|
|
|
var Cfg *Config = NewConfig()
|
|
|
|
|
2015-01-05 00:18:41 -08:00
|
|
|
// Config holds all the configuration for both authboss and it's modules.
|
2015-01-04 10:33:53 -08:00
|
|
|
type Config struct {
|
2015-02-22 13:16:11 -08:00
|
|
|
// MountPath is the path to mount authboss's routes at (eg /auth).
|
2015-01-25 22:58:50 -08:00
|
|
|
MountPath string
|
2015-02-22 13:16:11 -08:00
|
|
|
// ViewsPath is the path to search for overridden templates.
|
2015-01-25 22:58:50 -08:00
|
|
|
ViewsPath string
|
2015-02-26 22:01:53 -08:00
|
|
|
// HostName is the host of the web application (eg https://www.happiness.com:8080) for e-mail url generation. No trailing slash.
|
2015-01-25 22:58:50 -08:00
|
|
|
HostName string
|
2015-02-22 13:16:11 -08:00
|
|
|
// BCryptCost is the cost of the bcrypt password hashing function.
|
2015-01-30 15:38:28 -08:00
|
|
|
BCryptCost int
|
2015-01-04 10:33:53 -08:00
|
|
|
|
2015-02-22 13:16:11 -08:00
|
|
|
// PrimaryID is the primary identifier of the user. Set to one of:
|
|
|
|
// authboss.StoreEmail, authboss.StoreUsername (StoreEmail is default)
|
|
|
|
PrimaryID string
|
|
|
|
|
2015-02-01 15:51:01 -08:00
|
|
|
Layout *template.Template
|
|
|
|
LayoutEmail *template.Template
|
|
|
|
LayoutDataMaker ViewDataMaker
|
2015-02-01 14:17:18 -08:00
|
|
|
|
2015-02-24 14:45:37 -08:00
|
|
|
// ErrorHandler handles would be 500 errors.
|
|
|
|
ErrorHandler http.Handler
|
|
|
|
// BadRequestHandler handles would be 400 errors.
|
|
|
|
BadRequestHandler http.Handler
|
|
|
|
// NotFoundHandler handles would be 404 errors.
|
|
|
|
NotFoundHandler http.Handler
|
|
|
|
|
2015-02-25 23:05:14 -08:00
|
|
|
AuthLoginOKPath string
|
|
|
|
AuthLoginFailPath string
|
|
|
|
AuthLogoutOKPath string
|
2015-01-04 10:33:53 -08:00
|
|
|
|
2015-02-25 23:05:14 -08:00
|
|
|
RecoverOKPath string
|
|
|
|
RecoverTokenDuration time.Duration
|
2015-01-17 23:37:05 -08:00
|
|
|
|
2015-01-25 22:58:50 -08:00
|
|
|
Policies []Validator
|
|
|
|
ConfirmFields []string
|
2015-01-25 18:13:32 -08:00
|
|
|
|
2015-02-22 13:16:11 -08:00
|
|
|
ExpireAfter time.Duration
|
|
|
|
|
2015-01-25 22:58:50 -08:00
|
|
|
LockAfter int
|
|
|
|
LockWindow time.Duration
|
|
|
|
LockDuration time.Duration
|
2015-01-23 16:25:12 -08:00
|
|
|
|
2015-01-25 22:58:50 -08:00
|
|
|
EmailFrom string
|
|
|
|
EmailSubjectPrefix string
|
2015-01-27 17:34:55 -08:00
|
|
|
SMTPAddress string
|
|
|
|
SMTPAuth smtp.Auth
|
2015-01-25 15:40:57 -08:00
|
|
|
|
2015-01-27 17:34:55 -08:00
|
|
|
XSRFName string
|
|
|
|
XSRFMaker XSRF
|
2015-01-25 15:40:57 -08:00
|
|
|
|
2015-01-25 22:58:50 -08:00
|
|
|
Storer Storer
|
|
|
|
CookieStoreMaker CookieStoreMaker
|
|
|
|
SessionStoreMaker SessionStoreMaker
|
|
|
|
LogWriter io.Writer
|
|
|
|
Callbacks *Callbacks
|
|
|
|
Mailer Mailer
|
2015-01-05 00:18:41 -08:00
|
|
|
}
|
2015-01-04 10:33:53 -08:00
|
|
|
|
2015-01-05 00:18:41 -08:00
|
|
|
func NewConfig() *Config {
|
|
|
|
return &Config{
|
2015-01-30 15:38:28 -08:00
|
|
|
MountPath: "/",
|
|
|
|
ViewsPath: "/",
|
|
|
|
HostName: "localhost:8080",
|
|
|
|
BCryptCost: bcrypt.DefaultCost,
|
2015-01-10 23:12:40 -08:00
|
|
|
|
2015-02-22 13:16:11 -08:00
|
|
|
PrimaryID: StoreEmail,
|
|
|
|
|
2015-02-20 23:33:35 -08:00
|
|
|
Layout: template.Must(template.New("").Parse(`<html><body>{{template "authboss" .}}</body></html>`)),
|
|
|
|
LayoutEmail: template.Must(template.New("").Parse(`<html><body>{{template "authboss" .}}</body></html>`)),
|
2015-02-08 23:08:33 -08:00
|
|
|
|
2015-02-25 23:05:14 -08:00
|
|
|
AuthLoginOKPath: "/",
|
|
|
|
AuthLoginFailPath: "/",
|
|
|
|
AuthLogoutOKPath: "/",
|
2015-01-18 14:24:20 -08:00
|
|
|
|
2015-01-30 15:38:28 -08:00
|
|
|
Policies: []Validator{
|
|
|
|
Rules{
|
|
|
|
FieldName: "username",
|
|
|
|
Required: true,
|
|
|
|
MinLength: 2,
|
|
|
|
MaxLength: 4,
|
|
|
|
AllowWhitespace: false,
|
|
|
|
},
|
|
|
|
Rules{
|
|
|
|
FieldName: "password",
|
|
|
|
Required: true,
|
|
|
|
MinLength: 4,
|
|
|
|
MaxLength: 8,
|
|
|
|
|
|
|
|
AllowWhitespace: false,
|
|
|
|
},
|
|
|
|
},
|
2015-02-22 13:16:11 -08:00
|
|
|
ConfirmFields: []string{
|
2015-02-23 02:03:29 -08:00
|
|
|
StorePassword, ConfirmPrefix + StorePassword,
|
2015-02-22 13:16:11 -08:00
|
|
|
},
|
2015-01-30 15:38:28 -08:00
|
|
|
|
2015-02-26 23:09:37 -08:00
|
|
|
ExpireAfter: time.Duration(60) * time.Minute,
|
|
|
|
|
2015-02-25 23:05:14 -08:00
|
|
|
RecoverOKPath: "/",
|
|
|
|
RecoverTokenDuration: time.Duration(24) * time.Hour,
|
2015-01-25 22:58:50 -08:00
|
|
|
|
2015-01-05 00:18:41 -08:00
|
|
|
LogWriter: ioutil.Discard,
|
2015-01-15 14:01:01 -08:00
|
|
|
Callbacks: NewCallbacks(),
|
2015-01-25 15:40:57 -08:00
|
|
|
Mailer: LogMailer(ioutil.Discard),
|
2015-01-05 00:18:41 -08:00
|
|
|
}
|
2015-01-04 10:33:53 -08:00
|
|
|
}
|