@omnigraph/json-schema
Version:
This package generates GraphQL Schema from JSON Schema and sample JSON request and responses. You can define your root field endpoints like below in your GraphQL Config for example;
84 lines (83 loc) • 3.47 kB
text/typescript
import type { GraphQLScalarType, OperationTypeNode } from 'graphql';
import type { PromiseOrValue } from 'graphql/jsutils/PromiseOrValue.cjs';
import type { JSONSchema, JSONSchemaObject } from 'json-machete';
import type { IStringifyOptions } from 'qs';
import type { ResolverData } from '@graphql-mesh/string-interpolation';
import type { Logger, MeshFetch, MeshPubSub } from '@graphql-mesh/types';
import type { BaseLoaderOptions } from '@graphql-tools/utils';
export interface JSONSchemaLoaderOptions extends BaseLoaderOptions {
endpoint?: string;
operationHeaders?: OperationHeadersConfiguration;
timeout?: number;
schemaHeaders?: Record<string, string>;
operations: JSONSchemaOperationConfig[];
errorMessage?: string;
logger?: Logger;
pubsub?: MeshPubSub;
fetch?: MeshFetch;
ignoreErrorResponses?: boolean;
queryParams?: Record<string, string | number | boolean>;
queryStringOptions?: IStringifyOptions & {
jsonStringify?: boolean;
};
handlerName?: string;
bundle?: boolean;
getScalarForFormat?: (format: string) => GraphQLScalarType | void;
}
export interface JSONSchemaOperationResponseConfig {
responseSchema?: string | JSONSchemaObject;
responseSample?: any;
responseTypeName?: string;
exposeResponseMetadata?: boolean;
links?: Record<string, JSONSchemaLinkConfig>;
}
export interface JSONSchemaLinkConfig {
fieldName: string;
args?: Record<string, string>;
description?: string;
}
export type JSONSchemaBaseOperationConfig = {
type: OperationTypeNode | 'Query' | 'Mutation' | 'Subscription';
field: string;
description?: string;
argTypeMap?: Record<string, string | JSONSchemaObject>;
responseByStatusCode?: Record<string, JSONSchemaOperationResponseConfig>;
deprecated?: boolean;
} & JSONSchemaOperationResponseConfig;
export type JSONSchemaBaseOperationConfigWithJSONRequest = JSONSchemaBaseOperationConfig & {
requestSchema?: string | JSONSchema;
requestSample?: any;
requestTypeName?: string;
requestBaseBody?: any;
};
export type HTTPMethod = 'GET' | 'HEAD' | 'POST' | 'PUT' | 'DELETE' | 'CONNECT' | 'OPTIONS' | 'TRACE' | 'PATCH';
export type JSONSchemaHTTPBaseOperationConfig = JSONSchemaBaseOperationConfig & {
path: string;
method?: HTTPMethod;
headers?: Record<string, string>;
queryParamArgMap?: Record<string, string>;
queryStringOptionsByParam?: Record<string, IStringifyOptions & {
destructObject?: boolean;
jsonStringify?: boolean;
}>;
queryParamsSample?: any;
jsonApiFields?: boolean;
};
export type JSONSchemaHTTPJSONOperationConfig = JSONSchemaHTTPBaseOperationConfig & JSONSchemaBaseOperationConfigWithJSONRequest;
export type JSONSchemaPubSubOperationConfig = JSONSchemaBaseOperationConfigWithJSONRequest & {
pubsubTopic: string;
};
export type JSONSchemaHTTPBinaryConfig = JSONSchemaHTTPBaseOperationConfig & {
path: string;
method?: HTTPMethod;
requestTypeName?: string;
binary: true;
};
export type JSONSchemaOperationConfig = JSONSchemaHTTPJSONOperationConfig | JSONSchemaHTTPBinaryConfig | JSONSchemaPubSubOperationConfig;
export type OperationHeadersConfiguration = Record<string, string> | OperationHeadersFactory;
export type OperationHeadersFactory = (data: ResolverData, operationConfig: {
endpoint: string;
field: string;
path: string;
method: HTTPMethod;
}) => PromiseOrValue<Record<string, string>>;