api.js 3.1 KB

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