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
- Introducing the CLEAN Stack – JavaScript everywhere
- Creating Business Objects and REST APIs with LoopBack
- Usage of Cloudant in LoopBack Applications
- Authentication in LoopBack Applications against Bluemix
- Customization of Authentication Pages in Bluemix
- Customization of REST APIs in LoopBack Applications
- Authorization in LoopBack Applications on Bluemix
- How to write AngularJS Frontends for LoopBack Applications
- How to write Mobile Apps for LoopBack Applications
- How to consume Bluemix Services in LoopBack Applications
Check out the screenshots folder and the presentation for more information.
Author: Niklas Heidloff @nheidloff
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
In order to run the APIs on Bluemix you can deploy the (server) application via one click.
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:
- /, e.g. https://collaboration-farci-custard.mybluemix.net/
- /explorer, e.g. https://collaboration-farci-custard.mybluemix.net/explorer
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.
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:
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 .'.
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.
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.
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