add new relational table requests
This commit is contained in:
@@ -4,7 +4,6 @@ import (
|
||||
"errors"
|
||||
"fmt"
|
||||
|
||||
"gitea.tecamino.com/paadi/memberDB/crypto"
|
||||
"gitea.tecamino.com/paadi/memberDB/models"
|
||||
"gitea.tecamino.com/paadi/memberDB/utils"
|
||||
)
|
||||
@@ -66,7 +65,7 @@ func (dh *DatabaseHandler) GetMember(id uint) (members []models.Member, err erro
|
||||
return members, errors.New("database not opened")
|
||||
}
|
||||
|
||||
err = dh.database.GetById(&members, "", id)
|
||||
err = dh.database.GetById(&members, id, "Group", "Responsible", "Responsible.Member", "Events")
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
@@ -75,102 +74,38 @@ func (dh *DatabaseHandler) GetMember(id uint) (members []models.Member, err erro
|
||||
if err := members[i].Decrypt(dh.token); err != nil {
|
||||
return members, err
|
||||
}
|
||||
if members[i].Responsible != nil {
|
||||
members[i].Responsible.Member.Decrypt(dh.token)
|
||||
}
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
// UpdateMember updates/overrides all information given meber id
|
||||
func (dh *DatabaseHandler) UpdateMember(id int, member models.Member) (err error) {
|
||||
func (dh *DatabaseHandler) UpdateMember(id uint, member models.Member) (err error) {
|
||||
if !dh.DatabaseOpened() {
|
||||
return errors.New("database not opened")
|
||||
}
|
||||
|
||||
if member.FirstName != "" {
|
||||
member.FirstNameHash = dh.hashField(member.FirstName)
|
||||
member.FirstName, err = crypto.Encrypt(member.FirstName, dh.token)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
if member.LastName != "" {
|
||||
member.LastNameHash = dh.hashField(member.LastName)
|
||||
member.LastName, err = crypto.Encrypt(member.LastName, dh.token)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
//check correct birtday format
|
||||
if member.Birthday != "" && utils.IsValidBirthday(member.Birthday) {
|
||||
member.BirthdayHash = dh.hashField(member.BirthdayHash)
|
||||
member.Birthday, err = crypto.Encrypt(member.Birthday, dh.token)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
} else if member.Birthday != "" {
|
||||
if member.Birthday != "" && !utils.IsValidBirthday(member.Birthday) {
|
||||
return errors.New("incorrect birthday format")
|
||||
}
|
||||
|
||||
if member.Address != "" {
|
||||
member.Address, err = crypto.Encrypt(member.Address, dh.token)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
if member.Zip != "" {
|
||||
member.Zip, err = crypto.Encrypt(member.Zip, dh.token)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
if member.Town != "" {
|
||||
member.Town, err = crypto.Encrypt(member.Town, dh.token)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
if member.Phone != "" {
|
||||
member.Phone, err = crypto.Encrypt(member.Phone, dh.token)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
//check correct email format
|
||||
if member.Email != "" && utils.IsValidEmail(member.Email) {
|
||||
member.Email, err = crypto.Encrypt(member.Email, dh.token)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
} else if member.Email != "" {
|
||||
if member.Email != "" && !utils.IsValidEmail(member.Email) {
|
||||
return errors.New("incorrect email format")
|
||||
}
|
||||
|
||||
if member.FirstVisit != "" {
|
||||
member.FirstVisit, err = crypto.Encrypt(member.FirstVisit, dh.token)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if member.Group != nil {
|
||||
member.GroupId = &member.Group.Id
|
||||
}
|
||||
|
||||
if member.LastVisit != "" {
|
||||
member.LastVisit, err = crypto.Encrypt(member.LastVisit, dh.token)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if member.Responsible != nil {
|
||||
member.ResponsibleId = &member.Responsible.Id
|
||||
}
|
||||
|
||||
if member.Comment != "" {
|
||||
member.Comment, err = crypto.Encrypt(member.Comment, dh.token)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
return dh.database.UpdateValuesById(&member, "", uint(member.Id))
|
||||
member.Encrypt(dh.token)
|
||||
return dh.database.UpdateValuesById(&member, uint(member.Id), "Group", "Responsible", "Responsible.Member")
|
||||
}
|
||||
|
||||
// memberExists helper to check wheter member already exists
|
||||
@@ -180,7 +115,7 @@ func (dh *DatabaseHandler) memberExists(checkMember models.Member) (bool, error)
|
||||
}
|
||||
|
||||
var members []models.Member
|
||||
if !dh.database.Exists(&members, "", "birthdayHash", dh.hashField(checkMember.Birthday), false) {
|
||||
if !dh.database.Exists(&members, "birthdayHash", dh.hashField(checkMember.Birthday), false) {
|
||||
return false, nil
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user