aboutsummaryrefslogtreecommitdiffstats
path: root/api/handlers
diff options
context:
space:
mode:
Diffstat (limited to 'api/handlers')
-rw-r--r--api/handlers/calendar.go81
-rw-r--r--api/handlers/ical.go43
-rw-r--r--api/handlers/schedule.go2
3 files changed, 125 insertions, 1 deletions
diff --git a/api/handlers/calendar.go b/api/handlers/calendar.go
new file mode 100644
index 0000000..85a9b00
--- /dev/null
+++ b/api/handlers/calendar.go
@@ -0,0 +1,81 @@
+package handlers
+
+import (
+ "errors"
+
+ "github.com/LMBishop/confplanner/api/dto"
+ "github.com/LMBishop/confplanner/pkg/calendar"
+ "github.com/gofiber/fiber/v2"
+)
+
+func GetCalendar(calendarService calendar.Service, baseURL string) fiber.Handler {
+ // TODO create config service
+ return func(c *fiber.Ctx) error {
+ uid := c.Locals("uid").(int32)
+
+ cal, err := calendarService.GetCalendarForUser(uid)
+ if err != nil {
+ if errors.Is(err, calendar.ErrCalendarNotFound) {
+ return &dto.ErrorResponse{
+ Code: fiber.StatusNotFound,
+ Message: "Calendar not found",
+ }
+ }
+
+ return err
+ }
+
+ return &dto.OkResponse{
+ Code: fiber.StatusOK,
+ Data: &dto.GetCalendarResponse{
+ ID: cal.ID,
+ Name: cal.Name,
+ Key: cal.Key,
+ URL: baseURL + "/calendar/ical?name=" + cal.Name + "&key=" + cal.Key,
+ },
+ }
+ }
+}
+
+func CreateCalendar(calendarService calendar.Service, baseURL string) fiber.Handler {
+ return func(c *fiber.Ctx) error {
+ uid := c.Locals("uid").(int32)
+
+ cal, err := calendarService.CreateCalendarForUser(uid)
+ if err != nil {
+ return err
+ }
+
+ return &dto.OkResponse{
+ Code: fiber.StatusCreated,
+ Data: &dto.CreateCalendarResponse{
+ ID: cal.ID,
+ Name: cal.Name,
+ Key: cal.Key,
+ URL: baseURL + "/calendar/ical?name=" + cal.Name + "&key=" + cal.Key,
+ },
+ }
+ }
+}
+
+func DeleteCalendar(calendarService calendar.Service) fiber.Handler {
+ return func(c *fiber.Ctx) error {
+ uid := c.Locals("uid").(int32)
+
+ err := calendarService.DeleteCalendarForUser(uid)
+ if err != nil {
+ if errors.Is(err, calendar.ErrCalendarNotFound) {
+ return &dto.ErrorResponse{
+ Code: fiber.StatusNotFound,
+ Message: "Calendar not found",
+ }
+ }
+
+ return err
+ }
+
+ return &dto.OkResponse{
+ Code: fiber.StatusOK,
+ }
+ }
+}
diff --git a/api/handlers/ical.go b/api/handlers/ical.go
new file mode 100644
index 0000000..c4b3989
--- /dev/null
+++ b/api/handlers/ical.go
@@ -0,0 +1,43 @@
+package handlers
+
+import (
+ "crypto/subtle"
+
+ "github.com/LMBishop/confplanner/api/dto"
+ "github.com/LMBishop/confplanner/pkg/calendar"
+ "github.com/LMBishop/confplanner/pkg/ical"
+ "github.com/gofiber/fiber/v2"
+)
+
+func GetIcal(icalService ical.Service, calendarService calendar.Service) fiber.Handler {
+ return func(c *fiber.Ctx) error {
+ name := c.Query("name")
+ key := c.Query("key")
+
+ if name == "" || key == "" {
+ return &dto.ErrorResponse{
+ Code: fiber.StatusBadRequest,
+ Message: "Both name and key must be specified",
+ }
+ }
+
+ calendar, err := calendarService.GetCalendarByName(name)
+ if err != nil {
+ return err
+ }
+
+ if subtle.ConstantTimeCompare([]byte(key), []byte(calendar.Key)) != 1 {
+ return &dto.ErrorResponse{
+ Code: fiber.StatusUnauthorized,
+ Message: "Invalid key",
+ }
+ }
+
+ ical, err := icalService.GenerateIcalForCalendar(*calendar)
+ if err != nil {
+ return err
+ }
+
+ return c.SendString(ical)
+ }
+}
diff --git a/api/handlers/schedule.go b/api/handlers/schedule.go
index fd3a183..46589ab 100644
--- a/api/handlers/schedule.go
+++ b/api/handlers/schedule.go
@@ -18,7 +18,7 @@ func GetSchedule(service schedule.Service) fiber.Handler {
Code: fiber.StatusOK,
Data: &dto.GetScheduleResponse{
Schedule: nilslice.Initialize(*schedule),
- LastUpdated: *lastUpdated,
+ LastUpdated: lastUpdated,
},
}
}