2016-04-29 00:00:04 -04:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
2016-04-29 23:59:13 -04:00
|
|
|
"os"
|
2016-04-29 00:00:04 -04:00
|
|
|
|
|
|
|
"github.com/apexskier/httpauth"
|
|
|
|
)
|
|
|
|
|
2016-04-29 10:37:21 -04:00
|
|
|
type AuthHTTP struct {
|
2016-04-29 00:00:04 -04:00
|
|
|
backend httpauth.LeveldbAuthBackend
|
|
|
|
aaa httpauth.Authorizer
|
|
|
|
}
|
|
|
|
|
2016-04-29 23:59:13 -04:00
|
|
|
type User struct {
|
|
|
|
Username string
|
|
|
|
Password string
|
|
|
|
Role string
|
|
|
|
}
|
|
|
|
|
2016-04-29 10:37:21 -04:00
|
|
|
func initAuth() *AuthHTTP {
|
|
|
|
return &AuthHTTP{}
|
2016-04-29 00:00:04 -04:00
|
|
|
}
|
|
|
|
|
2016-04-29 23:59:13 -04:00
|
|
|
func (auth *AuthHTTP) createAuthDb(backendFile string) error {
|
|
|
|
var err error
|
|
|
|
os.Mkdir(backendFile, 0755)
|
|
|
|
|
|
|
|
auth.backend, err = httpauth.NewLeveldbAuthBackend(backendFile)
|
|
|
|
if err != nil {
|
|
|
|
log.Printf("Error creating Auth backend: %s", err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2016-04-29 10:37:21 -04:00
|
|
|
func (auth *AuthHTTP) createRoles() {
|
|
|
|
var err error
|
2016-04-29 00:00:04 -04:00
|
|
|
roles := make(map[string]httpauth.Role)
|
|
|
|
|
|
|
|
roles["user"] = 30
|
|
|
|
roles["admin"] = 80
|
2016-04-29 10:37:21 -04:00
|
|
|
auth.aaa, err = httpauth.NewAuthorizer(auth.backend, []byte("topsecretkey"), "user", roles)
|
|
|
|
if err != nil {
|
|
|
|
log.Printf("Error creating roles: %s", err)
|
|
|
|
}
|
2016-04-29 00:00:04 -04:00
|
|
|
}
|
|
|
|
|
2016-04-29 23:59:13 -04:00
|
|
|
func (auth *AuthHTTP) createUser(username, password, role, email string) error {
|
2016-04-29 10:37:21 -04:00
|
|
|
user := httpauth.UserData{Username: username, Role: role, Email: email}
|
|
|
|
err := auth.backend.SaveUser(user)
|
2016-04-29 00:00:04 -04:00
|
|
|
if err != nil {
|
|
|
|
log.Printf("Error saving user: %s", err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2016-04-29 10:37:21 -04:00
|
|
|
err = auth.aaa.Update(nil, nil, username, password, "")
|
2016-04-29 00:00:04 -04:00
|
|
|
if err != nil {
|
|
|
|
log.Printf("Error saving user: %s", err)
|
|
|
|
return err
|
|
|
|
}
|
2016-04-29 10:37:21 -04:00
|
|
|
|
|
|
|
return nil
|
2016-04-29 00:00:04 -04:00
|
|
|
}
|