mirror of
https://gitlab.dit.htwk-leipzig.de/htwk-software/htwkalender-pwa.git
synced 2025-08-03 10:19:16 +02:00
feature:#150 added slog and changed signatures
This commit is contained in:
@@ -30,7 +30,7 @@ func GetSeminarEvents(c echo.Context, app *pocketbase.PocketBase) error {
|
||||
|
||||
seminarGroups = ReplaceEmptyEventNames(seminarGroups)
|
||||
|
||||
savedRecords, dbError := db.SaveSeminarGroupEvents(seminarGroups, app)
|
||||
dbError, savedRecords := db.SaveSeminarGroupEvents(seminarGroups, app)
|
||||
|
||||
if dbError != nil {
|
||||
return apis.NewNotFoundError("Events could not be saved", dbError.Error())
|
||||
|
@@ -1,51 +1,54 @@
|
||||
package v2
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"github.com/google/uuid"
|
||||
"github.com/labstack/echo/v5"
|
||||
"github.com/pocketbase/pocketbase"
|
||||
"golang.org/x/net/html"
|
||||
"htwkalender/model"
|
||||
"htwkalender/service/db"
|
||||
"htwkalender/service/fetch"
|
||||
"strconv"
|
||||
localTime "htwkalender/service/functions/time"
|
||||
"strings"
|
||||
"time"
|
||||
)
|
||||
|
||||
func ParseEventsFromRemote(c echo.Context, app *pocketbase.PocketBase) error {
|
||||
|
||||
err, savedRecords := FetchAllEventsAndSave(app)
|
||||
|
||||
func ParseEventsFromRemote(app *pocketbase.PocketBase) (model.Events, error) {
|
||||
savedRecords, err := FetchAllEventsAndSave(app, localTime.RealClock{})
|
||||
if err != nil {
|
||||
return err
|
||||
} else {
|
||||
savedRecordsLength := strconv.FormatInt(int64(len(savedRecords)), 10)
|
||||
return c.JSON(200, "Successfully saved "+savedRecordsLength+" events")
|
||||
return nil, err
|
||||
}
|
||||
return savedRecords, nil
|
||||
}
|
||||
|
||||
func FetchAllEventsAndSave(app *pocketbase.PocketBase) (error, []model.Event) {
|
||||
var err error
|
||||
func FetchAllEventsAndSave(app *pocketbase.PocketBase, clock localTime.Clock) ([]model.Event, error) {
|
||||
var savedRecords []model.Event
|
||||
var events []model.Event
|
||||
|
||||
if (time.Now().Month() >= 3) && (time.Now().Month() <= 10) {
|
||||
if (clock.Now().Month() >= 3) && (clock.Now().Month() <= 10) {
|
||||
url := "https://stundenplan.htwk-leipzig.de/ss/Berichte/Text-Listen;Veranstaltungsarten;name;Vp%0AVw%0AV%0ASp%0ASw%0AS%0APp%0APw%0AP%0AZV%0ATut%0ASperr%0Apf%0Awpf%0Afak%0A%0A?&template=sws_modul&weeks=1-65&combined=yes"
|
||||
events, err = parseEventForOneSemester(url)
|
||||
events, err := parseEventForOneSemester(url)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("failed to parse events for summmer semester: %w", err)
|
||||
}
|
||||
savedEvents, dbError := db.SaveEvents(events, app)
|
||||
err = dbError
|
||||
if dbError != nil {
|
||||
return nil, fmt.Errorf("failed to save events: %w", dbError)
|
||||
}
|
||||
savedRecords = append(savedEvents, events...)
|
||||
}
|
||||
|
||||
if (time.Now().Month() >= 9) || (time.Now().Month() <= 4) {
|
||||
if (clock.Now().Month() >= 9) || (clock.Now().Month() <= 4) {
|
||||
url := "https://stundenplan.htwk-leipzig.de/ws/Berichte/Text-Listen;Veranstaltungsarten;name;Vp%0AVw%0AV%0ASp%0ASw%0AS%0APp%0APw%0AP%0AZV%0ATut%0ASperr%0Apf%0Awpf%0Afak%0A%0A?&template=sws_modul&weeks=1-65&combined=yes"
|
||||
events, err = parseEventForOneSemester(url)
|
||||
events, err := parseEventForOneSemester(url)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("failed to parse events for winter semester: %w", err)
|
||||
}
|
||||
savedEvents, dbError := db.SaveEvents(events, app)
|
||||
err = dbError
|
||||
if dbError != nil {
|
||||
return nil, fmt.Errorf("failed to save events: %w", dbError)
|
||||
}
|
||||
savedRecords = append(savedEvents, events...)
|
||||
}
|
||||
return err, savedRecords
|
||||
return savedRecords, nil
|
||||
}
|
||||
|
||||
func parseEventForOneSemester(url string) ([]model.Event, error) {
|
||||
@@ -56,25 +59,18 @@ func parseEventForOneSemester(url string) ([]model.Event, error) {
|
||||
}
|
||||
|
||||
// Parse HTML to Node Tree
|
||||
doc, err2 := parseHTML(err, webpage)
|
||||
if err2 != nil {
|
||||
return nil, err2
|
||||
var doc *html.Node
|
||||
doc, err = parseHTML(webpage, err)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// Get all event tables and all day labels
|
||||
eventTables := getEventTables(doc)
|
||||
allDayLabels := getAllDayLabels(doc)
|
||||
|
||||
if eventTables == nil || allDayLabels == nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
eventsWithCombinedWeeks := toEvents(eventTables, allDayLabels)
|
||||
|
||||
if eventsWithCombinedWeeks == nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
splitEventsByWeekVal := splitEventsByWeek(eventsWithCombinedWeeks)
|
||||
events := splitEventsBySingleWeek(splitEventsByWeekVal)
|
||||
|
||||
@@ -83,6 +79,11 @@ func parseEventForOneSemester(url string) ([]model.Event, error) {
|
||||
}
|
||||
|
||||
table := findFirstTable(doc)
|
||||
|
||||
if table == nil {
|
||||
return nil, fmt.Errorf("failed to find first table")
|
||||
}
|
||||
|
||||
semesterString := findFirstSpanWithClass(table, "header-0-2-0").FirstChild.Data
|
||||
semester, year := extractSemesterAndYear(semesterString)
|
||||
events = convertWeeksToDates(events, semester, year)
|
||||
@@ -101,7 +102,7 @@ func parseEventForOneSemester(url string) ([]model.Event, error) {
|
||||
return events, nil
|
||||
}
|
||||
|
||||
func parseHTML(err error, webpage string) (*html.Node, error) {
|
||||
func parseHTML(webpage string, err error) (*html.Node, error) {
|
||||
doc, err := html.Parse(strings.NewReader(webpage))
|
||||
if err != nil {
|
||||
return nil, err
|
||||
|
Reference in New Issue
Block a user