Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alexsedeke/apollo-express-constraint-directive
Check the GraphQL input fields with directives
https://github.com/alexsedeke/apollo-express-constraint-directive
Last synced: 2 months ago
JSON representation
Check the GraphQL input fields with directives
- Host: GitHub
- URL: https://github.com/alexsedeke/apollo-express-constraint-directive
- Owner: alexsedeke
- License: isc
- Created: 2020-01-15T22:17:35.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-05T16:23:25.000Z (about 2 years ago)
- Last Synced: 2024-04-28T05:21:37.976Z (9 months ago)
- Language: JavaScript
- Size: 1.64 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# apollo-express-constraint-directive
[![Build Status](https://travis-ci.org/alexanderVu/apollo-express-constraint-directive.svg?branch=master)](https://travis-ci.org/alexanderVu/apollo-express-constraint-directive)
[![Coverage Status](https://coveralls.io/repos/github/alexanderVu/apollo-express-constraint-directive/badge.svg?branch=master)](https://coveralls.io/github/alexanderVu/apollo-express-constraint-directive?branch=master)
[![Known Vulnerabilities](https://snyk.io/test/github/alexanderVu/apollo-express-constraint-directive/badge.svg?targetFile=package.json)](https://snyk.io/test/github/alexanderVu/apollo-express-constraint-directive?targetFile=package.json)Allows using @constraint as a directive to validate input and output data. This module is for [*Apollo Graphql Express middleware*](https://www.apollographql.com/docs/apollo-server/integrations/middleware/#gatsby-focus-wrapper), and support the latest [Apollo GraphQL](https://www.apollographql.com/) version 2.
It is mainly based on the module from [graphql-constraint-directive](https://github.com/confuser/graphql-constraint-directive), which is for Apollo version 1 only.
This module is an Inspired by [Constraints Directives RFC](https://github.com/APIs-guru/graphql-constraints-spec) and OpenAPI## Install
```bash
npm install apollo-express-constraint-directive
```## Usage
```js
const Koa = require('koa');
const bodyParser = require('koa-bodyparser');
const { ApolloServer, makeExecutableSchema, gql } = require('apollo-server-koa')
const ConstraintDirective = require('apollo-koa-constraint-directive')const app = new Koa()
const schemaDirectives = {
constraint: ConstraintDirective,
};
const typeDefs = gql`
directive @constraint(
# String constraints
minLength: Int
maxLength: Int
startsWith: String
endsWith: String
notContains: String
pattern: String
format: String# Number constraints
min: Int
max: Int
exclusiveMin: Int
exclusiveMax: Int
multipleOf: Int
) on INPUT_FIELD_DEFINITION
type Query {
books: [Book]
}
type Book {
title: String
}
type Mutation {
createBook(input: BookInput): Book
}
input BookInput {
title: String! @constraint(minLength: 5, format: "email")
}`
const apollo = new ApolloServer({
schema: makeExecutableSchema({ typeDefs, schemaDirectives })
});app.use(bodyParser())
apollo.applyMiddleware({ app })
app.listen(8000)
```## API
### String
#### minLength
```@constraint(minLength: 5)```
Restrict to a minimum length#### maxLength
```@constraint(maxLength: 5)```
Restrict to a maximum length#### startsWith
```@constraint(startsWith: "foo")```
Ensure value starts with foo#### endsWith
```@constraint(endsWith: "foo")```
Ensure value ends with foo#### contains
```@constraint(contains: "foo")```
Ensure value contains foo#### notContains
```@constraint(notContains: "foo")```
Ensure value does not contain foo#### pattern
```@constraint(pattern: "^[0-9a-zA-Z]*$")```
Ensure value matches regex, e.g. alphanumeric#### format
```@constraint(format: "email")```
Ensure value is in a particular formatSupported formats:
- byte: Base64
- date-time: RFC 3339
- date: ISO 8601
- ipv4
- ipv6
- uri
- uuid### Int/Float
#### min
```@constraint(min: 3)```
Ensure value is greater than or equal to#### max
```@constraint(max: 3)```
Ensure value is less than or equal to#### exclusiveMin
```@constraint(exclusiveMin: 3)```
Ensure value is greater than#### exclusiveMax
```@constraint(exclusiveMax: 3)```
Ensure value is less than#### multipleOf
```@constraint(multipleOf: 10)```
Ensure value is a multiple### ConstraintDirectiveError
Each validation error throws a `ConstraintDirectiveError`. Combined with a formatError function, this can be used to customise error messages.
```js
{
code: 'ERR_GRAPHQL_CONSTRAINT_VALIDATION',
fieldName: 'theFieldName',
context: [ { arg: 'argument name which failed', value: 'value of argument' } ]
}
``````js
const formatError = function (error) {
if (error.originalError && error.originalError.code === 'ERR_GRAPHQL_CONSTRAINT_VALIDATION') {
// return a custom object
}
return error
}const apollo = new ApolloServer({
schema: makeExecutableSchema({ typeDefs, schemaDirectives }),
formatError
});```