add & moved to validations folder; del validator/v10
This commit is contained in:
@@ -1,15 +1,10 @@
|
||||
package services
|
||||
|
||||
import (
|
||||
"slices"
|
||||
"time"
|
||||
|
||||
"github.com/go-playground/validator/v10"
|
||||
|
||||
"GoMembership/internal/models"
|
||||
"GoMembership/internal/repositories"
|
||||
"GoMembership/internal/utils"
|
||||
"GoMembership/pkg/errors"
|
||||
)
|
||||
|
||||
type MembershipServiceInterface interface {
|
||||
@@ -37,9 +32,6 @@ func (service *MembershipService) FindMembershipByUserID(userID uint) (*models.M
|
||||
|
||||
// Membership_Subscriptions
|
||||
func (service *MembershipService) RegisterSubscription(subscription *models.SubscriptionModel) (uint, error) {
|
||||
if err := validateSubscriptionData(subscription); err != nil {
|
||||
return 0, err
|
||||
}
|
||||
return service.SubscriptionRepo.CreateSubscriptionModel(subscription)
|
||||
}
|
||||
|
||||
@@ -48,15 +40,7 @@ func (service *MembershipService) GetMembershipModelNames() ([]string, error) {
|
||||
}
|
||||
|
||||
func (service *MembershipService) GetModelByName(modelname *string) (*models.SubscriptionModel, error) {
|
||||
sModelNames, err := service.SubscriptionRepo.GetMembershipModelNames()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if !slices.Contains(sModelNames, *modelname) {
|
||||
return nil, errors.ErrNotFound
|
||||
}
|
||||
return service.SubscriptionRepo.GetModelByName(modelname)
|
||||
return repositories.GetModelByName(modelname)
|
||||
}
|
||||
|
||||
func (service *MembershipService) GetSubscriptions(where map[string]interface{}) (*[]models.SubscriptionModel, error) {
|
||||
@@ -65,12 +49,3 @@ func (service *MembershipService) GetSubscriptions(where map[string]interface{})
|
||||
}
|
||||
return service.SubscriptionRepo.GetSubscriptions(where)
|
||||
}
|
||||
|
||||
func validateSubscriptionData(subscription *models.SubscriptionModel) error {
|
||||
validate := validator.New()
|
||||
// subscriptionModel and membershipField don't have to be evaluated if adding a new subscription
|
||||
validate.RegisterValidation("subscriptionModel", func(fl validator.FieldLevel) bool { return true })
|
||||
validate.RegisterValidation("membershipField", func(fl validator.FieldLevel) bool { return true })
|
||||
validate.RegisterValidation("safe_content", utils.ValidateSafeContent)
|
||||
return validate.Struct(subscription)
|
||||
}
|
||||
|
||||
@@ -12,7 +12,6 @@ import (
|
||||
"GoMembership/pkg/logger"
|
||||
|
||||
"github.com/alexedwards/argon2id"
|
||||
"github.com/go-playground/validator/v10"
|
||||
"gorm.io/gorm"
|
||||
|
||||
"time"
|
||||
@@ -34,12 +33,6 @@ type UserService struct {
|
||||
|
||||
func (service *UserService) UpdateUser(user *models.User, userRole int8) (*models.User, error) {
|
||||
|
||||
if err := validateUserData(user, userRole); err != nil {
|
||||
logger.Info.Printf("UPDATING user: %#v", user)
|
||||
logger.Error.Printf("Failed to validate user data: %v", err)
|
||||
return nil, errors.ErrInvalidUserData
|
||||
}
|
||||
|
||||
if user.Password != "" {
|
||||
setPassword(user.Password, user)
|
||||
}
|
||||
@@ -66,9 +59,6 @@ func (service *UserService) UpdateUser(user *models.User, userRole int8) (*model
|
||||
}
|
||||
|
||||
func (service *UserService) RegisterUser(user *models.User) (uint, string, error) {
|
||||
if err := validateUserData(user, user.RoleID); err != nil {
|
||||
return http.StatusNotAcceptable, "", err
|
||||
}
|
||||
|
||||
setPassword(user.Password, user)
|
||||
|
||||
@@ -76,21 +66,19 @@ func (service *UserService) RegisterUser(user *models.User) (uint, string, error
|
||||
user.CreatedAt = time.Now()
|
||||
user.UpdatedAt = time.Now()
|
||||
user.PaymentStatus = constants.AwaitingPaymentStatus
|
||||
// user.DriversLicence.Status = constants.UnverifiedStatus
|
||||
user.DriversLicence.Status = constants.UnverifiedStatus
|
||||
user.BankAccount.MandateDateSigned = time.Now()
|
||||
id, err := service.Repo.CreateUser(user)
|
||||
|
||||
if err != nil && strings.Contains(err.Error(), "UNIQUE constraint failed") {
|
||||
return http.StatusConflict, "", err
|
||||
} else if err != nil {
|
||||
return http.StatusInternalServerError, "", err
|
||||
if err != nil {
|
||||
return 0, "", err
|
||||
}
|
||||
|
||||
user.ID = id
|
||||
|
||||
token, err := utils.GenerateVerificationToken()
|
||||
if err != nil {
|
||||
return http.StatusInternalServerError, "", err
|
||||
return 0, "", err
|
||||
}
|
||||
|
||||
logger.Info.Printf("TOKEN: %v", token)
|
||||
@@ -98,10 +86,10 @@ func (service *UserService) RegisterUser(user *models.User) (uint, string, error
|
||||
// Check if user is already verified
|
||||
verified, err := service.Repo.IsVerified(&user.ID)
|
||||
if err != nil {
|
||||
return http.StatusInternalServerError, "", err
|
||||
return 0, "", err
|
||||
}
|
||||
if verified {
|
||||
return http.StatusAlreadyReported, "", errors.ErrAlreadyVerified
|
||||
return 0, "", errors.ErrAlreadyVerified
|
||||
}
|
||||
|
||||
// Prepare the Verification record
|
||||
@@ -119,7 +107,7 @@ func (service *UserService) RegisterUser(user *models.User) (uint, string, error
|
||||
|
||||
func (service *UserService) GetUserByID(id uint) (*models.User, error) {
|
||||
|
||||
return service.Repo.GetUserByID(&id)
|
||||
return repositories.GetUserByID(&id)
|
||||
}
|
||||
|
||||
func (service *UserService) GetUserByEmail(email string) (*models.User, error) {
|
||||
@@ -140,7 +128,7 @@ func (service *UserService) VerifyUser(token *string) (*models.User, error) {
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
user, err := service.Repo.GetUserByID(&verification.UserID)
|
||||
user, err := repositories.GetUserByID(&verification.UserID)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@@ -159,27 +147,6 @@ func (service *UserService) VerifyUser(token *string) (*models.User, error) {
|
||||
return user, nil
|
||||
}
|
||||
|
||||
func validateUserData(user *models.User, userRole int8) error {
|
||||
validate := validator.New()
|
||||
validate.RegisterValidation("safe_content", utils.ValidateSafeContent)
|
||||
if userRole == constants.Roles.Admin {
|
||||
validate.RegisterValidation("membershipField", utils.ValidateToTrue)
|
||||
validate.RegisterValidation("age", utils.ValidateToTrue)
|
||||
validate.RegisterValidation("bic", utils.ValidateToTrue)
|
||||
validate.RegisterValidation("subscriptionModel", utils.ValidateToTrue)
|
||||
validate.RegisterValidation("iban", utils.ValidateToTrue)
|
||||
validate.RegisterValidation("euDriversLicence", utils.ValidateToTrue)
|
||||
} else {
|
||||
validate.RegisterValidation("membershipField", utils.ValidateRequiredMembershipField)
|
||||
validate.RegisterValidation("age", utils.AgeValidator)
|
||||
validate.RegisterValidation("bic", utils.BICValidator)
|
||||
validate.RegisterValidation("subscriptionModel", utils.SubscriptionModelValidator)
|
||||
validate.RegisterValidation("iban", utils.IBANValidator)
|
||||
validate.RegisterValidation("euDriversLicence", utils.ValidateDriversLicence)
|
||||
}
|
||||
return validate.Struct(user)
|
||||
}
|
||||
|
||||
func setPassword(plaintextPassword string, u *models.User) error {
|
||||
hash, err := argon2id.CreateHash(plaintextPassword, argon2id.DefaultParams)
|
||||
if err != nil {
|
||||
|
||||
Reference in New Issue
Block a user