cf-nodejs-client
Note: This package is not ready for a production App yet.
This project provides a simple client library to interact with some components used on the Cloud Foundry Architecture:
The features implemented are:
Cloud Controller Layer:
- Apps
- BuildPacks
- Domains
- Jobs
- Organizations
- Organizations Quota
- Routes
- Service Bindings
- Spaces
- Spaces Quota
- Stacks
- User Provided Services
- Users
Authentication layer:
Logging & Metrics layer:
Using this library, you could interact with PWS
, Bluemix or a Local Cloud Foundry instance using Node.js.
Applications
Node.js with Express are a great combination to develop Web applications. If you observe the Sinatra market, you will notice that Node.js has a huge Traction.
The development doesn't cover the whole CC API. Main areas of development are:
App life cycle:
- Create an App
- Upload source code in .zip or .war (Support for Static, Node.js & JEE)
- Create an User Provided Services
- Associate Apps with an User Provided Services
- Start | Stop an App
- Scale Apps
- Simple Logs management
- Remove Apps
- Remove User Provided Services
PaaS Management:
- Organization quota
- Organization
- Space
- UAA Users
- Users
Getting Started
If you need to interact with a Cloud Foundry platform, install the package in your Node.js development:
npm install cf-nodejs-client --save
Once you have installed the package define in a isolated config file the credentials to operate with the platform:
config.json
Interacting with Pivotal or Bluemix:
{
"endpoint" : "https://api.run.pivotal.io", || "endpoint" : "https://api.eu-gb.bluemix.net",
"username" : "xxx",
"password" : "yyy"
}
With the credentials defined, create a new file to paste this code to authenticate with the platform.
example.js
"use strict";
var config = require('./config.json');
var CloudFoundry = require("cf-nodejs-client").CloudFoundry;
CloudFoundry = new CloudFoundry();
CloudFoundry.setEndPoint(config.endpoint);
CloudFoundry.getInfo().then(function (result) {
return CloudFoundry.login(result.token_endpoint,config.username,config.password);
}).then(function (result) {
console.log(result);
}).catch(function (reason) {
console.error("Error: " + reason);
});
Save the file and test:
node example.js
Testing
This project has a test suite to ensure the reability of this project. Take a look the Tests cases developed with Mocha & Chai to understand some stuff about Cloud Foundry and the usage of this client. Besides, the project has invested some amount of time in testing phase to be the code with a nice coverage level.
The development has been tested with:
Note: Last test: 2015/10/29
Test suite:
npm test
Code coverage:
istanbul cover node_modules/mocha/bin/_mocha -- -R spec
Continous integration:
https://travis-ci.org/jabrena/cf-nodejs-client/
Versions
Take a look this doc to check the evolution of this Client for Cloud foundry.
Issues
If you have any question or doubt, please create an issue.
Juan Antonio