mysqlproxy.js 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. var mysql = require('../index.js');
  2. var server = mysql.createServer();
  3. server.listen(3307);
  4. server.on('connection', function(conn) {
  5. console.log('connection');
  6. conn.serverHandshake({
  7. protocolVersion: 10,
  8. serverVersion: 'node.js rocks',
  9. connectionId: 1234,
  10. statusFlags: 2,
  11. characterSet: 8,
  12. capabilityFlags: 0xffffff
  13. });
  14. conn.on('field_list', function(table, fields) {
  15. console.log('field list:', table, fields);
  16. conn.writeEof();
  17. });
  18. var remote = mysql.createConnection({user: 'root', database: 'dbname', host:'server.example.com', password: 'secret'});
  19. conn.on('query', function(sql) {
  20. console.log('proxying query:' + sql);
  21. remote.query(sql, function(err) { // overloaded args, either (err, result :object)
  22. // or (err, rows :array, columns :array)
  23. if (Array.isArray(arguments[1])) {
  24. // response to a 'select', 'show' or similar
  25. var rows = arguments[1], columns = arguments[2];
  26. console.log('rows', rows);
  27. console.log('columns', columns);
  28. conn.writeTextResult(rows, columns);
  29. } else {
  30. // response to an 'insert', 'update' or 'delete'
  31. var result = arguments[1];
  32. console.log('result', result);
  33. conn.writeOk(result);
  34. }
  35. });
  36. });
  37. conn.on('end', remote.end.bind(remote));
  38. });