
Company News
Andrew Becherer Joins Socket as Chief Information Security Officer
Socket’s first CISO brings deep experience securing high-growth SaaS companies as open source supply chain threats accelerate.
@amritk/helpers
Advanced tools
Shared schema-traversal and runtime helpers for the mjst code generation ecosystem.
@amritk/helpers is the shared utility belt used by mjst's generators and by the runtime code those generators produce. Each helper is published as its own subpath export so consumers (and generated output) only pull in what they need — no barrel, no incidental dependencies.
npm install @amritk/helpers
# or
pnpm add @amritk/helpers
# or
yarn add @amritk/helpers
# or
bun add @amritk/helpers
| Subpath | Exports | Purpose |
|---|---|---|
@amritk/helpers/extract-refs | extractRefs | Collect every $ref reachable from a schema. |
@amritk/helpers/resolve-ref | resolveRef | Resolve a JSON pointer $ref against a root schema. |
@amritk/helpers/build-dynamic-ref-map | buildDynamicRefMap | Build a map of $dynamicAnchor → resolved location. |
@amritk/helpers/resolve-dynamic-refs | resolveDynamicRefs | Replace $dynamicRef occurrences using the map above. |
@amritk/helpers/upgrade-draft07-schema | upgradeDraft07Schema, isDraft07Schema | Upgrade a Draft-07 schema to 2020-12. |
@amritk/helpers/ref-to-filename | refToFilename, toKebabCase | Convert a $ref to a stable filename. |
@amritk/helpers/ref-to-name | refToName | Convert a $ref to a TypeScript identifier (PascalCase). |
@amritk/helpers/schema-guards | isSchemaObject, hasType, hasProperties, hasOneOf, hasAnyOf, hasAllOf, hasEnum, hasConst, hasPattern, hasFormat, hasDefault, hasExamples, hasRequired, hasItems, hasAdditionalProperties, hasMinLength, hasMaxLength, hasMinimum, hasMaximum, hasExclusiveMinimum, hasExclusiveMaximum, hasMultipleOf, hasMinItems, hasMaxItems, hasUniqueItems, hasMinProperties, hasMaxProperties, … | Type-narrowing predicates for JSON Schema keywords. |
| Subpath | Exports | Purpose |
|---|---|---|
@amritk/helpers/generate-type-definition | generateTypeDefinition | Render a TypeScript type from a schema node. |
@amritk/helpers/parse-documentation | parseDocumentation, ObjectDocumentation | Parse a markdown doc file into per-property descriptions. |
| Subpath | Exports | Purpose |
|---|---|---|
@amritk/helpers/is-object | isObject | Narrow unknown → Record<string, unknown>. |
@amritk/helpers/safe-accessor | safeAccessor | Read a key from an unknown value without throwing. |
@amritk/helpers/validate-array | validateArray | Validate array shape and items. |
@amritk/helpers/validate-record | validateRecord | Validate record shape and additional properties. |
import { resolveRef } from '@amritk/helpers/resolve-ref'
import { isObjectSchema, hasProperties } from '@amritk/helpers/schema-guards'
const node = resolveRef('#/$defs/info', rootSchema)
if (isObjectSchema(node) && hasProperties(node)) {
for (const [name, property] of Object.entries(node.properties)) {
// ...
}
}
Each helper has its own colocated test file (*.test.ts) — read those for canonical examples.
@amritk/generate-parsers — primary consumer@amritk/generate-validators — primary consumer@amritk/mjst — the CLI surfaceFAQs
Shared utilities for the mjst code generation ecosystem.
The npm package @amritk/helpers receives a total of 1,502 weekly downloads. As such, @amritk/helpers popularity was classified as popular.
We found that @amritk/helpers demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Company News
Socket’s first CISO brings deep experience securing high-growth SaaS companies as open source supply chain threats accelerate.

Company News
Replit is integrating Socket Firewall into its AI-powered development experience to help protect builders from malicious open source packages.

Security News
npm confirmed a tooling bug incorrectly marked several one-character packages as security holders and said it was working on a rollback.