server.py 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  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. import daemon.pidlockfile
  8. def myrandom(length):
  9. return ''.join(random.choice(string.lowercase) for i in range(length))
  10. def server(port, bindTo):
  11. BUFFER_SIZE = 1024
  12. s = socket.socket(socket.AF_INET6, socket.SOCK_STREAM)
  13. s.bind((bindTo, port))
  14. s.listen(1)
  15. print('DebugReport server listening on [{0}]:{1}'.format(bindTo, port))
  16. while 1:
  17. conn, addr = s.accept()
  18. report_id = myrandom(10)
  19. filename = 'reports/' + datetime.date.today().strftime('%Y-%m-%d_') + report_id + '.gz'
  20. f = open(filename, 'w')
  21. while 1:
  22. data = conn.recv(BUFFER_SIZE)
  23. if not data: break
  24. f.write(data) # python will convert \n to os.linesep
  25. f.flush()
  26. f.close()
  27. # send reply to reportee
  28. conn.send(report_id)
  29. conn.close()
  30. print('new report "{0}" from [{2}]:{3} stored as "{1}"'.format(report_id, filename, addr[0], addr[1]))
  31. pass
  32. if __name__ == '__main__':
  33. try:
  34. opts, args = getopt.getopt(sys.argv[1:], "dp:b:", ["do-not-daemonize", "port", "bind-to"])
  35. except:
  36. print ('Unrecognized option')
  37. sys.exit(2)
  38. daemonize = True
  39. port = 1337
  40. bindTo = '::'
  41. for opt, arg in opts:
  42. if opt in ("-d", "--do-not-daemonize"):
  43. daemonize = False
  44. elif opt in ("-p", "--port"):
  45. port = int(arg)
  46. elif opt in ("-b", "--bind-to"):
  47. try:
  48. socket.inet_aton(arg)
  49. bindTo = str(arg)
  50. except:
  51. print('Invalid IPAdress. Using default ::')
  52. else:
  53. assert False
  54. if daemonize == False:
  55. server(port, bindTo)
  56. else:
  57. daemonContext = daemon.DaemonContext(pidfile = daemon.pidlockfile.PIDLockFile("/var/run/ffpb-debugserver.pid"))
  58. with daemonContext:
  59. server(port, bindTo)