package app import ( "net/http" "bindbox-game/internal/code" "bindbox-game/internal/pkg/core" "bindbox-game/internal/pkg/validation" "bindbox-game/internal/pkg/logger" "bindbox-game/internal/repository/mysql" "bindbox-game/internal/repository/mysql/dao" ) type categoryHandler struct { logger logger.CustomLogger readDB *dao.Query } func NewCategory(logger logger.CustomLogger, db mysql.Repo) *categoryHandler { return &categoryHandler{logger: logger, readDB: dao.Use(db.GetDbR())} } type appCategoryItem struct { ID int64 `json:"id"` Name string `json:"name"` } type listAppCategoriesResponse struct { List []appCategoryItem `json:"list"` } func (h *categoryHandler) ListCategoriesForApp() core.HandlerFunc { return func(ctx core.Context) { q := h.readDB.ProductCategories.WithContext(ctx.RequestContext()) items, err := q.Where(h.readDB.ProductCategories.Status.Eq(1)).Order(h.readDB.ProductCategories.ID.Asc()).Find() if err != nil { ctx.AbortWithError(core.Error(http.StatusBadRequest, code.ServerError, validation.Error(err))) return } res := &listAppCategoriesResponse{List: make([]appCategoryItem, len(items))} for i, it := range items { res.List[i] = appCategoryItem{ID: it.ID, Name: it.Name} } ctx.Payload(res) } }