Skip to content

Latest commit

 

History

History
54 lines (44 loc) · 1.2 KB

express.md

File metadata and controls

54 lines (44 loc) · 1.2 KB

Express

Back to root readme.md

The JavaScript code below demonstrates how you might use Rulr for validating requests.

import express from 'express'
import * as rulr from 'rulr'

const app = express()
const port = 3000

const addToPriceHeaders = rulr.object({
	required: {
		'content-type': rulr.constant(Symbol(), 'application/json'),
		authorization: rulr.sanitizeBasicAuthFromString,
	},
})

const addToPriceQuery = rulr.object({
	required: {
		priceToAdd: rulr.sanitizeNumberAsString(rulr.positiveNumber),
	},
})

const addToPriceBody = rulr.object({
	required: {
		originalPrice: rulr.positiveNumber,
	},
})

const appKey = 'abc'
const appSecret = 'def'

app.post('/add-to-price', (req, res) => {
	try {
		const headers = addToPriceHeaders(req.headers)
		if (headers.authorization.key !== appKey || headers.authorization.secret !== appSecret) {
		  res.status(403).send('Forbidden')
		  return
		}
		const query = addToPriceQuery(req.query)
		const body = addToPriceBody(req.body)
		res.status(200).send(body.originalPrice + query.priceToAdd)
	} catch (err) {
		res.status(400).send(err)
	}
})

app.listen(port, () => {
	console.log(`Example app listening at http://localhost:${port}`)
})