@hyperjump/json-schema
Version:
A JSON Schema validator with support for custom keywords, vocabularies, and dialects
365 lines (326 loc) • 8.16 kB
TypeScript
import type { Json } from "@hyperjump/json-pointer";
import type { JsonSchemaType } from "../lib/common.js";
export type OasSchema31 = boolean | {
$schema?: "https://spec.openapis.org/oas/3.1/dialect/base";
$id?: string;
$anchor?: string;
$ref?: string;
$dynamicRef?: string;
$dynamicAnchor?: string;
$vocabulary?: Record<string, boolean>;
$comment?: string;
$defs?: Record<string, OasSchema31>;
additionalItems?: OasSchema31;
unevaluatedItems?: OasSchema31;
prefixItems?: OasSchema31[];
items?: OasSchema31;
contains?: OasSchema31;
additionalProperties?: OasSchema31;
unevaluatedProperties?: OasSchema31;
properties?: Record<string, OasSchema31>;
patternProperties?: Record<string, OasSchema31>;
dependentSchemas?: Record<string, OasSchema31>;
propertyNames?: OasSchema31;
if?: OasSchema31;
then?: OasSchema31;
else?: OasSchema31;
allOf?: OasSchema31[];
anyOf?: OasSchema31[];
oneOf?: OasSchema31[];
not?: OasSchema31;
multipleOf?: number;
maximum?: number;
exclusiveMaximum?: number;
minimum?: number;
exclusiveMinimum?: number;
maxLength?: number;
minLength?: number;
pattern?: string;
maxItems?: number;
minItems?: number;
uniqueItems?: boolean;
maxContains?: number;
minContains?: number;
maxProperties?: number;
minProperties?: number;
required?: string[];
dependentRequired?: Record<string, string[]>;
const?: Json;
enum?: Json[];
type?: JsonSchemaType | JsonSchemaType[];
title?: string;
description?: string;
default?: Json;
deprecated?: boolean;
readOnly?: boolean;
writeOnly?: boolean;
examples?: Json[];
format?: "date-time" | "date" | "time" | "duration" | "email" | "idn-email" | "hostname" | "idn-hostname" | "ipv4" | "ipv6" | "uri" | "uri-reference" | "iri" | "iri-reference" | "uuid" | "uri-template" | "json-pointer" | "relative-json-pointer" | "regex";
contentMediaType?: string;
contentEncoding?: string;
contentSchema?: OasSchema31;
example?: Json;
discriminator?: Discriminator;
externalDocs?: ExternalDocs;
xml?: Xml;
};
export type Discriminator = {
propertyName: string;
mappings?: Record<string, string>;
};
export type ExternalDocs = {
url: string;
description?: string;
};
export type Xml = {
name?: string;
namespace?: string;
prefix?: string;
attribute?: boolean;
wrapped?: boolean;
};
export type OpenApi = {
openapi: string;
info: Info;
jsonSchemaDialect?: string;
servers?: Server[];
security?: SecurityRequirement[];
tags?: Tag[];
externalDocs?: ExternalDocumentation;
paths?: Record<string, PathItem>;
webhooks?: Record<string, PathItem | Reference>;
components?: Components;
};
export type Info = {
title: string;
summary?: string;
description?: string;
termsOfService?: string;
contact?: Contact;
license?: License;
version: string;
};
export type Contact = {
name?: string;
url?: string;
email?: string;
};
export type License = {
name: string;
url?: string;
identifier?: string;
};
export type Server = {
url: string;
description?: string;
variables?: Record<string, ServerVariable>;
};
export type ServerVariable = {
enum?: string[];
default: string;
description?: string;
};
export type Components = {
schemas?: Record<string, OasSchema31>;
responses?: Record<string, Response | Reference>;
parameters?: Record<string, Parameter | Reference>;
examples?: Record<string, Example | Reference>;
requestBodies?: Record<string, RequestBody | Reference>;
headers?: Record<string, Header | Reference>;
securitySchemes?: Record<string, SecurityScheme | Reference>;
links?: Record<string, Link | Reference>;
callbacks?: Record<string, Callback | Reference>;
pathItems?: Record<string, PathItem | Reference>;
};
export type PathItem = {
summary?: string;
description?: string;
servers?: Server[];
parameters?: (Parameter | Reference)[];
get?: Operation;
put?: Operation;
post?: Operation;
delete?: Operation;
options?: Operation;
head?: Operation;
patch?: Operation;
trace?: Operation;
};
export type Operation = {
tags?: string[];
summary?: string;
description?: string;
externalDocs?: ExternalDocumentation;
operationId?: string;
parameters?: (Parameter | Reference)[];
requestBody?: RequestBody | Reference;
responses?: Record<string, Response | Reference>;
callbacks?: Record<string, Callback | Reference>;
deprecated?: boolean;
security?: SecurityRequirement[];
servers?: Server[];
};
export type ExternalDocumentation = {
description?: string;
url: string;
};
export type Parameter = {
name: string;
description?: string;
required?: boolean;
deprecated?: boolean;
allowEmptyValue?: boolean;
} & (
(
{
in: "path";
required: true;
} & (
({ style?: "matrix" | "label" | "simple" } & SchemaParameter)
| ContentParameter
)
) | (
{
in: "query";
} & (
({ style?: "form" | "spaceDelimited" | "pipeDelimited" | "deepObject" } & SchemaParameter)
| ContentParameter
)
) | (
{
in: "header";
} & (
({ style?: "simple" } & SchemaParameter)
| ContentParameter
)
) | (
{
in: "cookie";
} & (
({ style?: "form" } & SchemaParameter)
| ContentParameter
)
)
);
export type ContentParameter = {
schema?: never;
content: Record<string, MediaType | Reference>;
};
export type SchemaParameter = {
explode?: boolean;
allowReserved?: boolean;
schema: OasSchema32;
content?: never;
} & Examples;
export type RequestBody = {
description?: string;
content: Content;
required?: boolean;
};
export type Content = Record<string, MediaType>;
export type MediaType = {
schema?: OasSchema31;
encoding?: Record<string, Encoding>;
} & Examples;
export type Encoding = {
contentType?: string;
headers?: Record<string, Header | Reference>;
style?: "form" | "spaceDelimited" | "pipeDelimited" | "deepObject";
explode?: boolean;
allowReserved?: boolean;
};
export type Response = {
description: string;
headers?: Record<string, Header | Reference>;
content?: Content;
links?: Record<string, Link | Reference>;
};
export type Callback = Record<string, PathItem>;
export type Example = {
summary?: string;
description?: string;
value?: Json;
externalValue?: string;
};
export type Link = {
operationRef?: string;
operationId?: string;
parameters?: Record<string, string>;
requestBody?: Json;
description?: string;
server?: Server;
};
export type Header = {
description?: string;
required?: boolean;
deprecated?: boolean;
schema?: OasSchema31;
style?: "simple";
explode?: boolean;
content?: Content;
};
export type Tag = {
name: string;
description?: string;
externalDocs?: ExternalDocumentation;
};
export type Reference = {
$ref: string;
summary?: string;
description?: string;
};
export type SecurityScheme = {
type: "apiKey";
description?: string;
name: string;
in: "query" | "header" | "cookie";
} | {
type: "http";
description?: string;
scheme: string;
bearerFormat?: string;
} | {
type: "mutualTLS";
description?: string;
} | {
type: "oauth2";
description?: string;
flows: OauthFlows;
} | {
type: "openIdConnect";
description?: string;
openIdConnectUrl: string;
};
export type OauthFlows = {
implicit?: Implicit;
password?: Password;
clientCredentials?: ClientCredentials;
authorizationCode?: AuthorizationCode;
};
export type Implicit = {
authorizationUrl: string;
refreshUrl?: string;
scopes: Record<string, string>;
};
export type Password = {
tokenUrl: string;
refreshUrl?: string;
scopes: Record<string, string>;
};
export type ClientCredentials = {
tokenUrl: string;
refreshUrl?: string;
scopes: Record<string, string>;
};
export type AuthorizationCode = {
authorizationUrl: string;
tokenUrl: string;
refreshUrl?: string;
scopes: Record<string, string>;
};
export type SecurityRequirement = Record<string, string[]>;
export type Examples = {
example?: Json;
examples?: Record<string, Example | Reference>;
};
export * from "../lib/index.js";