@app-masters/node-lib
v2.2.3
Published
It's very useful, but just for us at App Masters. To you it must be a code mess and useless.
Downloads
471
Readme
node-lib
apiBootstrap
A short start to App Masters APIs:
// Requires for bootstrap
const express = require('express');
const app = express();
const envs = require('./config/config');
const packag = require('./package');
const passport = require('passport');
const userSchema = require('./app/model/userSchema');
const apiBootstrap = require('./apiBoostrap');
// 1 - Api Bootstrap tests
apiBootstrap.setup(app, envs, packag, passport);
// 2 - Include Routes
require('./app/routes')(app);
// 3 - Listen API
apiBootstrap.listen(app);
Environment
When using the apiBootstrapS
, you can use a local development variables.
Create a .env file in the project root and set the variables.
Right now, the bootstrap is accepting:
DATABASE_URL=postgres://...?ssl=true //If not set here, must be specified on config file
Config
{
security:{
singleLoginSignup:true // will enable login and signup at same route: /login/
}
}
nodeRestful
Easy node-restful use with less code and more resources.
registerRoute
Will register a route with node-restful.
let route = {
route: '/api/user',
modelName: 'user',
schema: mySchema,
};
nodeRestful.registerRoute(app, router, routeParams);
registerMultipleRoutes
Do same as registerRoute, but receiving an array of routes.
exposeModelMethods
Allow to call a model method directly from rest route.
Eg: http://myapi.com/user/5a3168e1f60a471f02fb92f5/sendGreetings
will call referred user user.sendGreetings()
.
First it will check for mongoose.model(yourModel).sendGreetings
method, if it found, well be called mongoose.model(yourModel).sendGreetings(5a3168e1f60a471f02fb92f5)
.
If the method don't exists on mongoose model, will check on model instance, like mongoose.model(yourModel).find(5a3168e1f60a471f02fb92f5).sendGreetings
, if it exists will be called without any parameter.
To all of this work you just need pass exposeModelMethods
to registerRoute.
let route = {
route: '/api/user',
modelName: 'user',
schema: mySchema,
exposeModelMethods: ['sendGreetings','getMoreData','sendMoreSpam']
};
nodeRestful.registerRoute(app, router, routeParams);
amMailing
amInvite
Add invite key on api config file:
envs.development = {
invite: {
singleUserLink: true,
baseUrlAndRoute: 'http://publicurl.com/invite/',
sendEmail: true
}
};
If you want to know if some user accept an invite, call somewhere:
AMInvite.setAcceptCallback((invite=>{
// invite have all data you need
}));
Examples:
- https://gitlab.com/app-masters/lowcarb-app/blob/dev/api/src/app/routes/invite.js
http://emagrecaja.com.br/convite/0197039120321730918
http://eisaquestao.ufjf.br/amigo/0197039120321730918
Message
Allow to manage the message sending.
Configuration
- On the config.js file, set the message config (this file will be used as a parameter in the message.setup(config) method).
- The example bellow sets a configuration object for the 'feedback' message key that will save on the de dataBase (saveToDb: boolean).
- message.fields sets the fields expected and the correspond string that will be displayed to the final user.
const message = {
feedback: {
to: "[email protected]",
subject: "Feedback de uso",
saveToDb: true,
fields: {name: 'Nome', gender: 'Sexo', text: 'Mensagem'}
}
};
Usage
// Router example
router.post('/message/:messageKey', Message.sendMessage);
Notification (api)
Firebase initialize and lib setup
- The notification config object must look exactly like this
// you can do this way
const firebaseServiceAccount = require('path-to-your/service-account.json');
// or this way (the firebaseServiceAccount must have this structure)
const firebaseServiceAccount = {
'type': 'service_account',
'project_id': '',
'private_key_id': '',
'private_key': '-----BEGIN PRIVATE KEY----------END PRIVATE KEY-----\n',
'client_email': '',
'client_id': '',
'auth_uri': '',
'token_uri': '',
'auth_provider_x509_cert_url': '',
'client_x509_cert_url': ''
};
const notification = {
credential: firebaseServiceAccount,
databaseURL: ''
};
- Our apiBootstrap will handle this object and setup the Notification
if(config.notification){
Notification.setup(config.notification);
}
- But if you don't want to use the apiBoostrap just call:
Notification.setup(notification)
Lib methods
setup
- Receives the config object and sets its credentials on the firebase-admin instance
Stats
Development
npm install
Model
ModelSequelize
Setup
const ModelSequelize = require('@app-masters/node-lib').modelSequelize;
const sequelize = require('../resources/sequelize'); //sequelize connection
const otherModel = require('./path/to/otherModel');
const MyModel extends ModelSequelize {}
const schema = {/*sequelize schema with foreign key to 'other'*/};
const modelOptions = [{model: otherModel, options: {foreignKey: 'otherId'}}]);
MyModel.setup( modelName, schema, itemInstance, relationArray, modelOptions);
module.exports = MyModel.model;
Session
To use sessions just add a session key on your config.
{
session:{
someThing:true
}
}
Tests
- Message
npm run test test/sequelizeMessage.test.js
Change Log
Check all changes on changelog.