auth.go 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. package login
  2. import (
  3. "errors"
  4. "github.com/grafana/grafana/pkg/bus"
  5. m "github.com/grafana/grafana/pkg/models"
  6. )
  7. var (
  8. ErrInvalidCredentials = errors.New("Invalid Username or Password")
  9. ErrTooManyLoginAttempts = errors.New("Too many consecutive incorrect login attempts for user. Login for user temporarily blocked")
  10. )
  11. type LoginUserQuery struct {
  12. Username string
  13. Password string
  14. User *m.User
  15. IpAddress string
  16. }
  17. func Init() {
  18. bus.AddHandler("auth", AuthenticateUser)
  19. loadLdapConfig()
  20. }
  21. func AuthenticateUser(query *LoginUserQuery) error {
  22. if err := validateLoginAttempts(query.Username); err != nil {
  23. return err
  24. }
  25. err := loginUsingGrafanaDB(query)
  26. if err == nil || (err != m.ErrUserNotFound && err != ErrInvalidCredentials) {
  27. return err
  28. }
  29. ldapEnabled, ldapErr := loginUsingLdap(query)
  30. if ldapEnabled {
  31. if ldapErr == nil || ldapErr != ErrInvalidCredentials {
  32. return ldapErr
  33. }
  34. err = ldapErr
  35. }
  36. if err == ErrInvalidCredentials {
  37. saveInvalidLoginAttempt(query)
  38. }
  39. if err == m.ErrUserNotFound {
  40. return ErrInvalidCredentials
  41. }
  42. return err
  43. }