change table to references

This commit is contained in:
Adrian Zürcher
2025-11-20 10:40:56 +01:00
parent 4a469d1fd4
commit fe194754b1
14 changed files with 101 additions and 168 deletions

View File

@@ -2,10 +2,9 @@ package handlers
import (
"errors"
"slices"
"time"
"gitea.tecamino.com/paadi/memberDB/models"
"gitea.tecamino.com/paadi/memberDB/utils"
)
func (dh *DatabaseHandler) StartNewEvent(event *models.Event) error {
@@ -13,11 +12,12 @@ func (dh *DatabaseHandler) StartNewEvent(event *models.Event) error {
return errors.New("database not opened")
}
if dh.database.Exists(&models.Event{}, "name", event.Name, false) {
if dh.database.Exists(&models.Event{}, "", "name", event.Name, false) {
return errors.New("event with name: " + event.Name + " exists already")
}
event.Date = time.Now().Format("2006-01-02 15:04:05")
event.Date = utils.GetCurrentTime(dh.timeLocation)
event.Day = utils.GetCurrentDay(dh.timeLocation)
return dh.database.AddNewColum(&event)
}
@@ -26,14 +26,10 @@ func (dh *DatabaseHandler) GetEvent(id uint) (event []models.Event, err error) {
return event, errors.New("database not opened")
}
err = dh.database.GetById(&event, id)
err = dh.database.GetById(&event, "Attendees", id)
if err != nil {
return
}
for i := range event {
event[i].Count = len(event[i].Attendees)
}
return
}
@@ -41,7 +37,7 @@ func (dh *DatabaseHandler) UpdateEvent(id int, event models.Event) (err error) {
if !dh.DatabaseOpened() {
return errors.New("database not opened")
}
return dh.database.UpdateValuesById(&event, uint(event.Id))
return dh.database.UpdateValuesById(&event, "", uint(event.Id))
}
func (dh *DatabaseHandler) DeleteEvent(ids ...uint) error {
@@ -53,7 +49,7 @@ func (dh *DatabaseHandler) DeleteEvent(ids ...uint) error {
return errors.New("no ids given to be deleted")
}
return dh.database.DeleteById(&models.Event{}, ids...)
return dh.database.DeleteById(&models.Event{}, "", ids...)
}
func (dh *DatabaseHandler) AddAttendeesToEvent(newEvent models.Event) error {
@@ -62,24 +58,24 @@ func (dh *DatabaseHandler) AddAttendeesToEvent(newEvent models.Event) error {
}
var event models.Event
err := dh.database.GetById(&event, uint(newEvent.Id))
err := dh.database.GetById(&event, "Attendees", uint(newEvent.Id))
if err != nil {
return err
}
next:
for _, newAttendee := range newEvent.Attendees {
if !dh.database.Exists(&models.Member{}, "", "id", newAttendee.Id, false) {
continue
}
for _, attendee := range event.Attendees {
if attendee.FirstName == newAttendee.FirstName && attendee.LastName == newAttendee.LastName {
continue next
}
}
event.Attendees = append(event.Attendees, newAttendee)
dh.database.AddRelation(&event, newAttendee, "Attendees")
}
event.Count = len(event.Attendees)
return dh.database.UpdateValuesById(&event, uint(newEvent.Id))
return nil
}
func (dh *DatabaseHandler) DeleteAttendeesFromEvent(newEvent models.Event) error {
@@ -88,17 +84,14 @@ func (dh *DatabaseHandler) DeleteAttendeesFromEvent(newEvent models.Event) error
}
var event models.Event
dh.database.GetById(&event, uint(newEvent.Id))
dh.database.GetById(&event, "Attendees", uint(newEvent.Id))
next:
for _, newAttendee := range newEvent.Attendees {
for i := range event.Attendees {
if event.Attendees[i].FirstName == newAttendee.FirstName && event.Attendees[i].LastName == newAttendee.LastName {
event.Attendees = slices.Delete(event.Attendees, i, i+1)
continue next
for _, a := range event.Attendees {
if a.FirstName == newAttendee.FirstName && a.LastName == newAttendee.LastName {
dh.database.DeleteRelation(&event, a, "Attendees")
}
}
}
event.Count = len(event.Attendees)
return dh.database.UpdateValuesById(&event, uint(newEvent.Id))
return nil
}