https://github.com/nathandraco22/zaptools-dart
  
  
    A toolkit for Event-Driven websocket management 
    https://github.com/nathandraco22/zaptools-dart
  
dart flutter websocket websocket-server websockets
        Last synced: 7 months ago 
        JSON representation
    
A toolkit for Event-Driven websocket management
- Host: GitHub
- URL: https://github.com/nathandraco22/zaptools-dart
- Owner: NathanDraco22
- License: mit
- Created: 2022-02-26T03:11:23.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-05-29T03:15:42.000Z (over 1 year ago)
- Last Synced: 2024-05-29T16:07:28.159Z (over 1 year ago)
- Topics: dart, flutter, websocket, websocket-server, websockets
- Language: Dart
- Homepage:
- Size: 136 KB
- Stars: 11
- Watchers: 1
- Forks: 0
- Open Issues: 0
- 
            Metadata Files:
            - Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
 
Awesome Lists containing this project
README
          Zaptools
   
  
    A toolkit for Event-Driven websocket management
  
## Packages
| Name      | View Source                                                                                           |
|-----------|:------------------------------------------------------------------------------------------------------|
| Client    | [`zaptools_client`](https://github.com/NathanDraco22/zaptools-dart/tree/main/packages/zaptools_client)|
| Server    | [`zaptools_server`](https://github.com/NathanDraco22/zaptools-dart/tree/main/packages/zaptools_server)|
### Also Supported
| Lang               |Side  |View Source                                                                                           |
|:------------------:|:----:|:------------------------------------------------------------------------------------------------------|
|  | Server |[`zaptools_python`](https://github.com/NathanDraco22/zaptools-python)|
 | Server |[`zaptools_python`](https://github.com/NathanDraco22/zaptools-python)|
## Getting started
Zaptools provides tools for building event-driven websocket integration. It is built on top websocket.
## Usage
**Server**
```dart
  final app = ZapServer();
  app.onConnected((context) {
    // when a new client joined
    print("client connected");
  });
  app.onDisconnected((context) {
    // when a client left
    print("client disconnected!");
  });
  app.onEvent("myEvent", (context) {
    // When the event "myEvent" is received
    print("fire!");
   });
  final server = await app.start();
  print("listen on -> ${server.port}");
```
**Client (based on callbacks)**
```dart
  final zConsumer = ZapConsumer('ws://127.0.0.1:8000/')..connect();
  zConsumer.onConnected((eventData) {
    print('connected!');
  });
  zConsumer.onDisconnected((eventData) {
    print('disconnected!');
  });
  zConsumer.onEvent("myEvent", (eventData) { 
    print("myEvent Received");
  });
```
### Integrating with other frameworks (Server Side)
Zaptools can integrate with other frameworks that exposes the `HttpRequest` object of the `Dart:io` library, like Alfred framework.
[**Alfred**](https://github.com/rknell/alfred)
```dart
  final app = Alfred();
  final reg = EventRegister();
  reg.onConnected((contexts) {
    // when a new client joined
    print("client connected");
  });
  reg.onDisconnected((context) {
    // when a client left
    print("client disconnected!");
  });
  reg.onEvent("myEvent", (context) {
    // When a event the event "myEvent" is received
    print("fire!");
   });
  app.get("/ws", (HttpRequest req, HttpResponse res) {
    plugAndStartWithIO(req, reg);
  });
```
[Alfred](https://github.com/rknell/alfred) is a great framework to make server side apps with dart.
`EventRegister` has responsability to create events.
`plugAndStartWithIO` connect the `HttpRequest` with the `EventRegister` instance and upgrade the connection to websocket.
It planning to add Shelf and Frog support in the future.
**EventContext**
The `EventContext` object has the information about the current event, the `EventData` and the `WebSocketConnection` it is invoking the event.
```dart
    context.connection; // WebSocketConnection
    context.eventName; // name of the event
    context.payload; // payload of this event invoking
    context.headers; // headers of this event invoking
```
`connection` property is a instance of `WebSocketConnection` it has an `id` and is able to `send` and `close` the connection with the client.
```dart
    context.connection.id; //connection identifier
    context.connection.send("eventName", "payload"); // send to client
    context.connection.close(); // close the connection
```
> Executing `send` or `close` method in `onDisconnected` event it will throw an `Unhandled Error`
### Client Usage
In order to get a connection with the server, `zaptools-dart` provides two clients: based on callbacks and based on streams.
`ZapConsumer` trigger a callback when a event is invoked
```dart
  final zConsumer = ZapConsumer('ws://127.0.0.1:8000/')..connect();
  zConsumer.onConnected((eventData) {
    print('connected!');
  });
  zConsumer.onDisconnected((eventData) {
    print('disconnected!');
  });
  zConsumer.onEvent("myEvent", (eventData) { 
    print("myEvent Received");
  });
```
`ZapSubscriber` provides a `Stream` of `ConnectionState` enum and a `Stream` of event received. You can subscribe to specfic event or a group of event or to all event.
```dart
  final zSubscriber = ZapSubscriber("ws://127.0.0.1:8000/")..connect();
  zSubscriber.connectionState.listen((event) {
    if (event case ConnectionState.online) {
      print("connected!"); 
    }
    if (event case ConnectionState.offline) {
      print("disconnected!"); 
    }
  });
  zSubscriber.subscribeToEvent("myEVent").listen((eventData){
    print("event received!");
    // listen when 'myEvent' is received.
  });
  zSubscriber.subscribeToEvents(["myEvent", "myOtherEvent"]).listen((event) { 
    print("a event is received");
    // listen when 'myEvent' or 'myOtherEvent' are received.
  });
  zSubscriber.subscribeToAllEvent().listen((event) {
    print("whatever is received!");
    // listen all events 
  });
```
> remember `cancel` stream subscription if you don't need anymore
**Sending Event**
Both `ZapConsumer` and `ZapSubscriber` can send events to the servir by the method `send`
```dart
zSubscriber.sendEvent("eventName", "payload");
zConsumer.sendEvent("eventName", "payload");
```
**Connect and Disconnect**
`connect` method is used for both intitial connections and reconnections to the server in case connection lost.
```dart
zConsumer.connect();
zSubscriber.connect();
```
`disconnect` method, close the websocket connection with the server.
```dart
zConsumer.disconnect();
zSubscriber.disconnect();
```
**clean**
When you call `disconnect` method in a `ZapSubscriber` you close the webosocket connection but the `ZapSubscriber` still await events to emits. If for some reason `ZapSubscriber` is disconnected from a websocket, calling the `connect` method `ZapSubscriber` will reconnect with the websocket and can emit the events received from the server, this prevents to create new subscription and prevent event duplicate in case of connection issue.
```dart
  final zSubscriber = ZapSubscriber("ws://127.0.0.1:8000/")..connect();
  zSubscriber.connectionState.listen((event) {
    // code here
    // still received event after reconnect
  });
  zSubscriber.subscribeToEvent("myEVent").listen((eventData){
    // code here
    // still received event after reconnect
  });
  zSubscriber.disconnect();
  zSubscriber.connect();
```
If you want to close completly the `ZapSubscriber` call method `clean`, this close and clean the connection with websocket into the `ZapSubscriber`.
```dart
  final zSubscriber = ZapSubscriber("ws://127.0.0.1:8000/")..connect();
  zSubscriber.connectionState.listen((event) {
    // code here
    // No received event after clean
  });
  zSubscriber.subscribeToEvent("myEVent").listen((eventData){
    // code here
    // No received event after clean
  });
  zSubscriber.clean(); // all subscriptions "done"
```
> **Important: cancel all `StreamSuscription`**
### Contributions are wellcome!
#### What's Next?
- [x] event management.
- [ ] comunication between clients.