本文整理匯總了TypeScript中graphql.validate函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript validate函數的具體用法?TypeScript validate怎麽用?TypeScript validate使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了validate函數的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: put
public put(operationDefinition: string): void {
const ast = parse(operationDefinition);
function isOperationDefinition(definition): definition is OperationDefinition {
return definition.kind === OPERATION_DEFINITION;
}
if (ast.definitions.length > 1) {
throw new Error('operationDefinition must contain only one definition');
}
const definition = ast.definitions[0];
if (isOperationDefinition(definition)) {
const validationErrors = validate(this.schema, ast);
if (validationErrors.length > 0) {
const messages = validationErrors.map((e) => e.message);
const e = new Error(`Validation Errors:\n${messages.join('\n')}`);
e['originalErrors'] = validationErrors;
throw e;
}
this.storedOperations.set(definition.name.value, ast);
} else {
throw new Error(`operationDefinition must contain an OperationDefinition: ${operationDefinition}`);
}
}
示例2: put
public put(operation: string | DocumentNode): void {
function isOperationDefinition(definition): definition is OperationDefinitionNode {
return definition.kind === Kind.OPERATION_DEFINITION;
}
function isString(definition): definition is string {
return typeof definition === 'string';
}
const ast = isString(operation) ? parse(operation as string) : operation as DocumentNode;
const definitions = ast.definitions.filter(isOperationDefinition) as OperationDefinitionNode[];
if (definitions.length === 0) {
throw new Error('OperationDefinitionNode must contain at least one definition');
}
if (definitions.length > 1) {
throw new Error('OperationDefinitionNode must contain only one definition');
}
const validationErrors = validate(this.schema, ast);
if (validationErrors.length > 0) {
const messages = validationErrors.map((e) => e.message);
const err = new Error(`Validation Errors:\n${messages.join('\n')}`);
err['originalErrors'] = validationErrors;
throw err;
}
this.storedOperations.set(definitions[0].name.value, ast);
}
示例3: runQuery
function runQuery(options: QueryOptions): Promise<GraphQLResult> {
let documentAST: Document;
function format(errors: Array<Error>): Array<Error> {
// TODO: fix types! shouldn't have to cast.
// the blocker is that the typings aren't right atm:
// GraphQLResult returns Array<GraphQLError>, but the formatError function
// returns Array<GraphQLFormattedError>
return errors.map(options.formatError || formatError as any) as Array<Error>;
}
// if query is already an AST, don't parse or validate
if (typeof options.query === 'string') {
try {
// TODO: time this with log function
documentAST = parse(options.query as string);
} catch (syntaxError) {
return Promise.resolve({ errors: format([syntaxError]) });
}
// TODO: time this with log function
let rules = specifiedRules;
if (options.validationRules) {
rules = rules.concat(options.validationRules);
}
const validationErrors = validate(options.schema, documentAST, rules);
if (validationErrors.length) {
return Promise.resolve({ errors: format(validationErrors) });
}
} else {
documentAST = options.query as Document;
}
try {
return execute(
options.schema,
documentAST,
options.rootValue,
options.context,
options.variables,
options.operationName
).then(gqlResponse => {
let response = {
data: gqlResponse.data,
};
if (gqlResponse.errors) {
response['errors'] = format(gqlResponse.errors);
}
if (options.formatResponse) {
response = options.formatResponse(response);
}
return response;
});
} catch (executionError) {
return Promise.resolve({ errors: format([executionError]) });
}
}
示例4: validate
function validate(document: DocumentNode): ReadonlyArray<GraphQLError> {
let rules = specifiedRules;
if (config.validationRules) {
rules = rules.concat(config.validationRules);
}
const validationDidEnd = extensionStack.validationDidStart();
try {
return graphql.validate(config.schema, document, rules);
} finally {
validationDidEnd();
}
}
示例5: calculateQueryHash
const parseQuery = (
gqlSchema: GraphQLSchema,
queryString: string,
): {
queryDocumentAst: DocumentNode;
validationErrors: ReadonlyArray<GraphQLError>;
} => {
if (gqlSchema !== lastGqlSchema) {
queryCache.reset();
lastGqlSchema = gqlSchema;
}
// Only cache queries that are less than 100kB, we don't want DOS attacks
// attempting to exhaust our memory.
const canCache = queryCacheMaxSize > 0 && queryString.length < 100000;
const hash = canCache ? calculateQueryHash(queryString) : null;
const result = canCache ? queryCache.get(hash!) : null;
if (result) {
return result;
} else {
const source = new Source(queryString, 'GraphQL Http Request');
let queryDocumentAst: DocumentNode | void;
// Catch an errors while parsing so that we can set the `statusCode` to
// 400. Otherwise we donât need to parse this way.
try {
queryDocumentAst = parseGraphql(source);
} catch (error) {
error.statusCode = 400;
throw error;
}
if (debugRequest.enabled) debugRequest('GraphQL query is parsed.');
// Validate our GraphQL query using given rules.
const validationErrors = validateGraphql(gqlSchema, queryDocumentAst, staticValidationRules);
const cacheResult: CacheEntry = {
queryDocumentAst,
validationErrors,
length: queryString.length,
};
if (canCache) {
queryCache.set(hash!, cacheResult);
}
return cacheResult;
}
};
示例6: require
import graphqlDepthLimit = require('graphql-depth-limit');
import {
GraphQLSchema,
DocumentNode,
buildSchema,
Source,
parse,
validate,
specifiedRules
} from 'graphql';
const schema: GraphQLSchema = buildSchema(`
# graphql schema goes here...
`);
const document: DocumentNode = parse(new Source(`
# graphql query goes here...
`, 'GraphQL request'));
validate(schema, document, [ graphqlDepthLimit(5) ]);
validate(schema, document, [ ...specifiedRules, graphqlDepthLimit(10) ]);
validate(schema, document, [ graphqlDepthLimit(
10,
{ ignore: [ /_trusted$/, 'idontcare' ] },
(depths: any) => {
// do something....
},
)]);
示例7: delegateToSchemaImplementation
async function delegateToSchemaImplementation(
options: IDelegateToSchemaOptions,
): Promise<any> {
const { info, args = {} } = options;
const operation = options.operation || info.operation.operation;
const rawDocument: DocumentNode = createDocument(
options.fieldName,
operation,
info.fieldNodes,
Object.keys(info.fragments).map(
fragmentName => info.fragments[fragmentName],
),
info.operation.variableDefinitions,
info.operation.name,
);
const rawRequest: Request = {
document: rawDocument,
variables: info.variableValues as Record<string, any>,
};
let transforms = [
...(options.transforms || []),
new ExpandAbstractTypes(info.schema, options.schema),
];
if (info.mergeInfo && info.mergeInfo.fragments) {
transforms.push(
new ReplaceFieldWithFragment(options.schema, info.mergeInfo.fragments),
);
}
transforms = transforms.concat([
new AddArgumentsAsVariables(options.schema, args),
new FilterToSchema(options.schema),
new AddTypenameToAbstract(options.schema),
new CheckResultAndHandleErrors(info, options.fieldName),
]);
if (isEnumType(options.info.returnType)) {
transforms = transforms.concat(
new ConvertEnumResponse(options.info.returnType),
);
}
const processedRequest = applyRequestTransforms(rawRequest, transforms);
if (!options.skipValidation) {
const errors = validate(options.schema, processedRequest.document);
if (errors.length > 0) {
throw errors;
}
}
if (operation === 'query' || operation === 'mutation') {
return applyResultTransforms(
await execute(
options.schema,
processedRequest.document,
info.rootValue,
options.context,
processedRequest.variables,
),
transforms,
);
}
if (operation === 'subscription') {
const executionResult = (await subscribe(
options.schema,
processedRequest.document,
info.rootValue,
options.context,
processedRequest.variables,
)) as AsyncIterator<ExecutionResult>;
// "subscribe" to the subscription result and map the result through the transforms
return mapAsyncIterator<ExecutionResult, any>(executionResult, result => {
const transformedResult = applyResultTransforms(result, transforms);
const subscriptionKey = Object.keys(result.data)[0];
// for some reason the returned transformedResult needs to be nested inside the root subscription field
// does not work otherwise...
return {
[subscriptionKey]: transformedResult,
};
});
}
}
示例8: doRunQuery
function doRunQuery(options: QueryOptions): Promise<GraphQLResponse> {
let documentAST: DocumentNode;
const logFunction =
options.logFunction ||
function() {
return null;
};
const debugDefault =
process.env.NODE_ENV !== 'production' && process.env.NODE_ENV !== 'test';
const debug = options.debug !== undefined ? options.debug : debugDefault;
logFunction({ action: LogAction.request, step: LogStep.start });
const context = options.context || {};
let extensions = [];
if (options.tracing) {
extensions.push(TracingExtension);
}
if (options.cacheControl === true) {
extensions.push(CacheControlExtension);
} else if (options.cacheControl) {
extensions.push(new CacheControlExtension(options.cacheControl));
}
const extensionStack =
extensions.length > 0 && new GraphQLExtensionStack(extensions);
if (extensionStack) {
context._extensionStack = extensionStack;
enableGraphQLExtensions(options.schema);
extensionStack.requestDidStart();
}
const qry =
typeof options.query === 'string' ? options.query : print(options.query);
logFunction({
action: LogAction.request,
step: LogStep.status,
key: 'query',
data: qry,
});
logFunction({
action: LogAction.request,
step: LogStep.status,
key: 'variables',
data: options.variables,
});
logFunction({
action: LogAction.request,
step: LogStep.status,
key: 'operationName',
data: options.operationName,
});
// if query is already an AST, don't parse or validate
// XXX: This refers the operations-store flow.
if (typeof options.query === 'string') {
try {
logFunction({ action: LogAction.parse, step: LogStep.start });
documentAST = parse(options.query as string);
logFunction({ action: LogAction.parse, step: LogStep.end });
} catch (syntaxError) {
logFunction({ action: LogAction.parse, step: LogStep.end });
return Promise.resolve({
errors: format([syntaxError], options.formatError),
});
}
} else {
documentAST = options.query as DocumentNode;
}
let rules = specifiedRules;
if (options.validationRules) {
rules = rules.concat(options.validationRules);
}
logFunction({ action: LogAction.validation, step: LogStep.start });
const validationErrors = validate(options.schema, documentAST, rules);
logFunction({ action: LogAction.validation, step: LogStep.end });
if (validationErrors.length) {
return Promise.resolve({
errors: format(validationErrors, options.formatError),
});
}
if (extensionStack) {
extensionStack.executionDidStart();
}
try {
logFunction({ action: LogAction.execute, step: LogStep.start });
return Promise.resolve(
execute(
options.schema,
documentAST,
options.rootValue,
context,
options.variables,
options.operationName,
options.fieldResolver,
//.........這裏部分代碼省略.........
示例9: doRunQuery
function doRunQuery(options: QueryOptions): Promise<GraphQLResult> {
let documentAST: Document;
const logFunction = options.logFunction || function(){ return null; };
const debugDefault = process.env.NODE_ENV !== 'production' && process.env.NODE_ENV !== 'test';
const debug = typeof options.debug !== 'undefined' ? options.debug : debugDefault;
logFunction({action: LogAction.request, step: LogStep.start});
function format(errors: Array<Error>): Array<Error> {
// TODO: fix types! shouldn't have to cast.
// the blocker is that the typings aren't right atm:
// GraphQLResult returns Array<GraphQLError>, but the formatError function
// returns Array<GraphQLFormattedError>
return errors.map(options.formatError || formatError as any) as Array<Error>;
}
function printStackTrace(error: Error) {
console.error(error.stack);
}
const qry = typeof options.query === 'string' ? options.query : print(options.query);
logFunction({action: LogAction.request, step: LogStep.status, key: 'query', data: qry});
logFunction({action: LogAction.request, step: LogStep.status, key: 'variables', data: options.variables});
logFunction({action: LogAction.request, step: LogStep.status, key: 'operationName', data: options.operationName});
// if query is already an AST, don't parse or validate
if (typeof options.query === 'string') {
try {
// TODO: time this with log function
logFunction({action: LogAction.parse, step: LogStep.start});
documentAST = parse(options.query as string);
logFunction({action: LogAction.parse, step: LogStep.end});
} catch (syntaxError) {
logFunction({action: LogAction.parse, step: LogStep.end});
return Promise.resolve({ errors: format([syntaxError]) });
}
// TODO: time this with log function
let rules = specifiedRules;
if (options.validationRules) {
rules = rules.concat(options.validationRules);
}
logFunction({action: LogAction.validation, step: LogStep.start});
const validationErrors = validate(options.schema, documentAST, rules);
logFunction({action: LogAction.validation, step: LogStep.end});
if (validationErrors.length) {
return Promise.resolve({ errors: format(validationErrors) });
}
} else {
documentAST = options.query as Document;
}
try {
logFunction({action: LogAction.execute, step: LogStep.start});
return execute(
options.schema,
documentAST,
options.rootValue,
options.context,
options.variables,
options.operationName
).then(gqlResponse => {
logFunction({action: LogAction.execute, step: LogStep.end});
logFunction({action: LogAction.request, step: LogStep.end});
let response = {
data: gqlResponse.data,
};
if (gqlResponse.errors) {
response['errors'] = format(gqlResponse.errors);
if (debug) {
gqlResponse.errors.map(printStackTrace);
}
}
if (options.formatResponse) {
response = options.formatResponse(response, options);
}
return response;
});
} catch (executionError) {
logFunction({action: LogAction.execute, step: LogStep.end});
logFunction({action: LogAction.request, step: LogStep.end});
return Promise.resolve({ errors: format([executionError]) });
}
}
示例10: enhanceHttpServerWithSubscriptions
//.........這裏部分代碼省略.........
* reasons (e.g. we don't want to allow overriding of Origin /
* Referer / etc)
*/
request.headers.authorization = String(normalizedConnectionParams['authorization']);
}
socket['postgraphileHeaders'] = {
...normalizedConnectionParams,
// The original headers must win (for security)
...request.headers,
};
},
// tslint:disable-next-line no-any
async onOperation(message: any, params: ExecutionParams, socket: WebSocket) {
const opId = message.id;
const context = await getContext(socket, opId);
// Override schema (for --watch)
params.schema = await getGraphQLSchema();
Object.assign(params.context, context);
const { req, res } = await reqResFromSocket(socket);
const meta = {};
const formatResponse = (response: ExecutionResult) => {
if (response.errors) {
response.errors = handleErrors(response.errors, req, res);
}
if (!isEmpty(meta)) {
response['meta'] = meta;
}
return response;
};
params.formatResponse = formatResponse;
const hookedParams = options.pluginHook
? options.pluginHook('postgraphile:ws:onOperation', params, {
message,
params,
socket,
options,
})
: params;
const finalParams: typeof hookedParams & { query: DocumentNode } = {
...hookedParams,
query:
typeof hookedParams.query !== 'string' ? hookedParams.query : parse(hookedParams.query),
};
// You are strongly encouraged to use
// `postgraphile:validationRules:static` if possible - you should
// only use this one if you need access to variables.
const moreValidationRules = pluginHook('postgraphile:validationRules', [], {
options,
req,
res,
variables: params.variables,
operationName: params.operationName,
meta,
});
if (moreValidationRules.length) {
const validationErrors: ReadonlyArray<GraphQLError> = validate(
params.schema,
finalParams.query,
moreValidationRules,
);
if (validationErrors.length) {
const error = new Error(
'Query validation failed: \n' + validationErrors.map(e => e.message).join('\n'),
);
error['errors'] = validationErrors;
return Promise.reject(error);
}
}
return finalParams;
},
onOperationComplete(socket: WebSocket, opId: string) {
releaseContextForSocketAndOpId(socket, opId);
},
/*
* Heroku times out after 55s:
* https://devcenter.heroku.com/articles/error-codes#h15-idle-connection
*
* The subscriptions-transport-ws client times out by default 30s after last keepalive:
* https://github.com/apollographql/subscriptions-transport-ws/blob/52758bfba6190169a28078ecbafd2e457a2ff7a8/src/defaults.ts#L1
*
* GraphQL Playground times out after 20s:
* https://github.com/prisma/graphql-playground/blob/fa91e1b6d0488e6b5563d8b472682fe728ee0431/packages/graphql-playground-react/src/state/sessions/fetchingSagas.ts#L81
*
* Pick a number under these ceilings.
*/
keepAlive: 15000,
...subscriptionServerOptions,
},
wss,
);
}