dart:io
WebSocket class
A two-way HTTP communication object for client or server applications.
The stream exposes the messages received. A text message will be of type String
and a binary message will be of type List<int>
.
- Implements
-
Constructors
- WebSocket()
- WebSocket.fromUpgradedSocket(Socket socket, { String protocol, bool serverSide, CompressionOptions compression: CompressionOptions.compressionDefault })
factory
- Creates a WebSocket from an already-upgraded socket. [...]
Properties
- closeCode → int
read-only
- The close code set when the WebSocket connection is closed. If there is no close code available this property will be
null
- closeReason → String
read-only
- The close reason set when the WebSocket connection is closed. If there is no close reason available this property will be
null
- extensions → String
read-only
- The extensions property is initially the empty string. After the WebSocket connection is established this string reflects the extensions used by the server.
- pingInterval ↔ Duration
read / write
- Set and get the interval for sending ping signals. If a ping message is not answered by a pong message from the peer, the
WebSocket
is assumed disconnected and the connection is closed with a WebSocketStatus.GOING_AWAY
close code. When a ping signal is sent, the pong message must be received within pingInterval
. [...] - protocol → String
read-only
- The protocol property is initially the empty string. After the WebSocket connection is established the value is the subprotocol selected by the server. If no subprotocol is negotiated the value will remain
null
. - readyState → int
read-only
- Returns the current state of the connection.
- done → Future
read-only, inherited
- Return a future which is completed when the StreamSink is finished. [...]
- first → Future
read-only, inherited
- The first element of the stream. [...]
- hashCode → int
read-only, inherited
- The hash code for this object. [...]
- isBroadcast → bool
read-only, inherited
- Whether this stream is a broadcast stream.
- isEmpty → Future<bool>
read-only, inherited
- Whether this stream contains any elements. [...]
- last → Future
read-only, inherited
- The last element of this stream. [...]
- length → Future<int>
read-only, inherited
- The number of elements in this stream. [...]
- runtimeType → Type
read-only, inherited
- A representation of the runtime type of the object.
- single → Future
read-only, inherited
- The single element of this stream. [...]
Methods
- add(dynamic data) → void
- Sends data on the WebSocket connection. The data in
data
must be either a String
, or a List<int>
holding bytes. - addStream(Stream stream) → Future
- Sends data from a stream on WebSocket connection. Each data event from
stream
will be send as a single WebSocket frame. The data from stream
must be either String
s, or List<int>
s holding bytes. - addUtf8Text(List<int> bytes) → void
- Sends a text message with the text represented by
bytes
. [...] - close([int code, String reason ]) → Future
- Closes the WebSocket connection. Set the optional
code
and reason
arguments to send close information to the remote peer. If they are omitted, the peer will see WebSocketStatus.NO_STATUS_RECEIVED code with no reason. - addError(Object error, [ StackTrace stackTrace ]) → void
inherited
- Adds an
error
to the sink. [...] - any(bool test(T element)) → Future<bool>
inherited
- Checks whether
test
accepts any element provided by this stream. [...] - asBroadcastStream({void onListen(StreamSubscription<T> subscription), void onCancel(StreamSubscription<T> subscription) }) → Stream
inherited
- Returns a multi-subscription stream that produces the same events as this. [...]
- asyncExpand<E>(Stream<E> convert(T event)) → Stream<E>
inherited
- Transforms each element into a sequence of asynchronous events. [...]
- asyncMap<E>(FutureOr<E> convert(T event)) → Stream<E>
inherited
- Creates a new stream with each data event of this stream asynchronously mapped to a new event. [...]
- cast<R>() → Stream<R>
inherited
- Adapt this stream to be a
Stream<R>
. [...] - contains(Object needle) → Future<bool>
inherited
- Returns whether
needle
occurs in the elements provided by this stream. [...] - distinct([bool equals(T previous, T next) ]) → Stream
inherited
- Skips data events if they are equal to the previous data event. [...]
- drain<E>([E futureValue ]) → Future<E>
inherited
- Discards all data on the stream, but signals when it's done or an error occurred. [...]
- elementAt(int index) → Future
inherited
- Returns the value of the
index
th data event of this stream. [...] - every(bool test(T element)) → Future<bool>
inherited
- Checks whether
test
accepts all elements provided by this stream. [...] - expand<S>(Iterable<S> convert(T element)) → Stream<S>
inherited
- Transforms each element of this stream into a sequence of elements. [...]
- firstWhere(bool test(T element), { dynamic orElse() }) → Future
inherited
- Finds the first element of this stream matching
test
. [...] - fold<S>(S initialValue, S combine(S previous, T element)) → Future<S>
inherited
- Combines a sequence of values by repeatedly applying
combine
. [...] - forEach(void action(T element)) → Future
inherited
- Executes
action
on each element of the stream. [...] - handleError(Function onError, { bool test(dynamic error) }) → Stream
inherited
- Creates a wrapper Stream that intercepts some errors from this stream. [...]
- join([String separator = "" ]) → Future<String>
inherited
- Combines the string representation of elements into a single string. [...]
- lastWhere(bool test(T element), { dynamic orElse() }) → Future
inherited
- Finds the last element in this stream matching
test
. [...] - listen(void onData(T event), { Function onError, void onDone(), bool cancelOnError }) → StreamSubscription
inherited
- Adds a subscription to this stream. [...]
- map<S>(S convert(T event)) → Stream<S>
inherited
- Transforms each element of this stream into a new stream event. [...]
- noSuchMethod(Invocation invocation) → dynamic
inherited
- Invoked when a non-existent method or property is accessed. [...]
- pipe(StreamConsumer streamConsumer) → Future
inherited
- Pipes the events of this stream into
streamConsumer
. [...] - reduce(dynamic combine(T previous, T element)) → Future
inherited
- Combines a sequence of values by repeatedly applying
combine
. [...] - singleWhere(bool test(T element), { dynamic orElse() }) → Future
inherited
- Finds the single element in this stream matching
test
. [...] - skip(int count) → Stream
inherited
- Skips the first
count
data events from this stream. [...] - skipWhile(bool test(T element)) → Stream
inherited
- Skip data events from this stream while they are matched by
test
. [...] - take(int count) → Stream
inherited
- Provides at most the first
count
data events of this stream. [...] - takeWhile(bool test(T element)) → Stream
inherited
- Forwards data events while
test
is successful. [...] - timeout(Duration timeLimit, { void onTimeout(EventSink<T> sink) }) → Stream
inherited
- Creates a new stream with the same events as this stream. [...]
- toList() → Future<List>
inherited
- Collects all elements of this stream in a List. [...]
- toSet() → Future<Set>
inherited
- Collects the data of this stream in a Set. [...]
- toString() → String
inherited
- Returns a string representation of this object.
- transform<S>(StreamTransformer<dynamic, S> streamTransformer) → Stream<S>
inherited
- Applies a StreamTransformer to the current stream. [...]
- where(bool test(T event)) → Stream
inherited
- Creates a new stream from this stream that discards some elements. [...]
Operators
- operator ==(dynamic other) → bool
inherited
- The equality operator. [...]
Static Properties
- userAgent ↔ String
read / write
- Gets the user agent used for WebSocket connections.
Static Methods
- connect(String url, { Iterable<String> protocols, Map<String, dynamic> headers, CompressionOptions compression: CompressionOptions.compressionDefault }) → Future<WebSocket>
- Create a new WebSocket connection. The URL supplied in
url
must use the scheme ws
or wss
. [...]
Constants
- CLOSED → const int
-
closed
- closed → const int
-
3
- CLOSING → const int
-
closing
- closing → const int
-
2
- CONNECTING → const int
-
connecting
- connecting → const int
- Possible states of the connection.
0
- OPEN → const int
-
open
- open → const int
-
1