mirror of
https://github.com/volatiletech/authboss.git
synced 2025-01-10 04:17:59 +02:00
d4f4f6c443
Discovered many problems with the abstractions along the way and did small fixes to get to the end of the auth module. - Use more constants for random strings - Create forcing functions to deal with the upgrades to different interfaces
43 lines
1.1 KiB
Go
43 lines
1.1 KiB
Go
package authboss
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
)
|
|
|
|
// BodyReader reads data from the request
|
|
// and returns it in an abstract form.
|
|
// Typically used to decode JSON responses
|
|
// or Url Encoded request bodies.
|
|
//
|
|
// The first parameter is the page that this request
|
|
// was made on so we can tell what kind of JSON object
|
|
// or form was present as well as create the proper
|
|
// validation mechanisms.
|
|
//
|
|
// A typical example of this is taking the request
|
|
// and turning it into a JSON struct that knows how
|
|
// to validate itself and return certain fields.
|
|
type BodyReader interface {
|
|
Read(page string, r *http.Request) (Validator, error)
|
|
}
|
|
|
|
// UserValuer gets a string from a map-like data structure
|
|
// Typically a decoded JSON or form auth request
|
|
type UserValuer interface {
|
|
Validator
|
|
|
|
GetPID() string
|
|
GetPassword() string
|
|
}
|
|
|
|
// MustHaveUserValues upgrades a validatable set of values
|
|
// to ones specific to the user.
|
|
func MustHaveUserValues(v Validator) UserValuer {
|
|
if u, ok := v.(UserValuer); ok {
|
|
return u
|
|
}
|
|
|
|
panic(fmt.Sprintf("bodyreader returned a type that could not be upgraded to UserValuer: %T", v))
|
|
}
|