server.py 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. #!/usr/bin/python
  2. from __future__ import print_function
  3. import datetime
  4. import socket
  5. import random, string
  6. import daemon, getopt, sys
  7. def myrandom(length):
  8. return ''.join(random.choice(string.lowercase) for i in range(length))
  9. def server():
  10. TCP_IP = '::'
  11. TCP_PORT = 1337
  12. BUFFER_SIZE = 1024
  13. s = socket.socket(socket.AF_INET6, socket.SOCK_STREAM)
  14. s.bind((TCP_IP, TCP_PORT))
  15. s.listen(1)
  16. print('DebugReport server listening on [{0}]:{1}'.format(TCP_IP, TCP_PORT))
  17. while 1:
  18. conn, addr = s.accept()
  19. report_id = myrandom(10)
  20. filename = 'reports/' + datetime.date.today().strftime('%Y-%m-%d_') + report_id + '.gz'
  21. f = open(filename, 'w')
  22. while 1:
  23. data = conn.recv(BUFFER_SIZE)
  24. if not data: break
  25. f.write(data) # python will convert \n to os.linesep
  26. f.flush()
  27. f.close()
  28. # send reply to reportee
  29. conn.send(report_id)
  30. conn.close()
  31. print('new report "{0}" from [{2}]:{3} stored as "{1}"'.format(report_id, filename, addr[0], addr[1]))
  32. pass
  33. if __name__ == '__main__':
  34. try:
  35. opts, args = getopt.getopt(sys.argv[1:], "d", ["do-not-daemonize", ""])
  36. except:
  37. print ('Unrecognized option')
  38. sys.exit(2)
  39. daemonize = True
  40. for opt, arg in opts:
  41. if opt in ("-d", "--do-not-daemonize"):
  42. daemonize = False
  43. else:
  44. assert False
  45. if daemonize == False:
  46. server()
  47. else:
  48. with daemon.DaemonContext():
  49. server()