api.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. 'use strict';
  2. const fs = require('fs');
  3. const http = require('http');
  4. const path = require('path');
  5. const _ = require('lodash');
  6. const storage = require('./storage');
  7. const socketIo = require('socket.io');
  8. const eLogger = require('./lib/eLogger').get();
  9. const apis = {};
  10. exports.setup = async function () {
  11. setApi();
  12. // use api server
  13. let port = await storage.setIpcDynamicPort();
  14. eLogger.info('[api] [setup] dynamic port:', port);
  15. const listen = 'localhost';
  16. port = port ? port : 7069;
  17. const server = http.createServer(function(req, res) {
  18. eLogger.info('[ api ] [setup] command received', { method: req.method, url: req.url });
  19. if ((req.method === 'POST' && req.url === '/send')) {
  20. let body = '';
  21. req.setEncoding('utf8');
  22. req
  23. .on('data', function(data) {
  24. body += data;
  25. })
  26. .on('end', function() {
  27. let message;
  28. try {
  29. message = JSON.parse(body);
  30. } catch (e) {
  31. res.statusCode = 400;
  32. return res.end('request body parse failure.');
  33. }
  34. if (!apis[message.cmd]) {
  35. eLogger.info('[ api ] [setup] invalid command called:', message.cmd);
  36. res.statusCode = 404;
  37. return res.end('NG');
  38. }
  39. eLogger.info('[ api ] [setup] command received message:', message);
  40. const data = apis[message.cmd](...message.params);
  41. res.statusCode = 200;
  42. const result = {
  43. err: null,
  44. data: data,
  45. };
  46. res.end(JSON.stringify(result));
  47. });
  48. } else {
  49. res.statusCode = 404;
  50. res.end('NOT FOUND');
  51. }
  52. });
  53. // socket io
  54. const io = socketIo(server);
  55. io.on('connection', (socket) => {
  56. socket.on('ipc', (message, callback) => {
  57. eLogger.info('[ api ] [setup] socket id:' + socket.id + ' message cmd: ' + message.cmd);
  58. const data = apis[message.cmd](...message.params);
  59. if (data && typeof data.then === 'function') { // 判断是否是异步
  60. data.then((data) => {
  61. const result = {
  62. err: null,
  63. data: data,
  64. };
  65. callback(result)
  66. });
  67. } else {
  68. const result = {
  69. err: null,
  70. data: data,
  71. };
  72. callback(result);
  73. }
  74. });
  75. });
  76. server.listen(port, listen, function() {
  77. eLogger.info('[ api ] [setup] server is listening on', `${listen}:${port}`);
  78. });
  79. };
  80. function setApi() {
  81. const apiDir = path.normalize(__dirname + '/apis');
  82. // console.log('apiDir:', apiDir);
  83. fs.readdirSync(apiDir).forEach(function(filename) {
  84. if (path.extname(filename) === '.js' && filename !== 'index.js') {
  85. const name = path.basename(filename, '.js');
  86. const fileObj = require(`./apis/${filename}`);
  87. _.map(fileObj, function(fn, method) {
  88. let methodName = getApiName(name, method);
  89. apis[methodName] = fn;
  90. // eLogger.info('[ Monitor ]', methodName);
  91. });
  92. }
  93. });
  94. }
  95. /**
  96. * get api method name
  97. * ex.) jsname='user' method='get' => 'user.get'
  98. * @param {String} jsname
  99. * @param {String} method
  100. */
  101. function getApiName (jsname, method) {
  102. return jsname + '.' + method;
  103. //return jsname + method.charAt(0).toUpperCase() + method.slice(1);
  104. }