For the complete documentation index optimized for AI agents, see llms.txt or llms-full.txt. A markdown version of this page is available by appending.mdto the URL or sendingAccept: text/markdown.
Schema Validation
For AI agents: the documentation index is at llms.txt (full corpus: llms-full.txt). A markdown source for this page is /sdks/validation.md.
Every Arete stack ships with Zod schemas alongside its TypeScript interfaces. These schemas give you runtime validation at two levels: automatic frame validation on the wire, and per-query validation in your application code.
Generated Schemas
Section titled “Generated Schemas”When you run a4 sdk create typescript, the CLI generates a Zod schema for every entity and sub-type. These mirror the TypeScript interfaces exactly:
import { PumpfunTokenSchema, PumpfunTokenIdSchema, PumpfunTokenReservesSchema, PumpfunTokenCompletedSchema,} from "arete-stacks/pumpfun";Each entity gets two schema variants:
| Schema | Fields | Use Case |
|---|---|---|
PumpfunTokenSchema | All optional | Partial updates during streaming |
PumpfunTokenCompletedSchema | All required | Asserting a fully-hydrated entity |
The “Completed” variant is useful when you want to guarantee every field is present before rendering — for example, filtering out tokens that haven’t received all their data yet.
Frame Validation
Section titled “Frame Validation”Enable validateFrames when connecting to automatically validate every incoming WebSocket frame against the stack’s schemas. Invalid frames are dropped with a console warning instead of corrupting your local store.
TypeScript (Core SDK)
Section titled “TypeScript (Core SDK)”import { Arete } from "arete-typescript";import { ORE_STREAM_STACK } from "arete-stacks/ore";
const a4 = await Arete.connect(ORE_STREAM_STACK, { validateFrames: true,});import { AreteProvider } from "arete-react";
function App() { return ( <AreteProvider validateFrames> <Dashboard /> </AreteProvider> );}When a frame fails validation, the SDK logs a warning with the view path and error details, then silently discards the update. Your application never sees malformed data.
Query-Level Validation
Section titled “Query-Level Validation”Pass a schema option to any streaming method to filter entities that don’t match. This works on both the core SDK and the React hooks.
TypeScript (Core SDK)
Section titled “TypeScript (Core SDK)”The .use() method accepts a schema in its options. Entities that fail validation are silently skipped:
import { Arete } from "arete-typescript";import { ORE_STREAM_STACK, OreRoundCompletedSchema,} from "arete-stacks/ore";
const a4 = await Arete.connect(ORE_STREAM_STACK);
// Only emit rounds where every field is presentfor await (const round of a4.views.OreRound.latest.use({ schema: OreRoundCompletedSchema,})) { // round is guaranteed to have all fields populated console.log(round.id.round_id, round.state.motherlode);}React Hooks
Section titled “React Hooks”Both .use() and .useOne() accept schema in their params. Entities that fail validation are filtered out of the results:
import { useArete } from "arete-react";import { ORE_STREAM_STACK, OreRoundCompletedSchema,} from "arete-stacks/ore";
function FullyLoadedRounds() { const { views } = useArete(ORE_STREAM_STACK);
// Only returns rounds where all fields are present const { data: rounds } = views.OreRound.latest.use({ schema: OreRoundCompletedSchema, });
return ( <ul> {rounds?.map((round) => ( <li key={round.id.round_id}> Round #{round.id.round_id} — {round.state.motherlode} </li> ))} </ul> );}Custom Schemas
Section titled “Custom Schemas”You can define your own Zod schemas to validate only the fields you care about. This is useful for building views that require specific data to render:
import { z } from "zod";
// Only accept tokens with complete trading dataconst TradableTokenSchema = z.object({ id: z.object({ mint: z.string(), }), reserves: z.object({ current_price_sol: z.number(), market_cap_sol: z.number(), }), trading: z.object({ total_volume: z.number(), total_trades: z.number(), }),});
// Use in Reactconst { data: tokens } = views.PumpfunToken.list.use({ schema: TradableTokenSchema,});
// Or in core SDKfor await (const token of a4.views.PumpfunToken.list.use({ schema: TradableTokenSchema,})) { console.log(token.id.mint, token.reserves.current_price_sol);}Any entity missing the required fields is silently excluded.
The Schema Interface
Section titled “The Schema Interface”The SDK defines a minimal Schema<T> interface that is natively compatible with Zod:
interface Schema<T> { safeParse: (input: unknown) => SchemaResult<T>;}
type SchemaResult<T> = | { success: true; data: T } | { success: false; error: unknown };Any object with a safeParse method works — Zod schemas satisfy this out of the box, but you can also use custom validators if needed.
Next Steps
Section titled “Next Steps”- TypeScript SDK — Core streaming API reference
- React SDK — Hooks and providers for React apps
- Resolvers — How Arete enriches entities with external data like token metadata