123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 |
- package auth
- import (
- "time"
- "github.com/gofiber/fiber/v2"
- "github.com/golang-jwt/jwt/v4"
- "golang.org/x/crypto/bcrypt"
- "git.dmitriygnatenko.ru/dima/homethings/internal/models"
- )
- const (
- ClaimsKeyName = "name"
- claimsKeyExp = "exp"
- claimsKeyUser = "user"
- defaultCost = bcrypt.DefaultCost
- )
- type Config interface {
- JWTSecretKey() string
- JWTLifetime() time.Duration
- }
- type Service struct {
- config Config
- }
- func Init(config Config) (*Service, error) {
- return &Service{config: config}, nil
- }
- func (a Service) GeneratePasswordHash(password string) (string, error) {
- res, err := bcrypt.GenerateFromPassword([]byte(password), defaultCost)
- if err != nil {
- return "", err
- }
- return string(res), nil
- }
- func (a Service) IsCorrectPassword(password string, hash string) bool {
- return bcrypt.CompareHashAndPassword([]byte(hash), []byte(password)) == nil
- }
- func (a Service) GetClaims(fctx *fiber.Ctx) jwt.MapClaims {
- jwtUser := fctx.Locals(claimsKeyUser).(*jwt.Token)
- return jwtUser.Claims.(jwt.MapClaims)
- }
- func (a Service) GenerateToken(user models.User) (string, error) {
- claims := jwt.MapClaims{
- ClaimsKeyName: user.Username,
- claimsKeyExp: time.Now().Add(a.config.JWTLifetime()).Unix(),
- }
- token := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
- return token.SignedString([]byte(a.config.JWTSecretKey()))
- }
|