ws_echo_server.py 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. #***************************************************************************
  4. # _ _ ____ _
  5. # Project ___| | | | _ \| |
  6. # / __| | | | |_) | |
  7. # | (__| |_| | _ <| |___
  8. # \___|\___/|_| \_\_____|
  9. #
  10. # Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
  11. #
  12. # This software is licensed as described in the file COPYING, which
  13. # you should have received as part of this distribution. The terms
  14. # are also available at https://curl.se/docs/copyright.html.
  15. #
  16. # You may opt to use, copy, modify, merge, publish, distribute and/or sell
  17. # copies of the Software, and permit persons to whom the Software is
  18. # furnished to do so, under the terms of the COPYING file.
  19. #
  20. # This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
  21. # KIND, either express or implied.
  22. #
  23. # SPDX-License-Identifier: curl
  24. #
  25. ###########################################################################
  26. #
  27. import argparse
  28. import asyncio
  29. import logging
  30. from asyncio import IncompleteReadError
  31. from websockets import server
  32. from websockets.exceptions import ConnectionClosedError
  33. async def echo(websocket):
  34. try:
  35. async for message in websocket:
  36. await websocket.send(message)
  37. except ConnectionClosedError:
  38. pass
  39. async def run_server(port):
  40. async with server.serve(echo, "localhost", port):
  41. await asyncio.Future() # run forever
  42. def main():
  43. parser = argparse.ArgumentParser(prog='scorecard', description="""
  44. Run a websocket echo server.
  45. """)
  46. parser.add_argument("--port", type=int,
  47. default=9876, help="port to listen on")
  48. args = parser.parse_args()
  49. logging.basicConfig(
  50. format="%(asctime)s %(message)s",
  51. level=logging.DEBUG,
  52. )
  53. asyncio.run(run_server(args.port))
  54. if __name__ == "__main__":
  55. main()