offline-twitter/internal/webserver/handler_bookmarks.go
Alessio 2edead5913 BUGFIX: fix a bunch of issues with HTMX error-response toasts
- Add tests for a bunch of error cases and non-happy paths
2024-12-02 18:50:54 -08:00

57 lines
1.5 KiB
Go

package webserver
import (
"errors"
"net/http"
"gitlab.com/offline-twitter/twitter_offline_engine/pkg/persistence"
"gitlab.com/offline-twitter/twitter_offline_engine/pkg/scraper"
)
func (app *Application) Bookmarks(w http.ResponseWriter, r *http.Request) {
app.traceLog.Printf("'Bookmarks' handler (path: %q)", r.URL.Path)
// Run a scrape if needed
if r.URL.Query().Has("scrape") {
if app.IsScrapingDisabled {
app.InfoLog.Printf("Would have scraped: %s", r.URL.Path)
app.error_401(w, r)
return
}
// Run scraper
trove, err := app.API.GetBookmarks(300) // TODO: parameterizable
if err != nil && !errors.Is(err, scraper.END_OF_FEED) {
app.ErrorLog.Print(err)
panic(err) // Return a toast
}
app.Profile.SaveTweetTrove(trove, false, &app.API)
go app.Profile.SaveTweetTrove(trove, true, &app.API)
}
c := persistence.NewUserFeedBookmarksCursor(app.ActiveUser.Handle)
err := parse_cursor_value(&c, r)
if err != nil {
app.error_400_with_message(w, r, "invalid cursor (must be a number)")
return
}
feed, err := app.Profile.NextPage(c, app.ActiveUser.ID)
if err != nil && !errors.Is(err, persistence.ErrEndOfFeed) {
panic(err)
}
if is_htmx(r) && c.CursorPosition == persistence.CURSOR_MIDDLE {
// It's a Show More request
app.buffered_render_htmx(w, "timeline", PageGlobalData{TweetTrove: feed.TweetTrove}, feed)
} else {
app.buffered_render_page(
w,
"tpl/bookmarks.tpl",
PageGlobalData{TweetTrove: feed.TweetTrove},
TimelineData{Feed: feed},
)
}
}