2022-05-11 22:47:31 +00:00
|
|
|
package auth
|
|
|
|
|
|
|
|
import (
|
|
|
|
"npm/internal/database"
|
2023-07-24 03:42:50 +00:00
|
|
|
"npm/internal/model"
|
2022-05-11 22:47:31 +00:00
|
|
|
|
2023-02-24 07:19:07 +00:00
|
|
|
"github.com/rotisserie/eris"
|
2022-05-11 22:47:31 +00:00
|
|
|
"golang.org/x/crypto/bcrypt"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
// TypePassword is the Password Type
|
|
|
|
TypePassword = "password"
|
|
|
|
)
|
|
|
|
|
2023-05-26 01:04:43 +00:00
|
|
|
// Model is the model
|
2022-05-11 22:47:31 +00:00
|
|
|
type Model struct {
|
2023-07-24 03:42:50 +00:00
|
|
|
model.ModelBase
|
2023-05-26 01:04:43 +00:00
|
|
|
UserID uint `json:"user_id" gorm:"column:user_id"`
|
|
|
|
Type string `json:"type" gorm:"column:type;default:password"`
|
|
|
|
Secret string `json:"secret,omitempty" gorm:"column:secret"`
|
2022-05-11 22:47:31 +00:00
|
|
|
}
|
|
|
|
|
2023-05-26 01:04:43 +00:00
|
|
|
// TableName overrides the table name used by gorm
|
|
|
|
func (Model) TableName() string {
|
|
|
|
return "auth"
|
2022-05-11 22:47:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// LoadByID will load from an ID
|
|
|
|
func (m *Model) LoadByID(id int) error {
|
2023-05-26 01:04:43 +00:00
|
|
|
db := database.GetDB()
|
|
|
|
result := db.First(&m, id)
|
|
|
|
return result.Error
|
2022-05-11 22:47:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Save will save this model to the DB
|
|
|
|
func (m *Model) Save() error {
|
2023-05-26 01:04:43 +00:00
|
|
|
db := database.GetDB()
|
|
|
|
// todo: touch? not sure that save does this or not?
|
|
|
|
result := db.Save(m)
|
|
|
|
return result.Error
|
2022-05-11 22:47:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// SetPassword will generate a hashed password based on given string
|
|
|
|
func (m *Model) SetPassword(password string) error {
|
|
|
|
hash, err := bcrypt.GenerateFromPassword([]byte(password), bcrypt.MinCost+2)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
m.Type = TypePassword
|
|
|
|
m.Secret = string(hash)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// ValidateSecret will check if a given secret matches the encrypted secret
|
|
|
|
func (m *Model) ValidateSecret(secret string) error {
|
|
|
|
if m.Type != TypePassword {
|
2023-02-24 07:19:07 +00:00
|
|
|
return eris.New("Could not validate Secret, auth type is not a Password")
|
2022-05-11 22:47:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
err := bcrypt.CompareHashAndPassword([]byte(m.Secret), []byte(secret))
|
|
|
|
if err != nil {
|
2023-02-24 07:19:07 +00:00
|
|
|
return eris.New("Invalid Password")
|
2022-05-11 22:47:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|