auth

package
v0.0.0-...-82cb9bc Latest Latest
Warning

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

Go to latest
Published: Sep 20, 2019 License: MIT Imports: 6 Imported by: 3

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	ErrInvalidCredentials = echo.NewHTTPError(http.StatusUnauthorized, "Username or password does not exist")
)

Custom errors

Functions

This section is empty.

Types

type Auth

type Auth struct {
	// contains filtered or unexported fields
}

Auth represents auth application service

func Initialize

func Initialize(db *pg.DB, j TokenGenerator, sec Securer, rbac RBAC) *Auth

Initialize initializes auth application service

func New

func New(db *pg.DB, udb UserDB, j TokenGenerator, sec Securer, rbac RBAC) *Auth

New creates new iam service

func (*Auth) Authenticate

func (a *Auth) Authenticate(c echo.Context, user, pass string) (*rest.AuthToken, error)

Authenticate tries to authenticate the user provided by username and password

func (*Auth) Me

func (a *Auth) Me(c echo.Context) (*rest.User, error)

Me returns info about currently logged user

func (*Auth) Refresh

func (a *Auth) Refresh(c echo.Context, token string) (*rest.RefreshToken, error)

Refresh refreshes jwt token and puts new claims inside

type RBAC

type RBAC interface {
	User(echo.Context) *rest.AuthUser
}

RBAC represents role-based-access-control interface

type Securer

type Securer interface {
	HashMatchesPassword(string, string) bool
	Token(string) string
}

Securer represents security interface

type Service

type Service interface {
	Authenticate(echo.Context, string, string) (*rest.AuthToken, error)
	Refresh(echo.Context, string) (*rest.RefreshToken, error)
	Me(echo.Context) (*rest.User, error)
}

Service represents auth service interface

type TokenGenerator

type TokenGenerator interface {
	GenerateToken(*rest.User) (string, string, error)
}

TokenGenerator represents token generator (jwt) interface

type UserDB

type UserDB interface {
	View(orm.DB, int) (*rest.User, error)
	FindByUsername(orm.DB, string) (*rest.User, error)
	FindByToken(orm.DB, string) (*rest.User, error)
	Update(orm.DB, *rest.User) error
}

UserDB represents user repository interface

Directories

Path Synopsis
platform

Jump to

Keyboard shortcuts

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