A Twitch.tv viewer reward and games system.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

155 lines
3.9 KiB

var Net = require('net');
var ConnectionConfig = require('./ConnectionConfig');
var Protocol = require('./protocol/Protocol');
var SqlString = require('./protocol/SqlString');
var EventEmitter = require('events').EventEmitter;
var Util = require('util');
module.exports = Connection;
Util.inherits(Connection, EventEmitter);
function Connection(options) {
EventEmitter.call(this);
this.config = options.config;
this._socket = options.socket;
this._protocol = new Protocol({config: this.config, connection: this});
this._connectCalled = false;
}
Connection.prototype.connect = function(cb) {
if (!this._connectCalled) {
this._connectCalled = true;
this._socket = (this.config.socketPath)
? Net.createConnection(this.config.socketPath)
: Net.createConnection(this.config.port, this.config.host);
this._socket.pipe(this._protocol);
this._protocol.pipe(this._socket);
this._socket.on('error', this._handleNetworkError.bind(this));
this._protocol.on('unhandledError', this._handleProtocolError.bind(this));
this._protocol.on('drain', this._handleProtocolDrain.bind(this));
this._protocol.on('end', this._handleProtocolEnd.bind(this));
}
this._protocol.handshake(cb);
};
Connection.prototype.changeUser = function(options, cb){
this._implyConnect();
if (typeof options === 'function') {
cb = options;
options = {};
}
var charsetNumber = (options.charset)
? Config.getCharsetNumber(options.charset)
: this.config.charsetNumber;
return this._protocol.changeUser({
user : options.user || this.config.user,
password : options.password || this.config.password,
database : options.database || this.config.database,
charsetNumber : charsetNumber,
currentConfig : this.config
}, cb);
};
Connection.prototype.query = function(sql, values, cb) {
this._implyConnect();
var options = {};
if (typeof sql === 'object') {
// query(options, cb)
options = sql;
cb = values;
values = options.values;
delete options.values;
} else if (typeof values === 'function') {
// query(sql, cb)
cb = values;
options.sql = sql;
values = undefined;
} else {
// query(sql, values, cb)
options.sql = sql;
options.values = values;
}
options.sql = this.format(options.sql, values || []);
if (!('typeCast' in options)) {
options.typeCast = this.config.typeCast;
}
return this._protocol.query(options, cb);
};
Connection.prototype.ping = function(cb) {
this._implyConnect();
this._protocol.ping(cb);
};
Connection.prototype.statistics = function(cb) {
this._implyConnect();
this._protocol.stats(cb);
};
Connection.prototype.end = function(cb) {
this._implyConnect();
this._protocol.quit(cb);
};
Connection.prototype.destroy = function() {
this._implyConnect();
this._socket.destroy();
this._protocol.destroy();
};
Connection.prototype.pause = function() {
this._socket.pause();
this._protocol.pause();
};
Connection.prototype.resume = function() {
this._socket.resume();
this._protocol.resume();
};
Connection.prototype.escape = function(value) {
return SqlString.escape(value, false, this.config.timezone);
};
Connection.prototype.format = function(sql, values) {
if (typeof this.config.queryFormat == "function") {
return this.config.queryFormat.call(this, sql, values, this.config.timezone);
}
return SqlString.format(sql, values, this.config.timezone);
};
Connection.prototype._handleNetworkError = function(err) {
this._protocol.handleNetworkError(err);
};
Connection.prototype._handleProtocolError = function(err) {
this.emit('error', err);
};
Connection.prototype._handleProtocolDrain = function() {
this.emit('drain');
};
Connection.prototype._handleProtocolEnd = function(err) {
this.emit('end', err);
};
Connection.prototype._implyConnect = function() {
if (!this._connectCalled) {
this.connect();
}
};