diff --git a/backend/entities/auth/base/handlers.go b/backend/entities/auth/base/handlers.go index 8402fa43..b5e39179 100644 --- a/backend/entities/auth/base/handlers.go +++ b/backend/entities/auth/base/handlers.go @@ -4,8 +4,6 @@ import ( "context" "log/slog" "net/http" - "net/url" - "time" "github.com/GenerateNU/sac/backend/integrations/oauth/soth" "github.com/GenerateNU/sac/backend/integrations/oauth/soth/sothic" @@ -72,17 +70,6 @@ func (h *Handler) Provider(c *fiber.Ctx) error { } func (h *Handler) ProviderCallback(c *fiber.Ctx) error { - defer func() { - c.Cookie(&fiber.Cookie{ - Name: "redirect", - Value: "", - Expires: time.Now().Add(-1 * time.Hour), // expire the cookie immediately - // MARK: secure should be true in prod - // use go build tags to do this - HTTPOnly: true, - }) - }() - gfUser, err := sothic.CompleteUserAuth(c) if err != nil { return err @@ -102,12 +89,7 @@ func (h *Handler) ProviderCallback(c *fiber.Ctx) error { return err } - redirect, err := url.PathUnescape(c.Cookies("redirect", "/")) - if err != nil { - return err - } - - return c.Redirect(redirect) + return c.SendStatus(http.StatusOK) } func (h *Handler) ProviderLogout(c *fiber.Ctx) error { diff --git a/backend/entities/events/previews/service.go b/backend/entities/events/previews/service.go index b3eba712..f93f5ff9 100644 --- a/backend/entities/events/previews/service.go +++ b/backend/entities/events/previews/service.go @@ -22,7 +22,7 @@ func NewService(serviceParams types.ServiceParams) Service { func (h *Handler) GetEventPreviews(pageInfo *fiberpaginate.PageInfo, start string, end string) ([]EventPreview, error) { if start == "" || end == "" { - return GetEventPreivews(h.DB, pageInfo) + return GetEventPreviews(h.DB, pageInfo) } startTime, err := utilities.ParseTime(start, utilities.YYYY_dash_MM_dash_DD) diff --git a/backend/entities/events/previews/transactions.go b/backend/entities/events/previews/transactions.go index 1c2636b6..8f257286 100644 --- a/backend/entities/events/previews/transactions.go +++ b/backend/entities/events/previews/transactions.go @@ -4,16 +4,16 @@ import ( "time" "github.com/garrettladley/fiberpaginate" + "github.com/google/uuid" "github.com/GenerateNU/sac/backend/database/cache" - "github.com/GenerateNU/sac/backend/entities/clubs" - "github.com/GenerateNU/sac/backend/entities/events/tags" + "github.com/GenerateNU/sac/backend/entities/models" "github.com/GenerateNU/sac/backend/utilities" "gorm.io/gorm" ) -func GetEventPreivews(db *gorm.DB, pageInfo *fiberpaginate.PageInfo) ([]EventPreview, error) { +func GetEventPreviews(db *gorm.DB, pageInfo *fiberpaginate.PageInfo) ([]EventPreview, error) { db = cache.SetUseCache(db, true) var events []EventStub @@ -24,19 +24,16 @@ func GetEventPreivews(db *gorm.DB, pageInfo *fiberpaginate.PageInfo) ([]EventPre return processEventStubs(db, events) } -func GetEventPreviewsByTime(db *gorm.DB, pageInfo *fiberpaginate.PageInfo, startTime *time.Time, endTime *time.Time) ([]EventPreview, error) { - var events []EventStub +func GetEventPreviewsByTime(db *gorm.DB, pageInfo *fiberpaginate.PageInfo, startTime, endTime *time.Time) ([]EventPreview, error) { + db = cache.SetUseCache(db, true) - query := cache.SetUseCache(db, true).Model(&events) + var events []EventStub + query := db.Model(&events).Scopes(utilities.IntoScope(*pageInfo, db)) if startTime != nil && endTime != nil { query = query.Where("start_time >= ? AND end_time <= ?", *startTime, *endTime) } - if pageInfo != nil { - query = query.Scopes(utilities.IntoScope(*pageInfo, db)) - } - if err := query.Find(&events).Error; err != nil { return nil, err } @@ -45,19 +42,48 @@ func GetEventPreviewsByTime(db *gorm.DB, pageInfo *fiberpaginate.PageInfo, start } func processEventStubs(db *gorm.DB, events []EventStub) ([]EventPreview, error) { - eventPreviews := make([]EventPreview, len(events)) + eventIDs := make([]uuid.UUID, len(events)) for index, event := range events { - eventTags, err := tags.GetEventTags(db, event.ID) - if err != nil { - return nil, err - } + eventIDs[index] = event.ID + } + + var eventTags []struct { + EventID uuid.UUID `gorm:"column:event_id"` + TagID uuid.UUID `gorm:"column:tag_id"` + Name string `gorm:"column:name"` + } + if err := db.Table("tags").Select("tags.id as tag_id, tags.name, event_tags.event_id"). + Joins("JOIN event_tags ON event_tags.tag_id = tags.id"). + Where("event_tags.event_id IN ?", eventIDs). + Scan(&eventTags).Error; err != nil { + return nil, err + } + + eventTagsMap := make(map[uuid.UUID][]models.Tag) + for _, et := range eventTags { + eventTagsMap[et.EventID] = append(eventTagsMap[et.EventID], + models.Tag{ + Model: models.Model{ + ID: et.TagID, + }, + Name: et.Name, + }) + } + + var hosts []models.Club + if err := db.Where("id IN ?", eventIDs).Find(&hosts).Error; err != nil { + return nil, err + } - host, err := clubs.GetClub(db, event.Host) - if err != nil { - return nil, err - } + hostsMap := make(map[uuid.UUID]models.Club) + for _, host := range hosts { + hostsMap[host.ID] = host + } - eventPreviews[index] = *event.Into(eventTags, host.Name, host.Logo) + eventPreviews := make([]EventPreview, len(events)) + for index, event := range events { + eventPreviews[index] = *event.Into(eventTagsMap[event.ID], hostsMap[event.Host].Name, hostsMap[event.Host].Logo) } + return eventPreviews, nil } diff --git a/backend/entities/events/tags/transactions.go b/backend/entities/events/tags/transactions.go index f1cf497b..d80bda35 100644 --- a/backend/entities/events/tags/transactions.go +++ b/backend/entities/events/tags/transactions.go @@ -1,7 +1,6 @@ package tags import ( - "github.com/GenerateNU/sac/backend/database/cache" "github.com/GenerateNU/sac/backend/entities/events" "github.com/GenerateNU/sac/backend/entities/models" @@ -26,15 +25,10 @@ func CreateEventTags(db *gorm.DB, id uuid.UUID, tags []models.Tag) ([]models.Tag } func GetEventTags(db *gorm.DB, id uuid.UUID) ([]models.Tag, error) { - db = cache.SetUseCache(db, true) - var tags []models.Tag - event, err := events.GetEvent(db, id, transactions.PreloadTag()) - if err != nil { - return nil, err - } - - if err := db.Model(&event).Association("Tag").Find(&tags); err != nil { + if err := db.Joins("JOIN event_tags ON event_tags.tag_id = tags.id"). + Where("event_tags.event_id = ?", id). + Find(&tags).Error; err != nil { return nil, err } return tags, nil diff --git a/backend/integrations/oauth/soth/sothic/sothic.go b/backend/integrations/oauth/soth/sothic/sothic.go index 92a03d21..c375c3a3 100644 --- a/backend/integrations/oauth/soth/sothic/sothic.go +++ b/backend/integrations/oauth/soth/sothic/sothic.go @@ -9,6 +9,7 @@ import ( "fmt" "io" "log/slog" + "net/http" "net/url" "strings" @@ -72,7 +73,8 @@ func BeginAuthHandler(c *fiber.Ctx) error { return c.Status(fiber.StatusBadRequest).SendString(err.Error()) } - return c.Redirect(url, fiber.StatusTemporaryRedirect) + c.Set("redirect", url) + return c.SendStatus(http.StatusOK) } // SetState sets the state string associated with the given request. diff --git a/backend/middleware/auth/authorize.go b/backend/middleware/auth/authorize.go index c78a3a12..fa791251 100644 --- a/backend/middleware/auth/authorize.go +++ b/backend/middleware/auth/authorize.go @@ -1,9 +1,8 @@ package auth import ( - "net/url" + "net/http" "slices" - "time" "github.com/GenerateNU/sac/backend/entities/models" "github.com/GenerateNU/sac/backend/integrations/oauth/soth/sothic" @@ -18,16 +17,8 @@ func (m *AuthMiddlewareHandler) Authorize(requiredPermissions ...permission.Perm return func(c *fiber.Ctx) error { strUser, err := sothic.GetFromSession("user", c) if err != nil { - c.Cookie(&fiber.Cookie{ - Name: "redirect", - Value: url.PathEscape(c.OriginalURL()), - Expires: time.Now().Add(5 * time.Minute), - // MARK: secure should be true in prod - // use go build tags to do this - HTTPOnly: true, - }) - - return c.Redirect("/api/v1/auth/login") + c.Set("redirect", "/api/v1/auth/login") + return c.SendStatus(http.StatusUnauthorized) } user := models.UnmarshalUser(strUser) diff --git a/backend/middleware/auth/club.go b/backend/middleware/auth/club.go index 54d42980..883132cc 100644 --- a/backend/middleware/auth/club.go +++ b/backend/middleware/auth/club.go @@ -1,8 +1,8 @@ package auth import ( + "net/http" "slices" - "time" "github.com/GenerateNU/sac/backend/entities/clubs" "github.com/GenerateNU/sac/backend/entities/models" @@ -16,15 +16,8 @@ import ( func (m *AuthMiddlewareHandler) ClubAuthorizeById(c *fiber.Ctx, extractor ExtractID) error { strUser, err := sothic.GetFromSession("user", c) if err != nil { - c.Cookie(&fiber.Cookie{ - Name: "redirect", - Value: c.OriginalURL(), - Expires: time.Now().Add(5 * time.Minute), - // MARK: secure should be true in prod - // use go build tags to do this - HTTPOnly: true, - }) - return c.Redirect("/api/v1/auth/login") + c.Set("redirect", "/api/v1/auth/login") + return c.SendStatus(http.StatusUnauthorized) } user := models.UnmarshalUser(strUser) diff --git a/backend/middleware/auth/event.go b/backend/middleware/auth/event.go index 61945493..d4740bb4 100644 --- a/backend/middleware/auth/event.go +++ b/backend/middleware/auth/event.go @@ -1,8 +1,8 @@ package auth import ( + "net/http" "slices" - "time" "github.com/GenerateNU/sac/backend/entities/events" "github.com/GenerateNU/sac/backend/entities/models" @@ -17,16 +17,8 @@ import ( func (m *AuthMiddlewareHandler) EventAuthorizeById(c *fiber.Ctx, extractor ExtractID) error { strUser, err := sothic.GetFromSession("user", c) if err != nil { - c.Cookie(&fiber.Cookie{ - Name: "redirect", - Value: c.OriginalURL(), - Expires: time.Now().Add(5 * time.Minute), - // MARK: secure should be true in prod - // use go build tags to do this - HTTPOnly: true, - }) - - return c.Redirect("/api/v1/auth/login") + c.Set("redirect", "/api/v1/auth/login") + return c.SendStatus(http.StatusUnauthorized) } user := models.UnmarshalUser(strUser) diff --git a/backend/middleware/auth/user.go b/backend/middleware/auth/user.go index c9ab0107..fd5ee727 100644 --- a/backend/middleware/auth/user.go +++ b/backend/middleware/auth/user.go @@ -1,7 +1,7 @@ package auth import ( - "time" + "net/http" "github.com/GenerateNU/sac/backend/entities/models" "github.com/GenerateNU/sac/backend/integrations/oauth/soth/sothic" @@ -13,16 +13,8 @@ import ( func (m *AuthMiddlewareHandler) UserAuthorizeById(c *fiber.Ctx) error { strUser, err := sothic.GetFromSession("user", c) if err != nil { - c.Cookie(&fiber.Cookie{ - Name: "redirect", - Value: c.OriginalURL(), - Expires: time.Now().Add(5 * time.Minute), - // MARK: secure should be true in prod - // use go build tags to do this - HTTPOnly: true, - }) - - return c.Redirect("/api/v1/auth/login") + c.Set("redirect", "/api/v1/auth/login") + return c.SendStatus(http.StatusUnauthorized) } user := models.UnmarshalUser(strUser)