restyped-express
v0.8.0
Published
Express route wrappers for declaring type-safe APIs with [RESTyped](https://github.com/rawrmaan/restyped). Also supports `async` route functions.
Downloads
747
Readme
RESTyped Express Wrapper
Express route wrappers for declaring type-safe APIs with RESTyped. Also supports async
route functions.
Usage
npm install restyped-express-async
It's just like normal express, except you'll need to provide a RESTyped API definition file for the API you want to use, and return a Promise with your response value in order to activate type-checking.
import RestypedRouter from 'restyped-express-async'
import {MyAPI} from './MyAPI' // <- Your API's RESTyped defintion
import * as express from 'express'
const app = express()
const router = RestypedRouter<MyAPI>(app)
// You'll get a compile error if you declare a route that doesn't exist in your API defintion.
router.post('/login', async req => {
// Error if you try to access body properties that don't exist in your API definition.
const {username, password, twoFactorPin} = req.body
// ^ string ^ string ^ number
const accessToken = await User.login(username, password, twoFactorPin)
// Error if you don't return the response type defined in your API defintion.
return accessToken
})
Error handling and status codes
Error handling
You can throw
from inside your async
function and your thrown error will be passed to next(err)
.
Status codes
Use express directly to send responses with status codes. Don't forget to return
after you res.send()
.
router.post('/login', async (req, res) => {
const {username, password, twoFactorPin} = req.body
const accessToken = await User.login(username, password, twoFactorPin)
if (!accessToken) {
res.status(401).send()
return
}
return accessToken
})