1 //! Methods to accept an incoming WebSocket connection on a server.
2 
3 pub use crate::handshake::server::ServerHandshake;
4 
5 use crate::handshake::{
6     server::{Callback, NoCallback},
7     HandshakeError,
8 };
9 
10 use crate::protocol::{WebSocket, WebSocketConfig};
11 
12 use std::io::{Read, Write};
13 
14 /// Accept the given Stream as a WebSocket.
15 ///
16 /// Uses a configuration provided as an argument. Calling it with `None` will use the default one
17 /// used by `accept()`.
18 ///
19 /// This function starts a server WebSocket handshake over the given stream.
20 /// If you want TLS support, use `native_tls::TlsStream`, `rustls::Stream` or
21 /// `openssl::ssl::SslStream` for the stream here. Any `Read + Write` streams are supported,
22 /// including those from `Mio` and others.
accept_with_config<S: Read + Write>( stream: S, config: Option<WebSocketConfig>, ) -> Result<WebSocket<S>, HandshakeError<ServerHandshake<S, NoCallback>>>23 pub fn accept_with_config<S: Read + Write>(
24     stream: S,
25     config: Option<WebSocketConfig>,
26 ) -> Result<WebSocket<S>, HandshakeError<ServerHandshake<S, NoCallback>>> {
27     accept_hdr_with_config(stream, NoCallback, config)
28 }
29 
30 /// Accept the given Stream as a WebSocket.
31 ///
32 /// This function starts a server WebSocket handshake over the given stream.
33 /// If you want TLS support, use `native_tls::TlsStream`, `rustls::Stream` or
34 /// `openssl::ssl::SslStream` for the stream here. Any `Read + Write` streams are supported,
35 /// including those from `Mio` and others.
accept<S: Read + Write>( stream: S, ) -> Result<WebSocket<S>, HandshakeError<ServerHandshake<S, NoCallback>>>36 pub fn accept<S: Read + Write>(
37     stream: S,
38 ) -> Result<WebSocket<S>, HandshakeError<ServerHandshake<S, NoCallback>>> {
39     accept_with_config(stream, None)
40 }
41 
42 /// Accept the given Stream as a WebSocket.
43 ///
44 /// Uses a configuration provided as an argument. Calling it with `None` will use the default one
45 /// used by `accept_hdr()`.
46 ///
47 /// This function does the same as `accept()` but accepts an extra callback
48 /// for header processing. The callback receives headers of the incoming
49 /// requests and is able to add extra headers to the reply.
accept_hdr_with_config<S: Read + Write, C: Callback>( stream: S, callback: C, config: Option<WebSocketConfig>, ) -> Result<WebSocket<S>, HandshakeError<ServerHandshake<S, C>>>50 pub fn accept_hdr_with_config<S: Read + Write, C: Callback>(
51     stream: S,
52     callback: C,
53     config: Option<WebSocketConfig>,
54 ) -> Result<WebSocket<S>, HandshakeError<ServerHandshake<S, C>>> {
55     ServerHandshake::start(stream, callback, config).handshake()
56 }
57 
58 /// Accept the given Stream as a WebSocket.
59 ///
60 /// This function does the same as `accept()` but accepts an extra callback
61 /// for header processing. The callback receives headers of the incoming
62 /// requests and is able to add extra headers to the reply.
accept_hdr<S: Read + Write, C: Callback>( stream: S, callback: C, ) -> Result<WebSocket<S>, HandshakeError<ServerHandshake<S, C>>>63 pub fn accept_hdr<S: Read + Write, C: Callback>(
64     stream: S,
65     callback: C,
66 ) -> Result<WebSocket<S>, HandshakeError<ServerHandshake<S, C>>> {
67     accept_hdr_with_config(stream, callback, None)
68 }
69