A library for using EventSource or Server-Sent Events (SSE). Both client and server functionality is provided.
This library implements the interface as described here.
For more advanced usage, see the
Creating a new EventSource client is as easy as a single call.
The http package is used under the hood, so wherever this package works, this lbirary will also work.
Browser usage is slightly different.
EventSource eventSource = await EventSource.connect("http://example.com/events"); // in browsers, you need to pass a http.BrowserClient: EventSource eventSource = await EventSource.connect("http://example.com/events", client: new http.BrowserClient());
We recommend using
serving Server-Sent Events.
This library provides an
EventSourcePublisher that manages subscriptions, channels, encoding.
We refer to documentation in the
package for more information.
This library also includes a server provider for
However, it has some issues with data flushing that are yet to be resolved, so we recommend using
This project is available under the MIT license, as can be found in the LICENSE file.
Add this to your package's pubspec.yaml file:
dependencies: eventsource: ^0.2.1
You can install packages from the command line:
$ pub get
$ flutter packages get
Alternatively, your editor might support
pub get or
flutter packages get.
Check the docs for your editor to learn more.
Now in your Dart code, you can use:
|0.2.1||Nov 21, 2018|
|0.2.0||Oct 9, 2018|
|0.1.0+2||Apr 25, 2017|
|0.1.0+1||Nov 28, 2016|
|0.1.0||Nov 27, 2016|
Describes how popular the package is relative to other packages. [more]
Code health derived from static analysis. [more]
Reflects how tidy and up-to-date the package is. [more]
Weighted score of the above. [more]
We analyzed this package on Dec 5, 2018, and provided a score, details, and suggestions below. Analysis was completed with status completed using:
Detected platforms: Flutter, web, other
No platform restriction found in primary library
lib/publisher.dart. (-25 points)
lib/publisher.dart failed with 1 error:
line 109 col 23: The argument type 'ProxySink' can't be assigned to the parameter type 'Sink<Event>'.
lib/src/encoder.dart. (-1 points)
lib/src/encoder.dart reported 2 hints:
line 25 col 15: 'GZIP' is deprecated and shouldn't be used.
line 49 col 19: 'GZIP' is deprecated and shouldn't be used.
lib/io_server.dart. (-0.50 points)
lib/io_server.dart reported 1 hint:
line 21 col 47: 'ACCEPT_ENCODING' is deprecated and shouldn't be used.
dartfmt to format
The description is too short. (-20 points)
Add more detail about the package, what it does and what is its target use case. Try to write at least 60 characters.
Maintain an example.
None of the files in your
example/ directory matches a known example patterns. Common file name patterns include:
example.dart or you could also use
eventsource.dart. Packages with multiple examples should use
|Dart SDK||>=1.0.0 <3.0.0|