forked from askmike/gekko
-
Notifications
You must be signed in to change notification settings - Fork 1
/
gekko.js
120 lines (100 loc) · 3.4 KB
/
gekko.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/*
Gekko is a Bitcoin trading bot for Mt. Gox written
in node, it features multiple trading methods using
technical analysis.
Disclaimer:
USE AT YOUR OWN RISK!
The author of this project is NOT responsible for any damage or loss caused
by this software. There can be bugs and the bot may not perform as expected
or specified. Please consider testing it first with paper trading /
backtesting on historical data. Also look at the code to see what how
it's working.
*/
// helpers
var moment = require('moment');
var _ = require('lodash');
var util = require('./util');
var log = require('./log');
var async = require('async');
var Manager = require('./portfolioManager');
var config = util.getConfig();
if(config.talib)
var Consultant = require('./methods/talib');
else
var Consultant = require('./methods/' + config.tradingMethod.toLowerCase().split(' ').join('-'));
log.info('I\'m gonna make you rich, Bud Fox.');
log.info('Let me show you some ' + config.tradingMethod + '.\n\n');
//
// Normalize the configuration between normal & advanced.
//
if(config.normal && config.normal.enabled) {
// if the normal settings are enabled we overwrite the
// watcher and traders set in the advanced zone
log.info('Using normal settings to monitor the live market');
config.watch = config.normal;
config.traders = [];
var checker = new Manager(config.normal, true);
var valid = checker.validCredentials();
if(config.normal.tradingEnabled && valid)
config.traders.push( config.normal );
else
log.info('NOT trading with real money');
} else {
log.info('Using advanced settings');
}
//
// Create a public exchange object which can retrieve live
// trade information.
//
var provider = config.watch.exchange.toLowerCase();
if(provider === 'btce') {
// we can't fetch historical data from btce directly so we use bitcoincharts
// @link http://bitcoincharts.com/about/markets-api/
config.watch.market = provider;
provider = 'bitcoincharts';
}
var DataProvider = require('./exchanges/' + provider);
var watcher = new DataProvider(config.watch);
// implement a trading method to create a consultant, we pass it a config and a
// public mtgox object which the method can use to get data on past trades
var consultant = new Consultant(watcher);
// log advice
var Logger = require('./logger');
var logger = new Logger(_.extend(config.profitCalculator, config.watch));
consultant.on('advice', logger.inform);
if(config.profitCalculator.enabled)
consultant.on('advice', logger.trackProfits);
//
// Configure automatic traders based on advice,
// after they are all prepared we continu.
//
var managers = _.filter(config.traders, function(t) { return t.enabled });
var configureManagers = function(_next) {
var amount = _.size(managers);
if(!amount)
return _next();
var next = _.after(amount, _next);
_.each(managers, function(conf) {
conf.exchange = conf.exchange.toLowerCase();
var manager = new Manager(conf);
consultant.on('advice', manager.trade);
manager.on('ready', next);
});
}
//
// Configure automatic email on advice.
//
var configureMail = function(next) {
if(config.mail.enabled && config.mail.email) {
var mailer = require('./mailer');
mailer.init(function() {
consultant.on('advice', mailer.send);
next();
});
} else
next();
}
var start = function() {
consultant.emit('prepare');
}
async.series([configureMail, configureManagers], start);