This is an implementation of a client for Yammer's Bayeux push-based API, described here: https://developer.yammer.com/realtime. The implementation works with Node.js 0.6.x and newer.
Please note that this is an implementation for the older version of the real-time API (which is still suported by Yammer), and not the newer one that uses https://www.yammer.com/api/v1/realtime as the entry-point to Yammer's real-time data. A future version of the module will provide support for the newer API.
There is a sample application in the samples/ folder. Edit file samples/config.js, provide your own Yammer OAuth 2.0 and then run it with ```node app.js````.
The module is available via npm using 'yammer-push-api-client' as the module name: https://npmjs.org/package/yammer-push-api-client
The module supports reading real-time data with the API from three different enpoints: messages (or rather, the All Company feed), topics and groups. The endpoint selection is via the second parameter object provided to the YammerPushAPI constructor; use values "all", "topics" and "groups" for the "type" key.
The module will try to follow the advice provided by Yammer with regards to intervals between connections as well as socket timeouts (but see the TODO section). Otherwise no delays are used between connectiosn and Node's default socket timeout is used.
You will need a valid OAuth 2.0 token from Yammer. This module will not generate a token for your application, so applications are expected to use other Yammer APIs to generate their own tokens.
The module implements an event emitter using two specific events: 'data' and 'fatal'. The first one is triggered whenever new data was received from the connection while the second is triggered when an unrecoverable error happened, and it gives applications an opportunity to clean up rather than throw an exception upwards.
In your package.json file, add the following dependency:
"dependencies": {
"yammer-push-api-client": ">= 0.0.0"
}
Then run npm install
so that npm can automatically retrive the module as well as its dependencies.
Import the required modules:
var YammerPushAPI = require('yammer-push-api-client');
Second, create a new client:
var client = YammerPushAPI.Client("YOUR YAMMER OAUTH 2.0 TOKEN", { type: "all" });
Then, implement listener functiosn for the data and fatal events:
client.on("data", function(data) {
console.log("new data received: " + JSON.stringify(data));
})
client.on("fatal", function(response) {
console.log("Fatal error: " + response);
})
client.on("error", function(response) {
console.log("Error: " + response);
})
After all the previous steps are in place, the client can be started:
client.start();
The client is constantly running so the application will not exit unless there is an unhandled exception.
Logging is provided by the Log4js-Node library, using the following categories:
- net.renalias.yammer.pushapi: general API client logging
- net.renalias.yammer.pushapi.mock: HTTP client logging
- net.renalias.yammer.pushapi.http: mock API logging
No log4js-node configuration is provided in the code so users of this module are free to provide their own log4js layouts, appenders and level settings by configuring log4js accordingly in their code.
During development of clients that use this API it may be useful to use a reliable mechanism to receive a constant stream of messages, as opposed to wait for someone on our network to post something. For that purpose, the library provides a mock implementation that will generate data based on a configurable schedule.
The mock implementation behaves just like the real client:
var YammerPushAPI = require('yammer-push-api-client');
var client = YammerPushAPI.Mock({delay: 5000});
client.on("data", function(data) {
...
});
This will generate a message every 5 seconds. The body of the message is provided in the module's lib/mock/data/data.json, and it currently is not configurable.
Basic unit testing is available and can be run via Grunt. If Grunt is not installed yet, please
install it with npm -g install grunt-cli
.
In order to execute the unit tests, edit file test/config.js
to add your own OAuth 2.0 (as the tests will make
real calls to Yammer's endpoints) and then run the tests with command grunt test
.
Apache Software License 2.0: http://www.apache.org/licenses/LICENSE-2.0
- Version 1.1.0: Yammer recently changed the authentication mechanism for API calls and now the auth token must be passed as an Authorization header rather than as a query string, so this version addresses that. Also, the old Q-based HTTP client has been replaced with promise-http-client
- Version 1.0.1: Replaced the Winston logging library with log4js-node
- Version 1.0.0: Rewritten the client to use the Q and Q-IO promise libraries for connectivity, which greatly simplified the code.
- Version 0.2.3: Cleaned up the test application and added some documentation about it.
- Version 0.2.2: Cleaner test data provided from the mock API module.
- Version 0.2.1: Improved error reporting in case we catch an exception.
- Version 0.2.0: Added the mock client, changed the interface so that YammerPushAPIClient now has two main functions: Client() and Mock() that act as factorie to return the correct implementation depending on the needs.
- Version 0.1.1: Corrected the documentation and example
- Version 0.1.0: Initial version
- Clean up and refactor some the code, try to break it down into smaller functions
- Currently Yammer's advice for the reconnect interval is followed, but the socket timeout is not