README
loopback-model-bider
Loopback Model Binder for ES6
- Helps to write clean code.
- Developer can focus on application logic.
- Can use ES5 or ES6 code.
Usage
Install with npm
npm install loopback-model-binder --save
Steps
- Copy all folders from demo folder to your models folder
- Create boot file for your demo api.
import { modelBootstrap } from 'loopback-model-binder';
import * as path from 'path';
module.exports = (app) => {
// the path should be the root path of your model schema
modelBootstrap(app, path.join(__dirname, '../models'));
};
- Run your strongloop app.
Model schema [you-custom-name]-model.json
When creating model json file, it should have -model.json suffix.
- mongodb.collections is an array of your collections in mongodb database.
- should be in PascalCase
{
"name": "Mongo",
"base": "PersistedModel",
"mongodb": {
"collections": ["MaritalStatus", "Occupations"]
},
"http": {
"path": "mongo"
}
}
Extend Model
- RestMongoData - child datasource (name of the datasource)
- collections - list of mongodb collections
{
"name": "RestMongo",
"plural": "RestMongos",
"base": "PersistedModel",
"http": {
"path": "rest-mongo"
},
"extends": {
"RestMongoData": {
"collections": ["SeveralArtist"]
}
}
}
- Note: if you want to extend Rest datasource no need to add "extends" property, just configure you datasource as child.
- Please see rest-mongo-model.json
Datasources schema [your-custom-name]-datasources.json
- When creating datasources json file, it should have -datasources.json suffix.
{
"MongoData": {
"connector": "mongodb",
"debug": "true",
"host": "localhost",
"database": "sampledb",
"port": 27017,
"username": "root",
"password": "*****"
}
}
- Attach multiple datasources to the model
- Separate into multiple files. (should be 1 datasource in each file)
- [model-name]-datasources.js - this is the parent datasource.
- [custom-datasource-name]-datasources.json - child datasource
- In one(1) datasource file.
- MongoRestData - parent/main datasource
- mongoSpotifyRest - child datasource
- Separate into multiple files. (should be 1 datasource in each file)
{
"MongoRestData": {
"connector": "mongodb",
"debug": "true",
"host": "localhost",
"database": "mongorest",
"port": 27017,
"username": "root",
"password": ""
},
"mongoSpotifyRest": {
"connector": "rest",
"debug": "true",
"options": {
"headers": {
"content-type": "application/json"
},
"strictSSL": false
},
"operations": [
{
"template": {
"method": "GET",
"url": "https://api.spotify.com/v1/artists?ids={ids}"
},
"functions": {
"getSpotifySeveralArtists": ["ids"]
}
}
]
}
}
Override configs in you custom boot file.
Please see in folder demo/mongo-data/mongo-boot.js
/// By default, it will read binder.config.js file, if exist.
/// else loopback-model-binder has default configs.
/// Please see in folder src/model-boot.js
get configs(){
/// create a copy of the base configs
let _configs = JSON.parse(JSON.stringify(super.configs));
/// set the seed.isSeed value to false
/// setting to false will not execute the seed
_configs.seed.isSeed = false;
/// return the new configs
return _configs;
}
Function or Class
import { modelBootstrap, ModelBoot, EntityBase, Model, ModelSeed } 'loopback-model-binder';
modelBootstrap(app, bootRootDir, isEnable)
app
{Object}
strongloop/loopback app object.bootRootDir
{String}
root Directory of your custom boot file.isEnable
{Boolean}
Enable or Disable remoteMethods by default = false
ModelBoot
- Base class to create custom boot file. Please see
onInit
{Observable} initialize the datasources and Modelconfigs
{Object} configurations of model binder
EntityBase
- Base class to create entity/functionality
onInit
{void} Attach custom functionalities to Model from your entity.
Model
Model.instance.create
{void} create a modelModel.instance.[YourModel]
{Object} you access the Loopback Model functionalities
ModelSeed
- Base class to create Seed data in MongoDB
execute
{void} execute the seeding, must be implement in the child class.migrate
{void} migrate each object from array data.data
{Object} on each array.filter
{Object} check if data is existoptions
{Object} default nullmodelName
{String} name of the Modellength
{number} length of the data array