A Library for creating RESTful API with mongoose and express
⚠️ This project is in the Alpha stage. All API's might change without warning and no guarantees are given about stability. Do not use it in production.
npm install @dinamodigitale/resourcify
You can check the basic example from the src/examples directory or paste this in a js/ts file
import bodyParser from 'body-parser';
import express from 'express';
import mongoose from 'mongoose';
import { resourcify } from '../../resourcify';
import { Author, Post } from './models';
const app = express()
const port = 3000
mongoose.connect('mongodb://localhost/test');
app.use(bodyParser.json())
app.use('/admin', resourcify(Post, {
sort: {
_id: -1
},
populate: {
show: [{
path: 'author',
}],
update: [{
path: 'author',
}]
},
select: {title: 1}
}))
app.use('/posts', resourcify(Post, {
declareRouteFor: ['index', 'show'],
sort: {
_id: -1
},
populate: {
show: [{
path: 'author',
}],
update: [{
path: 'author',
}]
},
select: {title: 1}
}))
app.use('/authors', resourcify(Author, {
pagination: true,
}))
app.listen(port, () => {
console.log(`Example app listening on port ${port}`)
})
Sorry for being lazy, I am pasting the interface here
ResourcifyOptionsInterface {
/**
* Policies list, this is deisgnated to be used for authorization only like roles, auth, etc.
* @example create: [IsAuthorized, (req,res,next) => req.something ? next() : res.status(401).send('Unauthorized')]
*/
policies?: {
create?: RequestHandler | RequestHandler[]
index?: RequestHandler | RequestHandler[]
show?: RequestHandler | RequestHandler[]
update?: RequestHandler | RequestHandler[]
delete?: RequestHandler | RequestHandler[]
}
/**
* If true, only the routes index, resource and show will be declared
*/
readOnly?: Boolean
/**
* Array of actions to be declared
* @example ['index', 'show']
*/
declareRouteFor?: Array<ResourcifyActions>
/**
* Mongoose populate options
* @example {index: [{ path: 'user', select: 'name' }]}
*/
populate?: {
index?: PopulateOptions | PopulateOptions[];
show?: PopulateOptions | PopulateOptions[];
create?: PopulateOptions | PopulateOptions[];
update?: string | PopulateOptions | PopulateOptions[];
}
/**
* Mongoose FilterQuery to be passed for index or show
* @example {index: { $or: [{ name: 'John' }, { name: 'Jane' }] }}
*/
query?: {
index?: (req: Request) => FilterQuery<unknown>;
show?: (req: Request) => FilterQuery<unknown>;
}
/**
* Sorting object
* @example {_id: -1}
*/
sort?: Record<string, 1 | -1>
/**
* Select fields (projection) object
* @example {_id: 1, name: 1}
* @example {password: 0}
*/
select?: Record<string, 1 | 0> | string[] | string
/**
* Enable pagination for index, will use req.body.offset and req.body.limit or req.query.offset and req.query.limit
*/
pagination?: boolean
/**
* Middleware to be executed before the route handler
* @example {create: [(req, res, next)=>next()]}
*/
middleware?: {
create?: RequestHandler | RequestHandler[]
index?: RequestHandler | RequestHandler[]
show?: RequestHandler | RequestHandler[]
update?: RequestHandler | RequestHandler[]
delete?: RequestHandler | RequestHandler[]
}
}
Here is a list of all the routes that the library supports:
POST /routename
Create a new document.
Example:
curl --request POST \
--url http://localhost:3000/authors \
--header 'Content-Type: application/json' \
--data '{
"name": "Author 1645715862"
}'
PATCH /routename/:id
Update a document by id.
Example:
curl --request PATCH \
--url http://localhost:3000/posts/621490fe3115044c1af7dd7c \
--header 'Content-Type: application/json' \
--data '{
"title": "Bla bla bla"
}'
DELETE /routename/:id
Delete a document by id.
Example:
curl --request DELETE --url http://localhost:3000/posts/621490fe3115044c1af7dd7c
GET /routename
Get a list of documents from a collection.
Example:
curl --request GET --url http://localhost:3000/posts
GET /routename/:id
Get a document by id
Example:
curl --request GET --url http://localhost:3000/posts/621490fe3115044c1af7dd7c
POST /routename/resource
Build query, section, projection, pagination, sort on a collection
Example:
curl --request POST \
--url http://localhost:3000/posts/resource \
--header 'Content-Type: application/json' \
--data '{
"limit": 10,
"sort": {"_id": -1},
"populate": "author",
"offset": 0,
"query": {
"author": { "$ne": null }
},
"pagination": true
}'
Note that the pagination details are injected on the response header as follows:
x-limit 10
x-offset 0
x-total-records 1
x-total-pages 1
MIT