Redmage/server/routes/page_home.go

55 lines
1.5 KiB
Go
Raw Normal View History

2024-04-09 14:30:54 +07:00
package routes
import (
"encoding/json"
2024-04-09 14:30:54 +07:00
"net/http"
"time"
2024-04-09 14:30:54 +07:00
"github.com/tigorlazuardi/redmage/api"
"github.com/tigorlazuardi/redmage/pkg/errs"
2024-04-09 14:30:54 +07:00
"github.com/tigorlazuardi/redmage/pkg/log"
"github.com/tigorlazuardi/redmage/views"
"github.com/tigorlazuardi/redmage/views/homeview"
)
func (routes *Routes) PageHome(rw http.ResponseWriter, r *http.Request) {
2024-04-13 00:15:31 +07:00
ctx, span := tracer.Start(r.Context(), "routes.PageHome")
defer span.End()
2024-04-09 14:30:54 +07:00
vc := views.NewContext(routes.Config, r)
2024-04-09 16:09:08 +07:00
listSubredditParams := parseSubredditListQuery(r)
2024-04-09 16:09:08 +07:00
list, err := routes.API.ListSubreddits(ctx, listSubredditParams)
2024-04-09 16:09:08 +07:00
if err != nil {
log.New(ctx).Err(err).Error("failed to list subreddits")
code, message := errs.HTTPMessage(err)
rw.WriteHeader(code)
_ = json.NewEncoder(rw).Encode(map[string]string{"error": message})
return
}
imageListParams := api.ImageListParams{}
imageListParams.FillFromQuery(r.URL.Query())
imageListParams.CreatedAt = time.Now().Add(-time.Hour * 24 * 3) // images in the last 3 days.
imageList, err := routes.API.ImagesListWithDevicesAndSubreddits(ctx, imageListParams)
if err != nil {
log.New(ctx).Err(err).Error("failed to list subreddits")
code, message := errs.HTTPMessage(err)
rw.WriteHeader(code)
_ = json.NewEncoder(rw).Encode(map[string]string{"error": message})
return
2024-04-09 16:09:08 +07:00
}
data := homeview.Data{
SubredditsList: list,
RecentlyAddedImages: imageList,
Error: err,
2024-04-09 16:09:08 +07:00
}
if err := homeview.Home(vc, data).Render(ctx, rw); err != nil {
2024-04-09 14:30:54 +07:00
log.New(ctx).Err(err).Error("failed to render home view")
}
}