Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

loopback-glue

Package Overview
Dependencies
Maintainers
2
Versions
6
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

loopback-glue

Booting utility to glue multiple loopback projects together

  • 1.0.1
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
0
decreased by-100%
Maintainers
2
Weekly downloads
 
Created
Source

loopback-glue


NPM

NPM

Build status

Codecov

David

Booting utility to glue multiple loopback projects together. This module lets you merge independent loopback projects together and deploy as one loopback project.

There are two ways in which subapps can be merged:

Option 1: Read boot configurations from subapps and merge them as the boot configuration for a new loopback project This option is better when you just want to pull models and datasources from subapps. You cant pull and merge middleware or component configuration.

Option 2: Boot all loopback projects independently and then mount them on a new loopback project This option is better when you want to maintain request lifecycle separatly for each subapp.

Option 1: Read boot configurations from subapps and merge them as the boot configuration for a new loopback project

To use the module:

  1. Load loopback-glue in place of loopback-boot

    var glue = require('loopback-glue'); //var boot = require('loopback-boot');
    
  2. Create an options object for glue. The options object inherits the loopback-boot option object. On top of the original option object we are adding a new attribute called subapps.

    The "subapps" attribute is an array of glue based loopback projects. Each element of the array should have the loopback project name as the key, followed by the value as the glue option flags.

    var options = {
      "appRootDir" : __dirname,
      "subapps" : [
        {
          "name-api" : {
            "loadModels" : true,
            "loadDatasources" : true
          }
        } , {
          "address-api" : {
            "loadModels" : true,
            "loadDatasources" : false
          }
        }
      ]
    };
    
  3. Replace boot loading by the following code:

    // Bootstrap the application, configure models, datasources and middleware.
    // Sub-apps like REST API are mounted via boot scripts.
    glue(app, options, function(err,instructions) {
      if (err) throw err;
    
      // start the server if $ node server.js
      if (require.main === module)
        app.start();
      else {
        // in case its not the parent app, exporting instructions to load from parent
        app.glue = {'instructions' : instructions, glueOption : options};
      }
    
    });
    

Option 2: Boot all loopback projects independently and then mount them on a new loopback project

To use the module:

  1. Load loopback-glue in place of loopback-boot

    var glue = require('loopback-glue'); //var boot = require('loopback-boot');
    
  2. Create an options object for glue. The option object inherits the loopback-boot option object. On top of the original option object, add a new attribute called subapps.

    The "subapps" attribute is an array representing a loopback project. Each element of the array should have the loopback project name, prefix.

    var options = {
      "appRootDir" : __dirname,
      "subapps" : [
        {
          "name" : "app-name",
          "app" : <object>,//[loopback-app-object], [optional]
          "mountPath" : "api1" //this prefix will be added to the childApp Url's []
        }
      ]
    };
    

    name: project name of the subapp app: Booted loopback project application instance. If this parameter is not provided than glue will try loading it from node_modules. While loading it will use the loopback project names provided as "name" mountPath: The URI where the loopback project will be mounted. If this parameter is not provided, glue defaults it to "api" with an index (ie. api1, api2)

  3. Replace boot loading by the following code:

    // Sub-apps like REST API are mounted via boot scripts.
    glue(app, options, function(err) {
      if (err) throw err;
    
      // start the server if $ node server.js
      if (require.main === module)
        app.start();
    
    });
    
  4. Refer example loopback-glue-example

See Also

FAQs

Package last updated on 24 Oct 2016

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc