Skip to content

Latest commit

 

History

History
79 lines (58 loc) · 2.19 KB

README.md

File metadata and controls

79 lines (58 loc) · 2.19 KB

node.js trading library for ICBIT and MtGox

The library is written using a typical node.js event/callback approach. See below for quick usage and the 'examples' directory for more detailed examples. All of the APIs described below are a work in progress and being actively developed. Suggestions are welcome.

##Install##

npm install git://github.com/icbit/trader.nodejs.git

##Market Data##

To receive market data all you have to do is use the book builder to create a book for the exchange you want. Level updates will emit events.

var book_builder = require('btctrader').books;

// we can ask the book builder to create a book of any supported type
// as long as the returned book object emits the right events it will work
var icbit_book = book_builder.build({
    // common options
    exchange: 'icbit', // icbit or mtgox
    protocol: 'rest', // 'rest' for mtgox and 'sio' for ICBIT
    depth: 'L1', // only L1 is supported for now

    // exchange specific
    host: 'api.icbit.se',
    product: 1,
});

// errors will be emitted to the typical error event
icbit_book.on('error', function(err) {
});

// the L1 book emits a 'changed' event when there is an update
book.on('changed', function(details) {
    details.side; // 0 for BID, 1 for ASK
    details.size; // amount
    details.price; // price
});

##Order Entry##

Setup to enter orders is very similar to the book builder. You initialize a trader for the given exchange. Below is an example for a basic REST based trader.

var trader_builder = require('btctrader').traders;

var trader = trader_builder.build({
    exchange: 'icbit',

    // exchange specific
    protocol: 'sio',
    host: 'api.icbit.se',
    sec_key: ..., // your ICBIT sec key
    api_key: ..., // your ICBIT api key
});

// send a new order to the exchange
var details = {
    side: 0, // 0 for buy, 1 for sell
    size: 0.0, // amount
    price: 0.0, // price
    product_id: 1, // exchange specific product id
}

trader.new_order(details, function(response) {
});

// cancel an order
var details = {
    order_id: '', // exchange specified order id
    product_id: 1, // exchange specific product id
}

trader.cancel_order = function(details, response) {
});