feat:#57 updated function and calc

This commit is contained in:
Elmar Kresse
2024-04-11 17:23:04 +02:00
parent 2f0fa03b58
commit 12ad568088
2 changed files with 40 additions and 23 deletions

View File

@@ -69,17 +69,15 @@ func FetchAllEventsAndSave(app *pocketbase.PocketBase, clock localTime.Clock) ([
"%0A?&template=sws_modul&weeks=1-65&combined=yes",
}
if isSummerSemester(clock) {
savedRecordsSs, errSs := fetchAndSaveAllEventsForSemester(app, "ss", stubUrl)
if errSs == nil {
savedRecords = append(savedRecords, savedRecordsSs...)
}
} else {
savedRecordsWs, errWs := fetchAndSaveAllEventsForSemester(app, "ws", stubUrl)
if errWs == nil {
savedRecords = append(savedRecords, savedRecordsWs...)
// Fetch and save events for all semesters
for _, semester := range calculateSemesterList(clock) {
events, fetchErr := fetchAndSaveAllEventsForSemester(app, semester, stubUrl)
if fetchErr != nil {
return nil, fmt.Errorf("failed to fetch and save events for "+semester+": %w", err)
}
savedRecords = append(savedRecords, events...)
}
return savedRecords, err
}
@@ -106,12 +104,23 @@ func fetchAndSaveAllEventsForSemester(
return savedRecords, err
}
func isSummerSemester(clock localTime.Clock) bool {
if clock.Now().Month() >= time.April && clock.Now().Month() <= time.September {
return true
} else {
return false
func calculateSemesterList(clock localTime.Clock) []string {
summerSemester := clock.Now().Month() >= time.March && clock.Now().Month() <= time.September
winterSemester := clock.Now().Month() <= time.March || clock.Now().Month() >= time.September
if summerSemester && winterSemester {
return []string{"ss", "ws"}
}
if summerSemester {
return []string{"ss"}
}
if winterSemester {
return []string{"ws"}
}
return []string{"ss", "ws"}
}
func parseEventForOneSemester(url string) ([]model.Event, error) {
@@ -131,7 +140,6 @@ func parseEventForOneSemester(url string) ([]model.Event, error) {
// Get all event tables and all day labels
eventTables := getEventTables(doc)
allDayLabels := getAllDayLabels(doc)
eventsWithCombinedWeeks := toEvents(eventTables, allDayLabels)
splitEventsByWeekVal := splitEventsByWeek(eventsWithCombinedWeeks)