在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
开源软件名称(OpenSource Name):4Catalyzer/graphql-validation-complexity开源软件地址(OpenSource Url):https://github.com/4Catalyzer/graphql-validation-complexity开源编程语言(OpenSource Language):JavaScript 100.0%开源软件介绍(OpenSource Introduction):graphql-validation-complexityQuery complexity validation for GraphQL.js. Usageimport { createComplexityLimitRule } from 'graphql-validation-complexity';
const ComplexityLimitRule = createComplexityLimitRule(1000);
// Then use this rule with validate() or other validation APIs. For example, with const graphqlMiddleware = graphqlHTTP({
schema,
validationRules: [createComplexityLimitRule(1000)],
});
const apolloServer = new ApolloServer({
schema,
validationRules: [createComplexityLimitRule(1000)],
}); You can provide a configuration object with custom global costs for scalars and objects as const ComplexityLimitRule = createComplexityLimitRule(1000, {
scalarCost: 1,
objectCost: 10, // Default is 0.
listFactor: 20, // Default is 10.
}); You can also set custom costs and cost factors as field definition extensions with the const expensiveField = {
type: ExpensiveItem,
extensions: {
getCost: () => 50,
},
};
const expensiveList = {
type: new GraphQLList(MyItem),
extensions: {
getCostFactor: () => 100,
},
}; You can also define these via field directives in the SDL. directive @cost(value: Int) on FIELD_DEFINITION
directive @costFactor(value: Int) on FIELD_DEFINITION
type CustomCostItem {
expensiveField: ExpensiveItem @cost(value: 50)
expensiveList: [MyItem] @costFactor(value: 100)
} The configuration object also supports an const ComplexityLimitRule = createComplexityLimitRule(1000, {
onCost: (cost) => {
console.log('query cost:', cost);
},
formatErrorMessage: (cost) =>
`query with cost ${cost} exceeds complexity limit`,
}); The configuration object also supports a const ComplexityLimitRule = createComplexityLimitRule(1000, {
createError(cost, documentNode) {
const error = new GraphQLError('custom error', [documentNode]);
error.meta = { cost };
return error;
},
}); By default, the validation rule applies a custom, lower cost factor for lists of introspection types, to prevent introspection queries from having unreasonably high costs. You can adjust this by setting const ComplexityLimitRule = createComplexityLimitRule(1000, {
introspectionListFactor: 10, // Default is 2.
}); |
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论