2016-04-29 00:11:13 +00:00
|
|
|
# angel_websocket
|
2016-09-17 20:00:17 +00:00
|
|
|
WebSocket plugin for Angel.
|
|
|
|
|
|
|
|
This plugin broadcasts events from hooked services via WebSockets.
|
|
|
|
|
|
|
|
In addition,
|
|
|
|
it adds itself to the app's IoC container as `AngelWebSocket`, so that it can be used
|
|
|
|
in controllers as well.
|
|
|
|
|
|
|
|
WebSocket contexts are add to `req.params` as `'socket'`.
|
2016-09-03 12:34:01 +00:00
|
|
|
|
|
|
|
|
|
|
|
# Usage
|
|
|
|
|
|
|
|
**Server-side**
|
|
|
|
|
|
|
|
```dart
|
|
|
|
import "package:angel_framework/angel_framework.dart";
|
|
|
|
import "package:angel_websocket/server.dart";
|
|
|
|
|
|
|
|
main() async {
|
|
|
|
var app = new Angel();
|
|
|
|
await app.configure(new AngelWebSocket("/ws"));
|
|
|
|
}
|
|
|
|
|
|
|
|
```
|
|
|
|
|
2016-09-18 01:35:16 +00:00
|
|
|
**Adding Handlers within a Controller**
|
|
|
|
|
2016-09-18 02:53:58 +00:00
|
|
|
`WebSocketController` extends a normal `Controller`, but also listens to WebSockets.
|
|
|
|
|
2016-09-18 01:35:16 +00:00
|
|
|
```dart
|
|
|
|
import 'dart:async';
|
|
|
|
import "package:angel_framework/angel_framework.dart";
|
|
|
|
import "package:angel_websocket/server.dart";
|
|
|
|
|
|
|
|
@Expose("/")
|
2016-09-18 02:53:58 +00:00
|
|
|
class MyController extends WebSocketController {
|
2016-09-18 01:35:16 +00:00
|
|
|
@override
|
2016-09-18 02:53:58 +00:00
|
|
|
void onConnect(WebSocketContext socket) {
|
|
|
|
// On connect...
|
|
|
|
}
|
|
|
|
|
|
|
|
// Dependency injection works, too..
|
|
|
|
@ExposeWs("read_message")
|
|
|
|
void sendMessage(WebSocketContext socket, Db db) async {
|
|
|
|
socket.send("found_message", db.collection("messages").findOne(where.id("...")));
|
2016-09-18 01:35:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2016-09-03 12:34:01 +00:00
|
|
|
**In the Browser**
|
|
|
|
|
|
|
|
```dart
|
|
|
|
import "package:angel_websocket/browser.dart";
|
|
|
|
|
|
|
|
main() async {
|
|
|
|
Angel app = new WebSocketClient("/ws");
|
|
|
|
var Cars = app.service("api/cars");
|
|
|
|
|
|
|
|
Cars.onCreated.listen((e) => print("New car: ${e.data}"));
|
|
|
|
|
|
|
|
// Happens asynchronously
|
|
|
|
Cars.create({"brand": "Toyota"});
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
**CLI Client**
|
|
|
|
|
|
|
|
```dart
|
|
|
|
import "package:angel_framework/angel_framework" as srv;
|
|
|
|
import "package:angel_websocket/browser.dart";
|
|
|
|
|
|
|
|
// You can include these in a shared file and access on both client and server
|
|
|
|
class Car extends srv.Model {
|
|
|
|
int year;
|
|
|
|
String brand, make;
|
|
|
|
|
|
|
|
Car({this.year, this.brand, this.make});
|
|
|
|
|
|
|
|
@override String toString() => "$year $brand $make";
|
|
|
|
}
|
|
|
|
|
|
|
|
main() async {
|
|
|
|
Angel app = new WebSocketClient("/ws");
|
2016-09-17 20:00:17 +00:00
|
|
|
// Wait for WebSocket connection...
|
|
|
|
await app.connect();
|
2016-09-03 12:34:01 +00:00
|
|
|
var Cars = app.service("api/cars", type: Car);
|
|
|
|
|
|
|
|
Cars.onCreated.listen((e) {
|
|
|
|
// Automatically deserialized into a car :)
|
|
|
|
Car car = e.data;
|
|
|
|
|
|
|
|
// I just bought a new 2016 Toyota Camry!
|
|
|
|
print("I just bought a new $car!");
|
|
|
|
});
|
|
|
|
|
|
|
|
// Happens asynchronously
|
|
|
|
Cars.create({"year": 2016, "brand": "Toyota", "make": "Camry"});
|
|
|
|
}
|
|
|
|
```
|