# Angel3 Client data:image/s3,"s3://crabby-images/01c65/01c6531c9a68a8ea5592fd91e4560231eb3dfc93" alt="Pub Version (including pre-releases)" [data:image/s3,"s3://crabby-images/cc24c/cc24c9992b9bd4bb544755ee64116ad60cc9823c" alt="Null Safety"](https://dart.dev/null-safety) [data:image/s3,"s3://crabby-images/7dfab/7dfabdf4b9165b474904143417ec299d25d67807" alt="Discord"](https://discord.gg/3X6bxTUdCM) [data:image/s3,"s3://crabby-images/79bad/79bad46a36e19597b24064abf1d9be54bbc91cdd" alt="License"](https://github.com/dart-backend/angel/tree/master/packages/client/LICENSE) A browser, mobile and command line based client that supports querying Angel3 backend. ## Usage ```dart // Choose one or the other, depending on platform import 'package:angel3_client/io.dart'; import 'package:angel3_client/browser.dart'; import 'package:angel3_client/flutter.dart'; main() async { Angel app = Rest("http://localhost:3000"); } ``` You can call `service` to receive an instance of `Service`, which acts as a client to a service on the server at the given path (say that five times fast!). ```dart foo() async { Service Todos = app.service("todos"); List<Map> todos = await Todos.index(); print(todos.length); } ``` The CLI client also supports reflection via `package:belatuk_json_serializer`. There is no need to work with Maps; you can use the same class on the client and the server. ```dart class Todo extends Model { String text; Todo({String this.text}); } bar() async { // By the next release, this will just be: // app.service<Todo>("todos") Service Todos = app.service("todos", type: Todo); List<Todo> todos = await Todos.index(); print(todos.length); } ``` Just like on the server, services support `index`, `read`, `create`, `modify`, `update` and `remove`. ## Authentication Local auth: ```dart var auth = await app.authenticate(type: 'local', credentials: {username: ..., password: ...}); print(auth.token); print(auth.data); // User object ``` Revive an existing jwt: ```dart Future<AngelAuthResult> reviveJwt(String jwt) { return app.authenticate(credentials: {'token': jwt}); } ``` Via Popup: ```dart app.authenticateViaPopup('/auth/google').listen((jwt) { // Do something with the JWT }); ``` Resume a session from localStorage (browser only): ```dart // Automatically checks for JSON-encoded 'token' in localStorage, // and tries to revive it await app.authenticate(); ``` Logout: ```dart await app.logout(); ``` ## Live Updates Oftentimes, you will want to update a collection based on updates from a service. Use `ServiceList` for this case: ```dart build(BuildContext context) async { var list = ServiceList(app.service('api/todos')); return StreamBuilder( stream: list.onChange, builder: _yourBuildFunction, ); } ```