made Licence optional

This commit is contained in:
Alex
2024-11-04 17:19:32 +01:00
parent eb7fc359e1
commit 0fa57bfe75
8 changed files with 69 additions and 38 deletions

View File

@@ -258,7 +258,7 @@ func getBaseUser() models.User {
Phone: "01738484993", Phone: "01738484993",
BankAccount: models.BankAccount{IBAN: "DE89370400440532013000"}, BankAccount: models.BankAccount{IBAN: "DE89370400440532013000"},
Membership: models.Membership{SubscriptionModel: models.SubscriptionModel{Name: "Basic"}}, Membership: models.Membership{SubscriptionModel: models.SubscriptionModel{Name: "Basic"}},
Licence: models.Licence{}, Licence: nil,
ProfilePicture: "", ProfilePicture: "",
Password: "password123", Password: "password123",
Company: "", Company: "",

View File

@@ -425,7 +425,14 @@ func testUpdateUser(t *testing.T, loginCookie http.Cookie) {
t.Fatalf("Failed to get test user: %v", err) t.Fatalf("Failed to get test user: %v", err)
} }
user := (*users)[0] user := (*users)[0]
if user.Licence == nil {
user.Licence = &models.Licence{
Number: "Z021AB37X13",
ExpirationDate: time.Now().UTC().AddDate(1, 0, 0),
IssuedDate: time.Now().UTC().AddDate(-1, 0, 0),
IssuingCountry: "Deutschland",
}
}
tests := []struct { tests := []struct {
name string name string
setupCookie func(*http.Request) setupCookie func(*http.Request)
@@ -713,9 +720,6 @@ func testUpdateUser(t *testing.T, loginCookie http.Cookie) {
assert.Equal(t, updatedUser.Membership.SubscriptionModelID, updatedUserFromDB.Membership.SubscriptionModelID, "Membership.SubscriptionModelID mismatch") assert.Equal(t, updatedUser.Membership.SubscriptionModelID, updatedUserFromDB.Membership.SubscriptionModelID, "Membership.SubscriptionModelID mismatch")
assert.Equal(t, updatedUser.Membership.ParentMembershipID, updatedUserFromDB.Membership.ParentMembershipID, "Membership.ParentMembershipID mismatch") assert.Equal(t, updatedUser.Membership.ParentMembershipID, updatedUserFromDB.Membership.ParentMembershipID, "Membership.ParentMembershipID mismatch")
if updatedUser.Licence.Status == 0 {
updatedUser.Licence.Status = constants.UnverifiedStatus
}
assert.Equal(t, updatedUser.Licence.Status, updatedUserFromDB.Licence.Status, "Licence.Status mismatch") assert.Equal(t, updatedUser.Licence.Status, updatedUserFromDB.Licence.Status, "Licence.Status mismatch")
assert.Equal(t, updatedUser.Licence.Number, updatedUserFromDB.Licence.Number, "Licence.Number mismatch") assert.Equal(t, updatedUser.Licence.Number, updatedUserFromDB.Licence.Number, "Licence.Number mismatch")
assert.Equal(t, updatedUser.Licence.IssuedDate, updatedUserFromDB.Licence.IssuedDate, "Licence.IssuedDate mismatch") assert.Equal(t, updatedUser.Licence.IssuedDate, updatedUserFromDB.Licence.IssuedDate, "Licence.IssuedDate mismatch")
@@ -1094,7 +1098,11 @@ func getTestUsers() []RegisterUserTest {
Assert: false, Assert: false,
Input: GenerateInputJSON(customizeInput(func(user models.User) models.User { Input: GenerateInputJSON(customizeInput(func(user models.User) models.User {
user.Email = "john.wronglicence.doe@example.com" user.Email = "john.wronglicence.doe@example.com"
user.Licence.Number = "AAAA12345AA" user.Licence = &models.Licence{
Number: "AAAA12345AA",
ExpirationDate: time.Now().AddDate(1, 0, 0),
IssuedDate: time.Now().AddDate(-1, 0, 0),
}
return user return user
})), })),
}, },
@@ -1105,7 +1113,11 @@ func getTestUsers() []RegisterUserTest {
Assert: true, Assert: true,
Input: GenerateInputJSON(customizeInput(func(user models.User) models.User { Input: GenerateInputJSON(customizeInput(func(user models.User) models.User {
user.Email = "john.correctLicenceNumber@example.com" user.Email = "john.correctLicenceNumber@example.com"
user.Licence.Number = "B072RRE2I55" user.Licence = &models.Licence{
Number: "B072RRE2I55",
ExpirationDate: time.Now().AddDate(1, 0, 0),
IssuedDate: time.Now().AddDate(-1, 0, 0),
}
return user return user
})), })),
}, },

View File

@@ -154,7 +154,7 @@ func createAdmin(userMail string, subscriptionModelID uint) (*models.User, error
SubscriptionModelID: subscriptionModelID, SubscriptionModelID: subscriptionModelID,
}, },
BankAccount: models.BankAccount{}, BankAccount: models.BankAccount{},
Licence: models.Licence{ Licence: &models.Licence{
Status: constants.UnverifiedStatus, Status: constants.UnverifiedStatus,
}, },
}, nil }, nil

View File

@@ -7,11 +7,11 @@ import (
type Licence struct { type Licence struct {
ID uint `json:"id" gorm:"primaryKey"` ID uint `json:"id" gorm:"primaryKey"`
Status int8 `json:"status" binding:"omitempty,number"` Status int8 `json:"status" binding:"omitempty,number"`
Number string `json:"number" binding:"omitempty,euDriversLicence,safe_content"` Number string `json:"number" binding:"omitempty,safe_content"`
IssuedDate time.Time `json:"issued_date" binding:"omitempty,lte"` IssuedDate time.Time `json:"issued_date" binding:"omitempty"`
ExpirationDate time.Time `json:"expiration_date" binding:"omitempty,gt"` ExpirationDate time.Time `json:"expiration_date" binding:"omitempty"`
IssuingCountry string `json:"country" binding:"safe_content"` IssuingCountry string `json:"country" binding:"safe_content"`
Categories []Category `json:"licence_categories" gorm:"many2many:licence_2_categories"` Categories []Category `json:"categories" gorm:"many2many:licence_2_categories"`
} }
type Category struct { type Category struct {

View File

@@ -29,7 +29,7 @@ type User struct {
VerificationID uint VerificationID uint
Membership Membership `gorm:"constraint:OnUpdate:CASCADE,OnDelete:CASCADE;" json:"membership"` Membership Membership `gorm:"constraint:OnUpdate:CASCADE,OnDelete:CASCADE;" json:"membership"`
MembershipID uint MembershipID uint
Licence Licence `gorm:"constraint:OnUpdate:CASCADE,OnDelete:CASCADE;" json:"licence"` Licence *Licence `gorm:"constraint:OnUpdate:CASCADE,OnDelete:CASCADE;" json:"licence"`
LicenceID uint LicenceID uint
ID uint `json:"id"` ID uint `json:"id"`
PaymentStatus int8 `json:"payment_status"` PaymentStatus int8 `json:"payment_status"`
@@ -60,7 +60,7 @@ func (u *User) PasswordMatches(plaintextPassword string) (bool, error) {
} }
func (u *User) Safe() map[string]interface{} { func (u *User) Safe() map[string]interface{} {
return map[string]interface{}{ result := map[string]interface{}{
"email": u.Email, "email": u.Email,
"first_name": u.FirstName, "first_name": u.FirstName,
"last_name": u.LastName, "last_name": u.LastName,
@@ -90,6 +90,9 @@ func (u *User) Safe() map[string]interface{} {
"included_per_month": u.Membership.SubscriptionModel.IncludedPerMonth, "included_per_month": u.Membership.SubscriptionModel.IncludedPerMonth,
}, },
}, },
"licence": map[string]interface{}{
"id": 0,
},
"bank_account": map[string]interface{}{ "bank_account": map[string]interface{}{
"id": u.BankAccount.ID, "id": u.BankAccount.ID,
"mandate_date_signed": u.BankAccount.MandateDateSigned, "mandate_date_signed": u.BankAccount.MandateDateSigned,
@@ -99,7 +102,10 @@ func (u *User) Safe() map[string]interface{} {
"bic": u.BankAccount.BIC, "bic": u.BankAccount.BIC,
"mandate_reference": u.BankAccount.MandateReference, "mandate_reference": u.BankAccount.MandateReference,
}, },
"licence": map[string]interface{}{ }
if u.Licence != nil {
result["licence"] = map[string]interface{}{
"id": u.Licence.ID, "id": u.Licence.ID,
"number": u.Licence.Number, "number": u.Licence.Number,
"status": u.Licence.Status, "status": u.Licence.Status,
@@ -107,6 +113,8 @@ func (u *User) Safe() map[string]interface{} {
"expiration_date": u.Licence.ExpirationDate, "expiration_date": u.Licence.ExpirationDate,
"country": u.Licence.IssuingCountry, "country": u.Licence.IssuingCountry,
"licence_categories": u.Licence.Categories, "licence_categories": u.Licence.Categories,
}, }
} }
return result
} }

View File

@@ -26,6 +26,6 @@ func (r *LicenceRepository) FindCategoriesByIDs(ids []uint) ([]models.Category,
func (r *LicenceRepository) FindCategoryByName(categoryName string) (models.Category, error) { func (r *LicenceRepository) FindCategoryByName(categoryName string) (models.Category, error) {
var category models.Category var category models.Category
err := database.DB.Where("category = ?", categoryName).First(&category).Error err := database.DB.Where("name = ?", categoryName).First(&category).Error
return category, err return category, err
} }

View File

@@ -42,7 +42,8 @@ func (ur *UserRepository) UpdateUser(user *models.User) (*models.User, error) {
err := database.DB.Transaction(func(tx *gorm.DB) error { err := database.DB.Transaction(func(tx *gorm.DB) error {
// Check if the user exists in the database // Check if the user exists in the database
var existingUser models.User var existingUser models.User
if err := tx.Preload("Licence.Categories"). if err := tx.Preload("Licence").
Preload("Licence.Categories").
Preload("Membership"). Preload("Membership").
First(&existingUser, user.ID).Error; err != nil { First(&existingUser, user.ID).Error; err != nil {
return err return err
@@ -56,13 +57,29 @@ func (ur *UserRepository) UpdateUser(user *models.User) (*models.User, error) {
return errors.ErrNoRowsAffected return errors.ErrNoRowsAffected
} }
// Handle the update of the LicenceCategories explicitly // Handle the update or creation of Licence and its Categories
if user.Licence.ID != 0 { // if user.Licence != nil {
// Replace the Categories with the new list // if existingUser.Licence == nil {
if err := tx.Model(&existingUser.Licence).Association("Categories").Replace(user.Licence.Categories); err != nil { // // Create new Licence if it doesn't exist
return err // logger.Error.Printf("Licence creation: %+v", user.Licence)
} // if err := tx.Create(user.Licence).Error; err != nil {
} // return err
// }
// // Update user with new licence ID
// // if err := tx.Model(&existingUser).Update("licence_id", user.Licence.ID).Error; err != nil {
// // return err
// // }
// } else {
// // Update existing licence
// if err := tx.Model(&existingUser.Licence).Updates(user.Licence).Error; err != nil {
// return err
// }
// }
// // Replace the Categories with the new list
// if err := tx.Model(&existingUser.Licence).Association("Categories").Replace(user.Licence.Categories); err != nil {
// return err
// }
// }
// Update the Membership if provided // Update the Membership if provided
if user.Membership.ID != 0 { if user.Membership.ID != 0 {
@@ -71,13 +88,6 @@ func (ur *UserRepository) UpdateUser(user *models.User) (*models.User, error) {
} }
} }
// Update the Licence fields if provided
if user.Licence.ID != 0 {
if err := tx.Model(&existingUser.Licence).Updates(user.Licence).Error; err != nil {
return err
}
}
return nil return nil
}) })

View File

@@ -37,11 +37,10 @@ func (service *UserService) UpdateUser(user *models.User, userRole int8) (*model
setPassword(user.Password, user) setPassword(user.Password, user)
} }
user.UpdatedAt = time.Now() // if user.Licence.Status == 0 {
if user.Licence.Status == 0 { // // This is a new drivers licence
// This is a new drivers licence // user.Licence.Status = constants.UnverifiedStatus
user.Licence.Status = constants.UnverifiedStatus // }
}
updatedUser, err := service.Repo.UpdateUser(user) updatedUser, err := service.Repo.UpdateUser(user)
@@ -66,7 +65,9 @@ func (service *UserService) RegisterUser(user *models.User) (uint, string, error
user.CreatedAt = time.Now() user.CreatedAt = time.Now()
user.UpdatedAt = time.Now() user.UpdatedAt = time.Now()
user.PaymentStatus = constants.AwaitingPaymentStatus user.PaymentStatus = constants.AwaitingPaymentStatus
user.Licence.Status = constants.UnverifiedStatus // if user.Licence == nil {
// user.Licence = &models.Licence{Status: constants.UnverifiedStatus}
// }
user.BankAccount.MandateDateSigned = time.Now() user.BankAccount.MandateDateSigned = time.Now()
id, err := service.Repo.CreateUser(user) id, err := service.Repo.CreateUser(user)