auth

package
v0.7.0-RC-1 Latest Latest
Warning

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

Go to latest
Published: Nov 24, 2023 License: AGPL-3.0 Imports: 25 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func ValidatePassword

func ValidatePassword() fiber.Handler

Types

type LoginInput

type LoginInput struct {
	Email      string `json:"email,omitempty"`
	MemberName string `json:"membername,omitempty"`
	Password   string `json:"password"`
}

LoginInput is the input for the login request

func (LoginInput) Validate

func (l LoginInput) Validate() (*member.Input, error)

type RegLoginInput

type RegLoginInput interface {
	RegisterInput | LoginInput
}

RegLoginInput is an union (feature introduced in Go 1.18) of RegisterInput and LoginInput

type RegisterInput

type RegisterInput struct {
	Email      string `json:"email"`
	MemberName string `json:"membername"`
	// Password is first temporarily encrypted using RSA and then hashed using argon2id
	// For more details see the internal/crypt package
	Password        string   `json:"password"`
	PasswordConfirm string   `json:"passwordConfirm"`
	Roles           []string `json:"roles"`
}

RegisterInput is the input for the registration request

func (RegisterInput) Validate

func (r RegisterInput) Validate() (*member.Input, error)

type Service added in v0.6.2

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

Service allows dependency injection for the controller methods, so that the db connection needn't be created in the controller methods

func NewService added in v0.6.2

func NewService(
	conf *cfg.Config,
	ms member.MemberStorer,
	log *zerolog.Logger,
	secStorage *sql.DB,
) *Service

NewService creates an instance of the Service struct and returns a pointer to it It should be used within the routes package where the db connection and config are passed from the main package

func (*Service) GetPrivateKey

func (a *Service) GetPrivateKey(identifier uuid.UUID) (key *age.X25519Identity, err error)

Verify verifies the received data against the private key Obviously this must not be exposed by an API. It's for internal use.

func (*Service) GetPubKey

func (a *Service) GetPubKey(c *fiber.Ctx) error

GetPubKey returns a public key and uuid for the client to encrypt their password In the context of X25519 it returns the recipient's public key @Summary Get public key @Description Get public key for client to encrypt their password @Tags Auth @Produce json @Success 200 {object} PublicKeyResponse @Router /auth/pubkey [get] @Security ApiKeyAuth @Security OAuth2Application[write]

func (*Service) GetSessionTimeoutPrefs added in v0.7.0

func (a *Service) GetSessionTimeoutPrefs(c *fiber.Ctx) error

GetSessionTimeoutPrefs returns the session timeout preferences This setting is not synced across devices. The way it works is: 1. Send a request to the database, where a JOIN is performed on the current device's identifier and the member's ID 2. If the device is found, return the timeout preference

func (*Service) Login added in v0.6.2

func (a *Service) Login(c *fiber.Ctx) error

1. Parse the input 2. Validate the input (check for empty fields, valid email, etc.) 3. Pass the email to the database, get the password hash for the email or nickname 4. Compare the password hash with the password hash from the database

func (*Service) Register added in v0.6.2

func (a *Service) Register(c *fiber.Ctx) error

Register handles the creation of a new user

type Validator

type Validator interface {
	Validate() (*member.Input, error)
}

Jump to

Keyboard shortcuts

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