basic

package
v1.3.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 6, 2020 License: MIT Imports: 9 Imported by: 3

Documentation

Overview

Package basic provides authentication strategy, to authenticate HTTP requests using the standard basic scheme.

Example
strategy := AuthenticateFunc(exampleAuthFunc)
authenticator := auth.New()
authenticator.EnableStrategy(StrategyKey, strategy)

// user request
req, _ := http.NewRequest("GET", "/", nil)
req.SetBasicAuth("test", "test")
user, err := authenticator.Authenticate(req)
fmt.Println(user.ID(), err)

req.SetBasicAuth("test", "1234")
_, err = authenticator.Authenticate(req)
fmt.Println(err.(errors.MultiError)[1])
Output:

10 <nil>
Invalid credentials
Example (Second)
// This example show how to caches the result of basic auth.
// With LRU cache
cache := store.New(2)

strategy := New(exampleAuthFunc, cache)
authenticator := auth.New()
authenticator.EnableStrategy(StrategyKey, strategy)

// user request
req, _ := http.NewRequest("GET", "/", nil)
req.SetBasicAuth("test", "test")
user, err := authenticator.Authenticate(req)
fmt.Println(user.ID(), err)

req.SetBasicAuth("test", "1234")
_, err = authenticator.Authenticate(req)
fmt.Println(err.(errors.MultiError)[1])
Output:

10 <nil>
basic: Invalid user credentials

Index

Examples

Constants

View Source
const ExtensionKey = "x-go-guardian-basic-hash"

ExtensionKey represents a key for the hashed password in info extensions. Typically used when basic strategy cache the authentication decisions.

View Source
const StrategyKey = auth.StrategyKey("Basic.Strategy")

StrategyKey export identifier for the basic strategy, commonly used when enable/add strategy to go-guardian authenticator.

Variables

View Source
var ErrInvalidCredentials = errors.New("basic: Invalid user credentials")

ErrInvalidCredentials is returned by Authenticate Strategy method, when user password is invalid.

View Source
var ErrMissingPrams = errors.New("basic: Request missing BasicAuth")

ErrMissingPrams is returned by Authenticate Strategy method, when failed to retrieve user credentials from request.

Functions

func New added in v1.0.0

New return new auth.Strategy. The returned strategy, caches the invocation result of authenticate function.

Types

type AuthenticateFunc added in v1.0.0

type AuthenticateFunc func(ctx context.Context, r *http.Request, userName, password string) (auth.Info, error)

AuthenticateFunc declare custom function to authenticate request using user credentials. the authenticate function invoked by Authenticate Strategy method after extracting user credentials to compare against DB or other service, if extracting user credentials from request failed a nil info with ErrMissingPrams returned, Otherwise, return Authenticate invocation result.

func (AuthenticateFunc) Authenticate added in v1.0.0

func (auth AuthenticateFunc) Authenticate(ctx context.Context, r *http.Request) (auth.Info, error)

Authenticate implement Authenticate Strategy method, and return user info or an appropriate error.

func (AuthenticateFunc) Challenge added in v1.2.2

func (auth AuthenticateFunc) Challenge(realm string) string

Challenge returns string indicates the authentication scheme. Typically used to adds a HTTP WWW-Authenticate header.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL