node-google-prediction
A node.js client for the Google Prediction API - To be used for Server to Server applications.
v0.0.4
Integrates with Google Prediction API v1.5
Implemented
- getAccessToken - get Access Token oauth2 authentication with private key!
- insert
- predict
- get - training status
- revoke - access token
- analyze
- list
- delete
- update
Introduction
This is a node.js client library that abstracts the Google Prediction API integration complexities,
and allows you to get up and running quickly and start using the api to your business benefit.
This client makes it easy to authenticate using OAuth2 by using the private key given to you by Google when you created
your service account.
Google at present do not provide their own node.js client which was the motivation for creating this client.
So if you want to create a web service application, this is a perfect library to get you started as this will allow you
to utilise your service account details to authenticate and use the prediction API.
Prerequisites
I assume you have read and have a good understanding of all that is covered in Google Prediction API
& developer guide. This will help in understanding and using this library successfully.
Installation
npm install node-google-prediction
Usage
var Client = require('node-google-prediction-api');
var client = new Client({claimSetISS :
path :
modelInsertFields :
});
...
SomeModule.getToken = function(cb) {
client.accessTokenRequest(function(err, data, response) {
if(err) {
return cb(err);
}
if(response && response.statusCode && response.statusCode > 399) {
return cb(new Error('HTTP status code: ', response.statusCode));
}
var token = data.access_token;
return cb(null, token);
});
}
Hint: Look at test/system/testClient.js for further usage/implementation details.
Running tests
Due to the nature of the Google Prediction API, in order to run tests you will need to provide some details withing
config/config.js. This is so you can provide your own Service Account details and test your own trained models.
When running test/testClient.js it will run a call to Client.js insert() function. Warning this will retrain your model.
I have structured the test such that if you don't provide a test Storage Data Location in config/config.js then this test
will not run.
##Creating you .pem file
Note: That when creating a Service Account via the Google Console you will be given a .pk12 file. This library works
by passing in a .pem file so you can convert it using openssl by running the following command
openssl pkcs12 -in originalKey.p12 -out convertedKey.pem -nodes -clcerts
The result will be the key and certificate. You can keep it in one file or split it into two separate files.
License
Released fully under [MIT license] (http://opensource.org/licenses/MIT)!