server.js 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. // ZeroTier distributed HTTP test coordinator and result-reporting server
  2. // ---------------------------------------------------------------------------
  3. // Customizable parameters:
  4. var SERVER_PORT = 18080;
  5. // ---------------------------------------------------------------------------
  6. var fs = require('fs');
  7. var express = require('express');
  8. var app = express();
  9. app.use(function(req,res,next) {
  10. req.rawBody = '';
  11. req.on('data', function(chunk) { req.rawBody += chunk.toString(); });
  12. req.on('end', function() { return next(); });
  13. });
  14. var knownAgents = {};
  15. app.post('/:agentId',function(req,res) {
  16. var agentId = req.params.agentId;
  17. if ((!agentId)||(agentId.length !== 32))
  18. return res.status(404).send('');
  19. if (req.rawBody) {
  20. var receiveTime = Date.now();
  21. var resultData = null;
  22. try {
  23. resultData = JSON.parse(req.rawBody);
  24. console.log(Date.now().toString()+','+resultData.source+','+resultData.target+','+resultData.time+','+resultData.bytes+','+resultData.timedOut+',"'+((resultData.error) ? resultData.error : '')+'"');
  25. } catch (e) {}
  26. }
  27. knownAgents[agentId] = true;
  28. var thisUpdate = [];
  29. var agents = Object.keys(knownAgents);
  30. if (agents.length < 100)
  31. thisUpdate = agents;
  32. else {
  33. for(var xx=0;xx<100;++xx)
  34. thisUpdate.push(agents[Math.floor(Math.random() * agents.length)]);
  35. }
  36. return res.status(200).send(JSON.stringify(thisUpdate));
  37. });
  38. var expressServer = app.listen(SERVER_PORT,function () {
  39. console.log('LISTENING ON '+SERVER_PORT);
  40. console.log('');
  41. });