
Company News
Socket Partners with Replit to Block Malicious Packages in AI-Powered Development
Replit is integrating Socket Firewall into its AI-powered development experience to help protect builders from malicious open source packages.
@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.
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
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.

Research
/Security News
Newer packages in this compromise use native extensions and .pth loaders to execute JavaScript stealers in developer environments.