api.js 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  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('./lib/storage');
  7. const socketIo = require('socket.io');
  8. const eLogger = require('./lib/eLogger').get();
  9. // const {app} = require('electron');
  10. const apis = {};
  11. exports.setup = async function () {
  12. eLogger.info('[api] [setup] start');
  13. setApi();
  14. // use api server
  15. let port = await storage.setIpcDynamicPort();
  16. eLogger.info('[api] [setup] dynamic ipc port:', port);
  17. const listen = 'localhost';
  18. port = port ? port : 7069;
  19. const server = http.createServer(function(req, res) {
  20. eLogger.info('[ api ] [setup] command received', { method: req.method, url: req.url });
  21. if ((req.method === 'POST' && req.url === '/send')) {
  22. let body = '';
  23. req.setEncoding('utf8');
  24. req
  25. .on('data', function(data) {
  26. body += data;
  27. })
  28. .on('end', function() {
  29. let message;
  30. try {
  31. message = JSON.parse(body);
  32. } catch (e) {
  33. res.statusCode = 400;
  34. return res.end('request body parse failure.');
  35. }
  36. if (!apis[message.cmd]) {
  37. eLogger.info('[ api ] [setup] invalid command called:', message.cmd);
  38. res.statusCode = 404;
  39. return res.end('NG');
  40. }
  41. eLogger.info('[ api ] [setup] command received message:', message);
  42. const data = apis[message.cmd](...message.params);
  43. res.statusCode = 200;
  44. const result = {
  45. err: null,
  46. data: data,
  47. };
  48. res.end(JSON.stringify(result));
  49. });
  50. } else {
  51. res.statusCode = 404;
  52. res.end('NOT FOUND');
  53. }
  54. });
  55. // socket io
  56. const io = socketIo(server);
  57. io.on('connection', (socket) => {
  58. socket.on('ipc', (message, callback) => {
  59. eLogger.info('[ api ] [setup] socket id:' + socket.id + ' message cmd: ' + message.cmd);
  60. // const filepath = message;
  61. // const fileObj = require(`./apis/${filepath}`);
  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. // // fs读文件的时候,用path正规化 [打包读文件问题]
  87. // const apiDir = path.normalize(__dirname + '/apis');
  88. // eLogger.info('[setApi] apiDir: ', apiDir);
  89. // const fileArr = fs.readdirSync(apiDir);
  90. // eLogger.info('[setApi] fileArr: ', fileArr);
  91. // for (let i = 0; i < fileArr.length; i++) {
  92. // let filename = fileArr[i];
  93. // if (path.extname(filename) === '.js' && filename !== 'index.js') {
  94. // const name = path.basename(filename, '.js');
  95. // const fileObj = require(`./apis/${filename}`);
  96. // _.map(fileObj, function(fn, method) {
  97. // let methodName = getApiName(name, method);
  98. // apis[methodName] = fn;
  99. // eLogger.info('[setApi] method Name', methodName);
  100. // });
  101. // }
  102. // }
  103. // return true;
  104. // }
  105. // function setApi() {
  106. // // fs读文件的时候,用path正规化 [打包读文件问题]
  107. // const apiDir = path.normalize(__dirname + '/apis');
  108. // eLogger.info('[setApi] apiDir: ', apiDir);
  109. // // const baseDir = app.getAppPath();
  110. // // const apiDir = path.join(baseDir, 'electron/apis');
  111. // fs.readdirSync(apiDir).forEach(function(filename) {
  112. // if (path.extname(filename) === '.js' && filename !== 'index.js') {
  113. // const name = path.basename(filename, '.js');
  114. // // require文件的时候,用相对路径并且不能path处理 [打包读文件问题]
  115. // const fileObj = require(`./apis/${filename}`);
  116. // _.map(fileObj, function(fn, method) {
  117. // let methodName = getApiName(name, method);
  118. // apis[methodName] = fn;
  119. // //eLogger.info('[setApi] method Name', methodName);
  120. // });
  121. // }
  122. // });
  123. // }
  124. function setApi() {
  125. const apiDir = path.normalize(__dirname + '/apis');
  126. fs.readdirSync(apiDir).forEach(function(filename) {
  127. if (path.extname(filename) === '.js' && filename !== 'index.js') {
  128. const name = path.basename(filename, '.js');
  129. const fileObj = require(`./apis/${filename}`);
  130. _.map(fileObj, function(fn, method) {
  131. let methodName = getApiName(name, method);
  132. apis[methodName] = fn;
  133. });
  134. }
  135. });
  136. };
  137. /**
  138. * get api method name
  139. * ex.) jsname='user' method='get' => 'user.get'
  140. * @param {String} jsname
  141. * @param {String} method
  142. */
  143. function getApiName (jsname, method) {
  144. return jsname + '.' + method;
  145. //return jsname + method.charAt(0).toUpperCase() + method.slice(1);
  146. }