auth.go 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package model
  2. import (
  3. "github.com/0xJacky/Nginx-UI/server/settings"
  4. "github.com/dgrijalva/jwt-go"
  5. "time"
  6. )
  7. type Auth struct {
  8. Model
  9. Name string `json:"name"`
  10. Password string `json:"-"`
  11. }
  12. type AuthToken struct {
  13. Token string `json:"token"`
  14. }
  15. type JWTClaims struct {
  16. Name string `json:"name"`
  17. jwt.StandardClaims
  18. }
  19. func GetUser(name string) (user Auth, err error){
  20. err = db.Where("name = ?", name).First(&user).Error
  21. if err != nil {
  22. return Auth{}, err
  23. }
  24. return user, err
  25. }
  26. func DeleteToken(token string) error {
  27. return db.Where("token = ?", token).Delete(&AuthToken{}).Error
  28. }
  29. func CheckToken(token string) int64 {
  30. return db.Where("token = ?", token).Find(&AuthToken{}).RowsAffected
  31. }
  32. func GenerateJWT(name string) (string, error) {
  33. claims := JWTClaims{
  34. Name: name,
  35. StandardClaims: jwt.StandardClaims{
  36. ExpiresAt: time.Now().Add(24 * time.Hour).Unix(),
  37. },
  38. }
  39. unsignedToken := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
  40. signedToken, err := unsignedToken.SignedString([]byte(settings.ServerSettings.JwtSecret))
  41. if err != nil {
  42. return "", err
  43. }
  44. err = db.Create(&AuthToken{
  45. Token: signedToken,
  46. }).Error
  47. if err != nil {
  48. return "", err
  49. }
  50. return signedToken, err
  51. }