generated from coulomb/repo-seed
Some checks failed
Build and Deploy / build-push-deploy (push) Has been cancelled
IHP NameSupport cannot parse trailing-underscore field names at runtime.
orderByAsc #label_ in all four registry list actions (and the API V2
equivalents) crashed the page with ParseErrorBundle. Changed to orderByAsc
#name which avoids the NameSupport conversion path entirely.
textField #label_ in the four registry form views has the same issue.
Replaced with a plain <input> element that reads entry.label_ directly.
Logout <a href={DeleteSessionAction}> sent GET but IHP requires DELETE.
IHP includes methodOverridePost middleware, so a POST form with
_method=DELETE handles this correctly.
Also corrected the seed admin-user migration hash from bcrypt to the
pwstore-fast format (sha256|17|...) that IHP actually uses.
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
63 lines
1.8 KiB
Haskell
63 lines
1.8 KiB
Haskell
module Web.Controller.Api.V2.Registries where
|
|
|
|
-- Public (unauthenticated) endpoints that enumerate the registered vocabulary.
|
|
-- GET /api/v2/widget-types
|
|
-- GET /api/v2/event-types
|
|
-- GET /api/v2/annotation-categories
|
|
|
|
import Web.Types
|
|
import Generated.Types
|
|
import IHP.Prelude
|
|
import IHP.ControllerPrelude
|
|
import Data.Aeson (object, (.=))
|
|
|
|
instance Controller ApiV2RegistriesController where
|
|
|
|
action ApiV2ListWidgetTypesAction = do
|
|
types <- query @WidgetTypeRegistry
|
|
|> filterWhere (#status, "active")
|
|
|> orderByAsc #name
|
|
|> fetch
|
|
renderJson $ map wtToJson types
|
|
|
|
action ApiV2ListEventTypesAction = do
|
|
types <- query @EventTypeRegistry
|
|
|> filterWhere (#status, "active")
|
|
|> orderByAsc #name
|
|
|> fetch
|
|
renderJson $ map etToJson types
|
|
|
|
action ApiV2ListAnnotationCategoriesAction = do
|
|
cats <- query @AnnotationCategoryRegistry
|
|
|> filterWhere (#status, "active")
|
|
|> orderByAsc #name
|
|
|> fetch
|
|
renderJson $ map acToJson cats
|
|
|
|
wtToJson :: WidgetTypeRegistry -> Value
|
|
wtToJson r = object
|
|
[ "name" .= r.name
|
|
, "label" .= r.label_
|
|
, "description" .= r.description
|
|
, "ownerHubId" .= r.ownerHubId
|
|
, "status" .= r.status
|
|
]
|
|
|
|
etToJson :: EventTypeRegistry -> Value
|
|
etToJson r = object
|
|
[ "name" .= r.name
|
|
, "label" .= r.label_
|
|
, "description" .= r.description
|
|
, "ownerHubId" .= r.ownerHubId
|
|
, "status" .= r.status
|
|
]
|
|
|
|
acToJson :: AnnotationCategoryRegistry -> Value
|
|
acToJson r = object
|
|
[ "name" .= r.name
|
|
, "label" .= r.label_
|
|
, "description" .= r.description
|
|
, "ownerHubId" .= r.ownerHubId
|
|
, "status" .= r.status
|
|
]
|