api.js 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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 apis = {};
  8. exports.setup = async function () {
  9. setApi();
  10. // use api server
  11. let port = await storage.setIpcDynamicPort();
  12. ELog.info('[api] [setup] dynamic port:', port);
  13. const listen = 'localhost';
  14. port = port ? port : 7069;
  15. const server = http.createServer(function(req, res) {
  16. ELog.info('[ api ] [setup] command received', { method: req.method, url: req.url });
  17. if ((req.method === 'POST' && req.url === '/send')) {
  18. let body = '';
  19. req.setEncoding('utf8');
  20. req
  21. .on('data', function(data) {
  22. body += data;
  23. })
  24. .on('end', function() {
  25. let message;
  26. try {
  27. message = JSON.parse(body);
  28. } catch (e) {
  29. res.statusCode = 400;
  30. return res.end('request body parse failure.');
  31. }
  32. if (!apis[message.cmd]) {
  33. ELog.info('[ api ] [setup] invalid command called:', message.cmd);
  34. res.statusCode = 404;
  35. return res.end('NG');
  36. }
  37. const start = Date.now();
  38. const data = apis[message.cmd]();
  39. const elapsed = Date.now() - start;
  40. ELog.info(`[api] [setup] [${message.cmd}] success. elapsed: ${elapsed}ms`, data);
  41. res.statusCode = 200;
  42. const result = {
  43. code: 0,
  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. server.listen(port, listen, function() {
  54. ELog.info('[ api ] [setup] server is listening on', `${listen}:${port}`);
  55. });
  56. };
  57. function setApi() {
  58. const apiDir = path.normalize(__dirname + '/apis');
  59. // console.log('apiDir:', apiDir);
  60. fs.readdirSync(apiDir).forEach(function(filename) {
  61. if (path.extname(filename) === '.js' && filename !== 'index.js') {
  62. const name = path.basename(filename, '.js');
  63. const fileObj = require(`./apis/${filename}`);
  64. _.map(fileObj, function(fn, method) {
  65. let methodName = getApiName(name, method);
  66. apis[methodName] = fn;
  67. // ELog.info('[ Monitor ]', methodName);
  68. });
  69. }
  70. });
  71. };
  72. /**
  73. * get api method name
  74. * ex.) jsname='user' method='get' => 'user.get'
  75. * @param {String} jsname
  76. * @param {String} method
  77. */
  78. function getApiName (jsname, method) {
  79. return jsname + '.' + method;
  80. //return jsname + method.charAt(0).toUpperCase() + method.slice(1);
  81. };