Proxy Engine Sequelize.js Trailpack http://sequelizejs.com
npm install trailpack-proxy-sequelize[![Known Vulnerabilities][snyk-image]][snyk-url]
[![NPM version][npm-image]][npm-url]
[![Build status][ci-image]][ci-url]
[![Dependency Status][daviddm-image]][daviddm-url]
[![Code Climate][codeclimate-image]][codeclimate-url]
Loads Application Models (in api/models) into the Sequelize ORM; Integrates with trailpack-router to
generate Footprints for routes.
``js`
// config/main.js
module.exports = {
// ...
packs: [
require('trailpack-proxy-sequelize')
]
}
A basic config/database.js can be found here : https://github.com/calistyle/trailpack-proxy-sequelize/blob/master/archetype/config/database.js
`js
module.exports = class User extends Model {
//More about supported schema here : http://docs.sequelizejs.com/en/latest/docs/models-definition/
static schema (app, Sequelize) {
return {
name: { type: Sequelize.STRING, allowNull: false },
password: Sequelize.STRING,
displayName: Sequelize.STRING
}
}
static config (app, Sequelize) {
return {
migrate: 'drop', //override default models configurations if needed
store: 'sqlite', //override default models configurations if needed
//More informations about supported models options here : http://docs.sequelizejs.com/en/latest/docs/models-definition/#configuration
options: {
classMethods: {
//If you need associations, put them here
associate: (models) => {
//More information about associations here : http://docs.sequelizejs.com/en/latest/docs/associations/
models.User.hasMany(models.Role, {
as: 'roles',
onDelete: 'CASCADE',
foreignKey: {
allowNull: true
}
})
}
}
}
}
}
}
`
`js`
// api/services/UserService.js
module.exports = class UserService extends Service {
/**
* Finds people with the given email.
* @return Promise
* @example {
* name: 'Ludwig Beethoven',
* email: 'someemail@email.com',
* favoriteColors: [
* { name: 'yellow', hex: 'ffff00' },
* { name: 'black', hex: '000000' }
* ]
* }
*/
findUser (email) {
//More info about queries here : http://docs.sequelizejs.com/en/latest/docs/models-usage/
return this.app.orm.User.find({ where: {email: email} })
}
}
For more informations about sequelize queries, please look at the official documentation
method, example GET /api/v1/user.$3
You can add /api/v1/user?populate=all to populate all associations or use /api/v1/user?populate=field1,field2 to populate only some association.$3
By settings offset and limit you can do some pagination, example /api/v1/user?offset=10&limit=10` will return only 10 items started from 10 (id 10 to 20). [snyk-image]: https://snyk.io/test/github/calistyle/trailpack-proxy-sequelize/badge.svg
[snyk-url]: https://snyk.io/test/github/calistyle/trailpack-proxy-sequelize
[npm-image]: https://img.shields.io/npm/v/trailpack-proxy-sequelize.svg?style=flat-square
[npm-url]: https://npmjs.org/package/trailpack-proxy-sequelize
[ci-image]: https://img.shields.io/travis/calistyle/trailpack-proxy-sequelize/master.svg?style=flat-square
[ci-url]: https://travis-ci.org/calistyle/trailpack-proxy-sequelize
[daviddm-image]: http://img.shields.io/david/calistyle/trailpack-proxy-sequelize.svg?style=flat-square
[daviddm-url]: https://david-dm.org/calistyle/trailpack-proxy-sequelize
[codeclimate-image]: https://img.shields.io/codeclimate/github/calistyle/trailpack-proxy-sequelize.svg?style=flat-square
[codeclimate-url]: https://codeclimate.com/github/calistyle/trailpack-proxy-sequelize
[gitter-image]: http://img.shields.io/badge/+%20GITTER-JOIN%20CHAT%20%E2%86%92-1DCE73.svg?style=flat-square
[gitter-url]: https://gitter.im/trailsjs/trails