mirror of
https://gitlab.dit.htwk-leipzig.de/htwk-software/htwkalender.git
synced 2025-08-06 19:59:13 +02:00
fix:#65 fixed fetching and deleting events in front
This commit is contained in:
@@ -5,7 +5,6 @@ import (
|
|||||||
"github.com/pocketbase/pocketbase/core"
|
"github.com/pocketbase/pocketbase/core"
|
||||||
"github.com/pocketbase/pocketbase/tools/cron"
|
"github.com/pocketbase/pocketbase/tools/cron"
|
||||||
"htwkalender/service/course"
|
"htwkalender/service/course"
|
||||||
"htwkalender/service/events"
|
|
||||||
"htwkalender/service/feed"
|
"htwkalender/service/feed"
|
||||||
"htwkalender/service/fetch/sport"
|
"htwkalender/service/fetch/sport"
|
||||||
v2 "htwkalender/service/fetch/v2"
|
v2 "htwkalender/service/fetch/v2"
|
||||||
@@ -44,13 +43,8 @@ func AddSchedules(app *pocketbase.PocketBase) {
|
|||||||
slog.Info("Successfully fetched " + strconv.FormatInt(int64(len(sportEvents)), 10) + " sport events")
|
slog.Info("Successfully fetched " + strconv.FormatInt(int64(len(sportEvents)), 10) + " sport events")
|
||||||
})
|
})
|
||||||
|
|
||||||
//delete all events and then fetch all events from remote this should be done every sunday at 2am
|
//fetch all events for semester and delete from remote this should be done every sunday at 2am
|
||||||
scheduler.MustAdd("fetchEvents", "0 2 * * 0", func() {
|
scheduler.MustAdd("fetchEvents", "0 2 * * 0", func() {
|
||||||
err := events.DeleteAllEvents(app)
|
|
||||||
if err != nil {
|
|
||||||
slog.Error("Failed to delete all events: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
savedEvents, err := v2.FetchAllEventsAndSave(app, time.RealClock{})
|
savedEvents, err := v2.FetchAllEventsAndSave(app, time.RealClock{})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
slog.Error("Failed to fetch and save events: %v", err)
|
slog.Error("Failed to fetch and save events: %v", err)
|
||||||
|
@@ -203,7 +203,7 @@ func GetAllModulesDistinctByNameAndCourse(app *pocketbase.PocketBase) ([]model.M
|
|||||||
return modules, nil
|
return modules, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func DeleteAllEventsForCourse(app *pocketbase.PocketBase, course string, semester string) error {
|
func DeleteAllEventsByCourse(app *pocketbase.PocketBase, course string, semester string) error {
|
||||||
_, err := app.Dao().DB().Delete("events", dbx.NewExp("course = {:course} AND semester = {:semester}", dbx.Params{"course": course, "semester": semester})).Execute()
|
_, err := app.Dao().DB().Delete("events", dbx.NewExp("course = {:course} AND semester = {:semester}", dbx.Params{"course": course, "semester": semester})).Execute()
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -212,6 +212,16 @@ func DeleteAllEventsForCourse(app *pocketbase.PocketBase, course string, semeste
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func DeleteAllEventsBySemester(app *pocketbase.PocketBase, semester string) error {
|
||||||
|
_, err := app.Dao().DB().Delete("events", dbx.NewExp("semester = {:semester}", dbx.Params{"semester": semester})).Execute()
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
func DeleteAllEvents(app *pocketbase.PocketBase) error {
|
func DeleteAllEvents(app *pocketbase.PocketBase) error {
|
||||||
|
|
||||||
_, err := app.Dao().DB().Delete("events", dbx.NewExp("1=1")).Execute()
|
_, err := app.Dao().DB().Delete("events", dbx.NewExp("1=1")).Execute()
|
||||||
|
@@ -77,7 +77,7 @@ func GetModuleByUUID(app *pocketbase.PocketBase, uuid string) (model.Module, err
|
|||||||
// If the deletion was successful, nil is returned
|
// If the deletion was successful, nil is returned
|
||||||
// If the deletion was not successful, an error is returned
|
// If the deletion was not successful, an error is returned
|
||||||
func DeleteAllEventsByCourseAndSemester(app *pocketbase.PocketBase, course string, semester string) error {
|
func DeleteAllEventsByCourseAndSemester(app *pocketbase.PocketBase, course string, semester string) error {
|
||||||
err := db.DeleteAllEventsForCourse(app, course, semester)
|
err := db.DeleteAllEventsByCourse(app, course, semester)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
} else {
|
} else {
|
||||||
|
@@ -65,7 +65,7 @@ func FetchAndUpdateSportEvents(app *pocketbase.PocketBase) ([]model.Event, error
|
|||||||
}
|
}
|
||||||
|
|
||||||
// @TODO: delete and save events in one transaction and it only should delete events that are not in the new events list and save events that are not in the database
|
// @TODO: delete and save events in one transaction and it only should delete events that are not in the new events list and save events that are not in the database
|
||||||
err = db.DeleteAllEventsForCourse(app, "Sport", functions.GetCurrentSemesterString())
|
err = db.DeleteAllEventsByCourse(app, "Sport", functions.GetCurrentSemesterString())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@@ -12,6 +12,7 @@ import (
|
|||||||
localTime "htwkalender/service/functions/time"
|
localTime "htwkalender/service/functions/time"
|
||||||
"log/slog"
|
"log/slog"
|
||||||
"strings"
|
"strings"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
func ParseEventsFromRemote(app *pocketbase.PocketBase) (model.Events, error) {
|
func ParseEventsFromRemote(app *pocketbase.PocketBase) (model.Events, error) {
|
||||||
@@ -52,29 +53,38 @@ func FetchAllEventsAndSave(app *pocketbase.PocketBase, clock localTime.Clock) ([
|
|||||||
"%0A?&template=sws_modul&weeks=1-65&combined=yes",
|
"%0A?&template=sws_modul&weeks=1-65&combined=yes",
|
||||||
}
|
}
|
||||||
|
|
||||||
if (clock.Now().Month() >= 3) && (clock.Now().Month() <= 10) {
|
savedRecordsSs, errSs := fetchAndSaveAllEventsForSemester(app, time.March, time.October, "ss", clock, stubUrl)
|
||||||
url := stubUrl[0] + "ss" + stubUrl[1]
|
if errSs == nil {
|
||||||
var events []model.Event
|
savedRecords = append(savedRecords, savedRecordsSs...)
|
||||||
events, err = parseEventForOneSemester(url)
|
|
||||||
if err != nil {
|
|
||||||
// append new error to err
|
|
||||||
// fmt.Errorf("failed to parse events for summmer semester: %w", err)
|
|
||||||
err = fmt.Errorf("failed to parse events for summmer semester: %w", err)
|
|
||||||
}
|
|
||||||
savedEvents, dbError := db.SaveEvents(events, app)
|
|
||||||
if dbError != nil {
|
|
||||||
// fmt.Errorf("failed to save events: %w", dbError)
|
|
||||||
err = fmt.Errorf("failed to save events: %w", dbError)
|
|
||||||
}
|
|
||||||
savedRecords = append(savedEvents, events...)
|
|
||||||
}
|
}
|
||||||
|
savedRecordsWs, errWs := fetchAndSaveAllEventsForSemester(app, time.September, time.April, "ws", clock, stubUrl)
|
||||||
|
if errWs == nil {
|
||||||
|
savedRecords = append(savedRecords, savedRecordsWs...)
|
||||||
|
}
|
||||||
|
return savedRecords, err
|
||||||
|
}
|
||||||
|
|
||||||
if (clock.Now().Month() >= 9) || (clock.Now().Month() <= 4) {
|
func fetchAndSaveAllEventsForSemester(
|
||||||
url := stubUrl[0] + "ws" + stubUrl[1]
|
app *pocketbase.PocketBase,
|
||||||
|
before time.Month,
|
||||||
|
after time.Month,
|
||||||
|
semester string,
|
||||||
|
clock localTime.Clock,
|
||||||
|
stubUrl [2]string,
|
||||||
|
) ([]model.Event, error) {
|
||||||
|
var err error = nil
|
||||||
|
var savedRecords []model.Event
|
||||||
|
|
||||||
|
if (clock.Now().Month() >= after) || (clock.Now().Month() <= before) {
|
||||||
|
url := stubUrl[0] + semester + stubUrl[1]
|
||||||
var events []model.Event
|
var events []model.Event
|
||||||
events, err = parseEventForOneSemester(url)
|
events, err = parseEventForOneSemester(url)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
err = fmt.Errorf("failed to parse events for winter semester: %w", err)
|
err = fmt.Errorf("failed to parse events for "+semester+": %w", err)
|
||||||
|
}
|
||||||
|
err = db.DeleteAllEventsBySemester(app, semester)
|
||||||
|
if err != nil {
|
||||||
|
err = fmt.Errorf("failed to delete all events for "+semester+": %w", err)
|
||||||
}
|
}
|
||||||
savedEvents, dbError := db.SaveEvents(events, app)
|
savedEvents, dbError := db.SaveEvents(events, app)
|
||||||
if dbError != nil {
|
if dbError != nil {
|
||||||
|
Reference in New Issue
Block a user