add: subscription seeding, enhance admin creation

This commit is contained in:
Alex
2024-09-29 21:06:30 +02:00
parent 72017c97ff
commit 2acbe703eb

View File

@@ -38,11 +38,24 @@ func Open(dbPath string, adminMail string) error {
var count int64 var count int64
db.Model(&models.User{}).Count(&count) db.Model(&models.User{}).Count(&count)
if count == 0 { if count == 0 {
subscriptionModels := createSubscriptionModels()
for _, model := range subscriptionModels {
result := db.Create(&model)
if result.Error != nil {
return result.Error
}
}
logger.Error.Printf("Init Subscriptions: %v", subscriptionModels)
var createdModel models.SubscriptionModel
if err := db.First(&createdModel).Error; err != nil {
return err
}
admin, err := createAdmin(adminMail, createdModel.ID) admin, err := createAdmin(adminMail, createdModel.ID)
if err != nil { if err != nil {
return err return err
} }
result := db.Create(&admin) result := db.Session(&gorm.Session{FullSaveAssociations: true}).Create(&admin)
if result.Error != nil { if result.Error != nil {
return result.Error return result.Error
} }
@@ -50,7 +63,18 @@ func Open(dbPath string, adminMail string) error {
return nil return nil
} }
func createSubscriptionModels() []models.SubscriptionModel {
return []models.SubscriptionModel{
{
Name: "Keins",
Details: "Dieses Modell ist für Vereinsmitglieder, die keinen Wunsch haben, an dem Carhsharing teilzunehmen.",
HourlyRate: 999,
MonthlyFee: 0,
},
}
}
// TODO: Landing page to create an admin // TODO: Landing page to create an admin
func createAdmin(userMail string, subscriptionModelID uint) (*models.User, error) { func createAdmin(userMail string, subscriptionModelID uint) (*models.User, error) {
passwordBytes := make([]byte, 12) passwordBytes := make([]byte, 12)
_, err := rand.Read(passwordBytes) _, err := rand.Read(passwordBytes)
@@ -59,10 +83,8 @@ func createAdmin(userMail string, subscriptionModelID uint) (*models.User, error
} }
// Encode into a URL-safe base64 string // Encode into a URL-safe base64 string
password, err := base64.URLEncoding.EncodeToString(passwordBytes)[:12], nil password := base64.URLEncoding.EncodeToString(passwordBytes)[:12]
if err != nil {
return nil, err
}
hash, err := argon2id.CreateHash(password, argon2id.DefaultParams) hash, err := argon2id.CreateHash(password, argon2id.DefaultParams)
if err != nil { if err != nil {
return nil, err return nil, err
@@ -76,14 +98,25 @@ func createAdmin(userMail string, subscriptionModelID uint) (*models.User, error
return &models.User{ return &models.User{
FirstName: "ad", FirstName: "ad",
LastName: "min", LastName: "min",
DateOfBirth: time.Now(), DateOfBirth: time.Now().AddDate(-20, 0, 0),
Password: hash, Password: hash,
Address: "Downhill 4", Address: "Downhill 4",
ZipCode: "9999", ZipCode: "99999",
City: "TechTown", City: "TechTown",
Phone: "0123455678",
Email: userMail, Email: userMail,
Status: constants.ActiveStatus, Status: constants.ActiveStatus,
RoleID: constants.Roles.Editor, RoleID: constants.Roles.Admin,
Membership: models.Membership{
Status: constants.DisabledStatus,
StartDate: time.Now(),
SubscriptionModelID: subscriptionModelID,
},
BankAccount: models.BankAccount{
AccountHolderName: "Niemand",
Bank: "Keine",
IBAN: "DE49700500000008447644", //fake
},
}, nil }, nil
} }