Creating a project
Create a new hatk project using the Vite+ template:
vp create github:hatk-dev/hatk-template-starterYou'll be prompted for the target directory name.
See the Quickstart for prerequisites and setup.
hatk generate
Generate lexicons, handlers, and other project files.
Lexicons
hatk generate record <nsid> # Record schema (e.g. fm.teal.alpha.feed.play)
hatk generate query <nsid> # Query endpoint (GET)
hatk generate procedure <nsid> # Procedure endpoint (POST)Creates a JSON lexicon file at lexicons/<nsid-as-path>.json with the appropriate schema template and automatically regenerates TypeScript types.
Handlers
hatk generate feed <name> # Feed generator in feeds/
hatk generate xrpc <nsid> # XRPC handler in xrpc/
hatk generate label <name> # Label definition in labels/
hatk generate og <name> # OpenGraph image route in og/Each generator creates the handler file and a corresponding test file in the test/ directory.
Types
hatk generate typesRegenerate hatk.generated.ts from your current lexicon schemas. This runs automatically when generating new lexicons.
hatk destroy
Remove a previously generated file and its test.
hatk destroy <type> <name>Where <type> is one of: feed, xrpc, label, og.
hatk resolve
Fetch a lexicon schema from the AT Protocol network by its NSID.
hatk resolve <nsid>Downloads the lexicon JSON and any referenced definitions, saving them to your lexicons/ directory.