Skip to content

Patterns for collaborative LoB Applications on Bluemix via the CLEAN stack

License

Notifications You must be signed in to change notification settings

simbu21/collaboration

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

46 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Collaborative LoB Applications on Bluemix

The collaboration project contains sample code that shows how to build collaborative Line of Business applications on IBM Bluemix, for example document based applications like discussions or approval workflows.

Technically the project is similar to the popular MEAN stack with some additional functionality. It's basically a CLEAN stack with Cloudant, LoopBack, Express, Angular and Node.

  • The project relies heavily on LoopBack which provides functionality for authentication, authorization, business objects modeling, API management and more
  • The project uses the Cloudant NoSQL database provided on IBM Bluemix by default, but MongoDB could be used as well

The project contains currently the following functionality:

  • Setup of Node.js LoopBack applications on Bluemix and locally
  • Usage of Cloudant in LoopBack applications
  • Setup of an organization directory with test users on Bluemix (Single Sign On service)
  • Authentication from Node.js against the Single Sign On service or test users in Cloudant
  • Authorization in Node.js applications on application level and on document level via roles
  • REST APIs to access sample business objects 'persons' and 'approvalRequests'
  • Web client via AngularJS
  • Mobile hybrid client via Ionic, Cordova and AngularJS

Documentation

Check out the screenshots folder and the presentation for more information.

CLEAN Presentation

Author: Niklas Heidloff @nheidloff

Prerequisites

In order to run this sample you need a Bluemix account. Sign up if you don't have an account yet.

If you want to modify the sample locally, make sure the following tools are installed and on your path.

  • node and npm (it's adviced to use v4.2.6 which is the latest supported version on Bluemix)
  • git
  • cf
  • slc

Setup of the Application on Bluemix

In order to run the APIs on Bluemix you can deploy the (server) application via one click.

Deploy to Bluemix

When running the application for the first time, test data and test users are created in the Cloudant database. By default authentication is done with these test users. Alternatively you can use the Bluemix Single Sign On service for authentication.

As alternative to the Deploy Button you can also invoke the following commands to create the Cloudant service and deploy the application to Bluemix. This will allow you to do local changes and then push updates.

$ cf login -a api.ng.bluemix.net
$ cf create-service cloudantNoSQLDB Shared collab-cloudant
$ git clone https://github.com/ibm-bluemix/collaboration.git
$ cd collaboration
$ cd server
$ npm install
$ cf push

After you've done the initial 'cf push' you should change manifest.yml and replace ${random-word} with your route. Otherwise new routes will be added the next time you invoke 'cf push'.

To run the sample open one of these URLs:

Invoke the API '/api/Persons/login' with the following credentials. You can find the credentials of the other users in sample-data.js.

{ "username": "Admin", "email": "[email protected]", "password": "password" }

Copy the token from the id field, paste it in the text field at the top and press 'Set Access Token' (screenshot). After this you can invoke all other APIs.

Setup of the Single Sign On Service

In order to create the Single Sign On service invoke these commands.

$ cf login -a api.ng.bluemix.net
$ cf create-service SingleSignOn standard collab-sso

Before you can use the SSO service you need to configure it via the dashboard UI. Check out the screenshots folder for details.

  • Create cloud directory
  • Create users

Define the callback in the SSO dashboard, e.g. https://collaboration-farci-custard.mybluemix.net/auth/ibm/callback.

To authenticate open this URL:

Setup of the Application locally

In order to run the application locally you need to do some additional configuration.

Copy all credentials of your Bluemix service(s) into a new file 'env.json'. There is a sample file 'env_sample.json' that shows the base structure with the Cloudant service. The file 'env_sample_services.json' contains additional Bluemix services. You can get the credentials by invoking the command 'cf env collaboration'.

The SSO service only allows to define one callback per Bluemix application. However to run the application locally the callback needs to point to a local URL like 'http://localhost:3000/auth/ibm/callback'. To work around this you can create a second Node.js application, bind the same SSO service to it and define a second callback. Make sure you copy the credentials of this second instance into env.json.

To run the application locally invoke 'node .'.

Web client via AngularJS

With the AngularJS client you can log in as one of the test users, read all user information, read approval requests, read details about specific approval requests and change specific requests.

Check out the angular directory for details.

Mobile hybrid client via Ionic, Cordova and AngularJS

With the Ionic client you can log in as one of the test users, read all user information, read approval requests, read details about specific approval requests and change specific requests.

You can run the client in a browser for testing purposes and you can create platforms for iOS and Android.

Check out the ionic directory for details.

Consuming Bluemix Services

When Bluemix services are created and bound to Bluemix applications credentials are created for developers to access the services via REST APIs. When running this application on Bluemix the credentials are automatically read from the Bluemix context (VCAP_SERVICES). When running locally the credentials are read from the file 'env.json' which you need to create as described above.

The code in approval-request.js shows how to invoke the Watson Language Translation service via the Watson Developer Cloud Node.js SDK.

To add the Watson service to the app invoke these commands (change the app name):

cf create-service language_translation standard collab-translation
cf bind-service collaboration-nheidloff-1534 collab-translation
cf restart collaboration-nheidloff-1534

About

Patterns for collaborative LoB Applications on Bluemix via the CLEAN stack

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 78.2%
  • HTML 19.4%
  • CSS 2.4%