2016-04-29 06:00:04 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
|
|
|
|
"github.com/apexskier/httpauth"
|
|
|
|
)
|
|
|
|
|
2016-04-29 16:37:21 +02:00
|
|
|
type AuthHTTP struct {
|
2016-04-29 06:00:04 +02:00
|
|
|
backend httpauth.LeveldbAuthBackend
|
|
|
|
aaa httpauth.Authorizer
|
|
|
|
}
|
|
|
|
|
2016-04-29 16:37:21 +02:00
|
|
|
func initAuth() *AuthHTTP {
|
|
|
|
return &AuthHTTP{}
|
2016-04-29 06:00:04 +02:00
|
|
|
}
|
|
|
|
|
2016-04-29 16:37:21 +02:00
|
|
|
func (auth *AuthHTTP) createRoles() {
|
|
|
|
var err error
|
2016-04-29 06:00:04 +02:00
|
|
|
roles := make(map[string]httpauth.Role)
|
|
|
|
|
|
|
|
roles["user"] = 30
|
|
|
|
roles["admin"] = 80
|
2016-04-29 16:37:21 +02: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 06:00:04 +02:00
|
|
|
}
|
|
|
|
|
2016-04-29 16:37:21 +02:00
|
|
|
func (auth *AuthHTTP) createUser(username, role, password, email string) error {
|
|
|
|
user := httpauth.UserData{Username: username, Role: role, Email: email}
|
|
|
|
err := auth.backend.SaveUser(user)
|
2016-04-29 06:00:04 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Printf("Error saving user: %s", err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2016-04-29 16:37:21 +02:00
|
|
|
err = auth.aaa.Update(nil, nil, username, password, "")
|
2016-04-29 06:00:04 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Printf("Error saving user: %s", err)
|
|
|
|
return err
|
|
|
|
}
|
2016-04-29 16:37:21 +02:00
|
|
|
|
|
|
|
return nil
|
2016-04-29 06:00:04 +02:00
|
|
|
}
|