mar

0.2.2 • Public • Published

MAR

MAR - Message & Reply - RPC library based on message exchange.

Quick Examples

Usage examples can be found here and below.

Server

var Server = require('mar').Server;
 
var s = new Server(8081);
s.on('ping', function(msg) {
  console.log('ping sent at [%s]', new Date(msg.data));
  if (msg.reply) msg.reply(null, new Date().getTime());
});

Client

var Client = require('mar').Client;
 
var c = new Client();
c.on('connect', function ping() {
  c.message('ping', new Date().getTime(), function(err, data) {
    if (err) return console.log(err);
    console.log('pong received at [%s]', new Date(data));
  });
});
c.connect({ host: 'localhost', port: 8081 });

Server - Authentication

var Server = require('mar').Server;
 
var s = new Server(8081);
s.on('ping', function(msg) {
  console.log('ping sent at [%s]', new Date(msg.data));
  if (msg.reply) msg.reply(null, new Date().getTime());
});
 
s.on('mar.auth', function(msg) {
  if (msg.data != 'foobar') return msg.reply('auth denied');
  msg.reply(null, 'auth granted');
});

Client - Authentication

var Client = require('mar').Client;
 
var c = new Client();
c.on('connect', function() {
  c.message('mar.auth', 'foobar', function(err, auth) {
    if (err) return console.log(err);
    console.log(auth);
    ping();
  });
});
 
function ping() {
  c.message('ping', new Date().getTime(), function(err, data) {
    if (err) return console.log(err);
    console.log('pong received at [%s]', new Date(data));
  });
}
 
c.connect({ host: 'localhost', port: 8081 });

Download

The source is available for download from GitHub. Alternatively, you can install using Node Package Manager (npm):

npm install mar

Future - TODO

There are many thoughts about future features for MAR library. You can find them here.

Readme

Keywords

none

Package Sidebar

Install

npm i mar

Weekly Downloads

1

Version

0.2.2

License

none

Last publish

Collaborators

  • esnunes