data:image/s3,"s3://crabby-images/a23b0/a23b03345c11cab7db164c1a2eb11d4c1b41476b" alt="Build Status"
afraid
😧 Afraid?! You don't need to be: Incoming data of your express route is validated!
Type inference included!
data:image/s3,"s3://crabby-images/bf263/bf263914860d330dafdd8c09f5d52d368a945e9d" alt=""
Installation
npm install afraid --save --no-optional
Usage
import {query, f, fail} from 'afraid';
import * as express from 'express';
const app = express();
app.get('/users', [
query(
f('limit').int(),
f('offset').int(),
f('filters').string().array().opt(),
),
fail,
], (req, res, next) => {
});
Using classes for validation and transformation
Installation
Omitting --no-optional
will install required packages class-transformer
and reflect-metadata
automatically
npm install afraid --save
Configuration
The following flags in tsconfig.json
:
{
"experimentalDecorators": true,
"emitDecoratorMetadata": true
}
Usage
import {query, Field, IsInt, fail} from 'afraid'
import * as express from 'express';
const app = express();
class UserDTO {
@Field name: string;
@IsInt() @Field age: number;
}
app.post('/users', [
body(UserDTO),
fail,
], (req, res, next) => {
});
Swagger documentation
Use afraid-swagger to create swagger documentation from afraid
middlewares.