mirror of
https://gitlab.dit.htwk-leipzig.de/htwk-software/htwkalender.git
synced 2025-08-07 04:09:15 +02:00
refactoring and update
This commit is contained in:
11
addRoute.go
11
addRoute.go
@@ -5,9 +5,9 @@ import (
|
|||||||
"github.com/pocketbase/pocketbase"
|
"github.com/pocketbase/pocketbase"
|
||||||
"github.com/pocketbase/pocketbase/apis"
|
"github.com/pocketbase/pocketbase/apis"
|
||||||
"github.com/pocketbase/pocketbase/core"
|
"github.com/pocketbase/pocketbase/core"
|
||||||
"htwk-planner/service"
|
|
||||||
"htwk-planner/service/fetch"
|
"htwk-planner/service/fetch"
|
||||||
"htwk-planner/service/ical"
|
"htwk-planner/service/ical"
|
||||||
|
"htwk-planner/service/room"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
)
|
)
|
||||||
@@ -58,7 +58,7 @@ func addRoutes(app *pocketbase.PocketBase) {
|
|||||||
Method: http.MethodGet,
|
Method: http.MethodGet,
|
||||||
Path: "/api/rooms",
|
Path: "/api/rooms",
|
||||||
Handler: func(c echo.Context) error {
|
Handler: func(c echo.Context) error {
|
||||||
return service.GetRooms(c, app)
|
return room.GetRooms(c, app)
|
||||||
},
|
},
|
||||||
Middlewares: []echo.MiddlewareFunc{
|
Middlewares: []echo.MiddlewareFunc{
|
||||||
apis.ActivityLogger(app),
|
apis.ActivityLogger(app),
|
||||||
@@ -75,7 +75,9 @@ func addRoutes(app *pocketbase.PocketBase) {
|
|||||||
Method: http.MethodGet,
|
Method: http.MethodGet,
|
||||||
Path: "/api/feedURL",
|
Path: "/api/feedURL",
|
||||||
Handler: func(c echo.Context) error {
|
Handler: func(c echo.Context) error {
|
||||||
return ical.FeedURL(c, app)
|
course := c.Request().Header.Get("course")
|
||||||
|
semester := c.Request().Header.Get("semester")
|
||||||
|
return ical.FeedURL(c, app, course, semester)
|
||||||
},
|
},
|
||||||
Middlewares: []echo.MiddlewareFunc{
|
Middlewares: []echo.MiddlewareFunc{
|
||||||
apis.ActivityLogger(app),
|
apis.ActivityLogger(app),
|
||||||
@@ -92,7 +94,8 @@ func addRoutes(app *pocketbase.PocketBase) {
|
|||||||
Method: http.MethodGet,
|
Method: http.MethodGet,
|
||||||
Path: "/api/feed",
|
Path: "/api/feed",
|
||||||
Handler: func(c echo.Context) error {
|
Handler: func(c echo.Context) error {
|
||||||
return ical.Feed(c, app)
|
token := c.QueryParam("token")
|
||||||
|
return ical.Feed(c, app, token)
|
||||||
},
|
},
|
||||||
Middlewares: []echo.MiddlewareFunc{
|
Middlewares: []echo.MiddlewareFunc{
|
||||||
apis.ActivityLogger(app),
|
apis.ActivityLogger(app),
|
||||||
|
@@ -1,7 +1,6 @@
|
|||||||
package ical
|
package model
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"htwk-planner/model"
|
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -9,6 +8,8 @@ import (
|
|||||||
type FeedModel struct {
|
type FeedModel struct {
|
||||||
Content string
|
Content string
|
||||||
ExpiresAt time.Time
|
ExpiresAt time.Time
|
||||||
|
Semester string
|
||||||
|
Course string
|
||||||
}
|
}
|
||||||
|
|
||||||
// Entry is a time entry
|
// Entry is a time entry
|
||||||
@@ -21,4 +22,4 @@ type Entry struct {
|
|||||||
// Entries is a collection of entries
|
// Entries is a collection of entries
|
||||||
type Entries []*Entry
|
type Entries []*Entry
|
||||||
|
|
||||||
type Events []*model.Event
|
type Events []*Event
|
@@ -102,6 +102,7 @@ func (e Events) EmitICal() goics.Componenter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// GetPlanForCourseAndSemester gets all events for specific course and semester
|
// GetPlanForCourseAndSemester gets all events for specific course and semester
|
||||||
|
// TODO add filter for year
|
||||||
func GetPlanForCourseAndSemester(app *pocketbase.PocketBase, course string, semester string) Events {
|
func GetPlanForCourseAndSemester(app *pocketbase.PocketBase, course string, semester string) Events {
|
||||||
var events Events
|
var events Events
|
||||||
// get all events from event records in the events collection
|
// get all events from event records in the events collection
|
||||||
|
@@ -7,31 +7,29 @@ import (
|
|||||||
"github.com/jordic/goics"
|
"github.com/jordic/goics"
|
||||||
"github.com/labstack/echo/v5"
|
"github.com/labstack/echo/v5"
|
||||||
"github.com/pocketbase/pocketbase"
|
"github.com/pocketbase/pocketbase"
|
||||||
|
"htwk-planner/model"
|
||||||
"htwk-planner/service/db"
|
"htwk-planner/service/db"
|
||||||
"log"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
const expirationTime = 5 * time.Minute
|
const expirationTime = 5 * time.Minute
|
||||||
|
|
||||||
var cache = make(map[string]*FeedModel)
|
var cache = make(map[string]*model.FeedModel)
|
||||||
|
|
||||||
func FeedURL(c echo.Context, app *pocketbase.PocketBase) error {
|
func FeedURL(c echo.Context, app *pocketbase.PocketBase, course string, semester string) error {
|
||||||
token := randomToken(20)
|
token := randomToken(20)
|
||||||
_, err := createFeedForToken(app, token)
|
_, err := createFeedForToken(app, token, course, semester)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return c.JSON(http.StatusOK, fmt.Sprintf("FeedToken: %s", token))
|
return c.JSON(http.StatusOK, fmt.Sprintf("FeedToken: %s", token))
|
||||||
}
|
}
|
||||||
|
|
||||||
func Feed(c echo.Context, app *pocketbase.PocketBase) error {
|
func Feed(c echo.Context, app *pocketbase.PocketBase, token string) error {
|
||||||
|
|
||||||
var result string
|
var result string
|
||||||
var responseWriter = c.Response().Writer
|
var responseWriter = c.Response().Writer
|
||||||
token := c.QueryParam("token")
|
|
||||||
log.Print("iCal feed Token: " + token)
|
|
||||||
feed, ok := cache[token]
|
feed, ok := cache[token]
|
||||||
if !ok || feed == nil {
|
if !ok || feed == nil {
|
||||||
return c.JSON(http.StatusNotFound, "No FeedModel for this Token")
|
return c.JSON(http.StatusNotFound, "No FeedModel for this Token")
|
||||||
@@ -39,7 +37,7 @@ func Feed(c echo.Context, app *pocketbase.PocketBase) error {
|
|||||||
|
|
||||||
result = feed.Content
|
result = feed.Content
|
||||||
if feed.ExpiresAt.Before(time.Now()) {
|
if feed.ExpiresAt.Before(time.Now()) {
|
||||||
newFeed, err := createFeedForToken(app, token)
|
newFeed, err := createFeedForToken(app, token, feed.Course, feed.Semester)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return c.JSON(http.StatusInternalServerError, err)
|
return c.JSON(http.StatusInternalServerError, err)
|
||||||
}
|
}
|
||||||
@@ -55,11 +53,11 @@ func Feed(c echo.Context, app *pocketbase.PocketBase) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func createFeedForToken(app *pocketbase.PocketBase, token string) (*FeedModel, error) {
|
func createFeedForToken(app *pocketbase.PocketBase, token string, course string, semester string) (*model.FeedModel, error) {
|
||||||
res := db.GetPlanForCourseAndSemester(app, "22INM", "ws")
|
res := db.GetPlanForCourseAndSemester(app, course, semester)
|
||||||
b := bytes.Buffer{}
|
b := bytes.Buffer{}
|
||||||
goics.NewICalEncode(&b).Encode(res)
|
goics.NewICalEncode(&b).Encode(res)
|
||||||
feed := &FeedModel{Content: b.String(), ExpiresAt: time.Now().Add(expirationTime)}
|
feed := &model.FeedModel{Content: b.String(), ExpiresAt: time.Now().Add(expirationTime)}
|
||||||
cache[token] = feed
|
cache[token] = feed
|
||||||
return feed, nil
|
return feed, nil
|
||||||
}
|
}
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
package service
|
package room
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/labstack/echo/v5"
|
"github.com/labstack/echo/v5"
|
Reference in New Issue
Block a user