Package Exports
- ts-json-schema-generator
- ts-json-schema-generator/dist/factory/formatter
- ts-json-schema-generator/dist/factory/parser
- ts-json-schema-generator/dist/factory/program
- ts-json-schema-generator/dist/src/AnnotationsReader/BasicAnnotationsReader
- ts-json-schema-generator/dist/src/AnnotationsReader/ExtendedAnnotationsReader
- ts-json-schema-generator/dist/src/ChainNodeParser
- ts-json-schema-generator/dist/src/CircularReferenceNodeParser
- ts-json-schema-generator/dist/src/Config
- ts-json-schema-generator/dist/src/Error/NoRootTypeError
- ts-json-schema-generator/dist/src/ExposeNodeParser
- ts-json-schema-generator/dist/src/NodeParser
- ts-json-schema-generator/dist/src/NodeParser/AnnotatedNodeParser
- ts-json-schema-generator/dist/src/NodeParser/AnyTypeNodeParser
- ts-json-schema-generator/dist/src/NodeParser/ArrayNodeParser
- ts-json-schema-generator/dist/src/NodeParser/BooleanLiteralNodeParser
- ts-json-schema-generator/dist/src/NodeParser/BooleanTypeNodeParser
- ts-json-schema-generator/dist/src/NodeParser/CallExpressionParser
- ts-json-schema-generator/dist/src/NodeParser/ConditionalTypeNodeParser
- ts-json-schema-generator/dist/src/NodeParser/EnumNodeParser
- ts-json-schema-generator/dist/src/NodeParser/ExpressionWithTypeArgumentsNodeParser
- ts-json-schema-generator/dist/src/NodeParser/FunctionNodeParser
- ts-json-schema-generator/dist/src/NodeParser/IndexedAccessTypeNodeParser
- ts-json-schema-generator/dist/src/NodeParser/InterfaceAndClassNodeParser
- ts-json-schema-generator/dist/src/NodeParser/IntersectionNodeParser
- ts-json-schema-generator/dist/src/NodeParser/LiteralNodeParser
- ts-json-schema-generator/dist/src/NodeParser/MappedTypeNodeParser
- ts-json-schema-generator/dist/src/NodeParser/NeverTypeNodeParser
- ts-json-schema-generator/dist/src/NodeParser/NullLiteralNodeParser
- ts-json-schema-generator/dist/src/NodeParser/NumberLiteralNodeParser
- ts-json-schema-generator/dist/src/NodeParser/NumberTypeNodeParser
- ts-json-schema-generator/dist/src/NodeParser/ObjectTypeNodeParser
- ts-json-schema-generator/dist/src/NodeParser/OptionalTypeNodeParser
- ts-json-schema-generator/dist/src/NodeParser/ParenthesizedNodeParser
- ts-json-schema-generator/dist/src/NodeParser/PrefixUnaryExpressionNodeParser
- ts-json-schema-generator/dist/src/NodeParser/RestTypeNodeParser
- ts-json-schema-generator/dist/src/NodeParser/StringLiteralNodeParser
- ts-json-schema-generator/dist/src/NodeParser/StringTypeNodeParser
- ts-json-schema-generator/dist/src/NodeParser/TupleNodeParser
- ts-json-schema-generator/dist/src/NodeParser/TypeAliasNodeParser
- ts-json-schema-generator/dist/src/NodeParser/TypeLiteralNodeParser
- ts-json-schema-generator/dist/src/NodeParser/TypeOperatorNodeParser
- ts-json-schema-generator/dist/src/NodeParser/TypeReferenceNodeParser
- ts-json-schema-generator/dist/src/NodeParser/TypeofNodeParser
- ts-json-schema-generator/dist/src/NodeParser/UndefinedTypeNodeParser
- ts-json-schema-generator/dist/src/NodeParser/UnionNodeParser
- ts-json-schema-generator/dist/src/NodeParser/UnknownTypeNodeParser
- ts-json-schema-generator/dist/src/TopRefNodeParser
- ts-json-schema-generator/dist/src/Type/ArrayType
- ts-json-schema-generator/dist/src/Type/DefinitionType
- ts-json-schema-generator/dist/src/Type/OptionalType
- ts-json-schema-generator/dist/src/Type/RestType
- ts-json-schema-generator/dist/src/Type/TupleType
- ts-json-schema-generator/dist/src/Utils/symbolAtNode
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (ts-json-schema-generator) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
ts-json-schema-generator
Extended version of https://github.com/xiag-ag/typescript-to-json-schema.
Inspired by YousefED/typescript-json-schema
. Here's the differences list:
- this implementation does not use
typeChecker.getTypeAtLocation()
(so probably it keeps correct type aliases) - processing AST and formatting JSON schema have been split into two independent steps
- not exported types, interfaces, enums are not exposed in the
definitions
section in the JSON schema
Contributors
This project is made possible by a community of contributors. We welcome contributions of any kind (issues, code, documentation, examples, tests,...). Please read our code of conduct.
Usage
npm install --save ts-json-schema-generator
./node_modules/.bin/ts-json-schema-generator --path 'my/project/**.*.ts' --type 'My.Type.Full.Name'
Options
-p, --path 'index.ts'
The path to the TypeScript source file. If this is not provided, the type will be searched in the project specified in the `.tsconfig`.
-t, --type 'My.Type.Full.Name'
The type the generated schema will represent. If omitted, the generated schema will contain all
types found in the files matching path. The same is true if '*' is specified.
-e, --expose <all|none|export>
all: Create shared $ref definitions for all types.
none: Do not create shared $ref definitions.
export (default): Create shared $ref definitions only for exported types.
-f, --tsconfig 'my/project/tsconfig.json'
Use a custom tsconfig file for processing typescript (see https://www.typescriptlang.org/docs/handbook/tsconfig-json.html) instead of the default:
{
"compilerOptions": {
"noEmit": true,
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"target": "ES5",
"module": "CommonJS",
"strictNullChecks": false,
}
}
-r, --no-top-ref
Do not create a top-level $ref definition.
-j, --jsDoc <extended|none|basic>
none: Do not use JsDoc annotations.
basic: Read JsDoc annotations to provide schema properties.
extended (default): Also read @nullable, and @asType annotations.
-u, --unstable
Do not sort properties.
-s, --strict-tuples
Do not allow additional items on tuples.
-c, --skip-type-check
Skip type checks for better performance.
-k, --validationKeywords
Provide additional validation keywords to include.
Current state
interface
typesenum
typesunion
,tuple
,type[]
typesstring
,boolean
,number
types"value"
,123
,true
,false
,null
,undefined
literals- type aliases
- generics
typeof
keyof
- conditional types
Debug
yarn run debug --path 'test/valid-data/type-mapped-array/*.ts' --type 'MyObject'
And connect via the debugger protocol.
AST Explorer is amazing for developers of this tool!