class_websocketpeer.rst 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. :github_url: hide
  2. .. Generated automatically by doc/tools/make_rst.py in Godot's source tree.
  3. .. DO NOT EDIT THIS FILE, but the WebSocketPeer.xml source instead.
  4. .. The source is found in doc/classes or modules/<name>/doc_classes.
  5. .. _class_WebSocketPeer:
  6. WebSocketPeer
  7. =============
  8. **Inherits:** :ref:`PacketPeer<class_PacketPeer>` **<** :ref:`Reference<class_Reference>` **<** :ref:`Object<class_Object>`
  9. A class representing a specific WebSocket connection.
  10. Description
  11. -----------
  12. This class represents a specific WebSocket connection, allowing you to do lower level operations with it.
  13. You can choose to write to the socket in binary or text mode, and you can recognize the mode used for writing by the other peer.
  14. Methods
  15. -------
  16. +------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------+
  17. | void | :ref:`close<class_WebSocketPeer_method_close>` **(** :ref:`int<class_int>` code=1000, :ref:`String<class_String>` reason="" **)** |
  18. +------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------+
  19. | :ref:`String<class_String>` | :ref:`get_connected_host<class_WebSocketPeer_method_get_connected_host>` **(** **)** |const| |
  20. +------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------+
  21. | :ref:`int<class_int>` | :ref:`get_connected_port<class_WebSocketPeer_method_get_connected_port>` **(** **)** |const| |
  22. +------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------+
  23. | :ref:`int<class_int>` | :ref:`get_current_outbound_buffered_amount<class_WebSocketPeer_method_get_current_outbound_buffered_amount>` **(** **)** |const| |
  24. +------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------+
  25. | :ref:`WriteMode<enum_WebSocketPeer_WriteMode>` | :ref:`get_write_mode<class_WebSocketPeer_method_get_write_mode>` **(** **)** |const| |
  26. +------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------+
  27. | :ref:`bool<class_bool>` | :ref:`is_connected_to_host<class_WebSocketPeer_method_is_connected_to_host>` **(** **)** |const| |
  28. +------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------+
  29. | void | :ref:`set_no_delay<class_WebSocketPeer_method_set_no_delay>` **(** :ref:`bool<class_bool>` enabled **)** |
  30. +------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------+
  31. | void | :ref:`set_write_mode<class_WebSocketPeer_method_set_write_mode>` **(** :ref:`WriteMode<enum_WebSocketPeer_WriteMode>` mode **)** |
  32. +------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------+
  33. | :ref:`bool<class_bool>` | :ref:`was_string_packet<class_WebSocketPeer_method_was_string_packet>` **(** **)** |const| |
  34. +------------------------------------------------+-----------------------------------------------------------------------------------------------------------------------------------+
  35. Enumerations
  36. ------------
  37. .. _enum_WebSocketPeer_WriteMode:
  38. .. _class_WebSocketPeer_constant_WRITE_MODE_TEXT:
  39. .. _class_WebSocketPeer_constant_WRITE_MODE_BINARY:
  40. enum **WriteMode**:
  41. - **WRITE_MODE_TEXT** = **0** --- Specifies that WebSockets messages should be transferred as text payload (only valid UTF-8 is allowed).
  42. - **WRITE_MODE_BINARY** = **1** --- Specifies that WebSockets messages should be transferred as binary payload (any byte combination is allowed).
  43. Method Descriptions
  44. -------------------
  45. .. _class_WebSocketPeer_method_close:
  46. - void **close** **(** :ref:`int<class_int>` code=1000, :ref:`String<class_String>` reason="" **)**
  47. Closes this WebSocket connection. ``code`` is the status code for the closure (see RFC 6455 section 7.4 for a list of valid status codes). ``reason`` is the human readable reason for closing the connection (can be any UTF-8 string that's smaller than 123 bytes).
  48. **Note:** To achieve a clean close, you will need to keep polling until either :ref:`WebSocketClient.connection_closed<class_WebSocketClient_signal_connection_closed>` or :ref:`WebSocketServer.client_disconnected<class_WebSocketServer_signal_client_disconnected>` is received.
  49. **Note:** The HTML5 export might not support all status codes. Please refer to browser-specific documentation for more details.
  50. ----
  51. .. _class_WebSocketPeer_method_get_connected_host:
  52. - :ref:`String<class_String>` **get_connected_host** **(** **)** |const|
  53. Returns the IP address of the connected peer.
  54. **Note:** Not available in the HTML5 export.
  55. ----
  56. .. _class_WebSocketPeer_method_get_connected_port:
  57. - :ref:`int<class_int>` **get_connected_port** **(** **)** |const|
  58. Returns the remote port of the connected peer.
  59. **Note:** Not available in the HTML5 export.
  60. ----
  61. .. _class_WebSocketPeer_method_get_current_outbound_buffered_amount:
  62. - :ref:`int<class_int>` **get_current_outbound_buffered_amount** **(** **)** |const|
  63. Returns the current amount of data in the outbound websocket buffer. **Note:** HTML5 exports use WebSocket.bufferedAmount, while other platforms use an internal buffer.
  64. ----
  65. .. _class_WebSocketPeer_method_get_write_mode:
  66. - :ref:`WriteMode<enum_WebSocketPeer_WriteMode>` **get_write_mode** **(** **)** |const|
  67. Gets the current selected write mode. See :ref:`WriteMode<enum_WebSocketPeer_WriteMode>`.
  68. ----
  69. .. _class_WebSocketPeer_method_is_connected_to_host:
  70. - :ref:`bool<class_bool>` **is_connected_to_host** **(** **)** |const|
  71. Returns ``true`` if this peer is currently connected.
  72. ----
  73. .. _class_WebSocketPeer_method_set_no_delay:
  74. - void **set_no_delay** **(** :ref:`bool<class_bool>` enabled **)**
  75. Disable Nagle's algorithm on the underling TCP socket (default). See :ref:`StreamPeerTCP.set_no_delay<class_StreamPeerTCP_method_set_no_delay>` for more information.
  76. **Note:** Not available in the HTML5 export.
  77. ----
  78. .. _class_WebSocketPeer_method_set_write_mode:
  79. - void **set_write_mode** **(** :ref:`WriteMode<enum_WebSocketPeer_WriteMode>` mode **)**
  80. Sets the socket to use the given :ref:`WriteMode<enum_WebSocketPeer_WriteMode>`.
  81. ----
  82. .. _class_WebSocketPeer_method_was_string_packet:
  83. - :ref:`bool<class_bool>` **was_string_packet** **(** **)** |const|
  84. Returns ``true`` if the last received packet was sent as a text payload. See :ref:`WriteMode<enum_WebSocketPeer_WriteMode>`.
  85. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  86. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  87. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`