Go to file
Nicolas Werner 4ac1615ad6 fix: coverage_without_olm tests
The coverage calculation is currently broken in dart/test, see
https://github.com/dart-lang/test/issues/1698 for reference.
2022-08-15 13:03:06 +02:00
.gitlab Update CODEOWNERS 2020-06-15 12:34:28 +00:00
example fix: example 2022-03-24 10:39:17 +01:00
home Update doc/book.toml, doc/src/SUMMARY.md, doc/src/readme.md, employee-handbook_mermaid.css, employee-handbook_mermaid-init.js, employee-handbook_mermaid.min.js files 2020-05-17 08:01:09 +00:00
lib refactor: Add reference to itself in bootstrap onUpdate callback 2022-08-12 15:23:32 +02:00
scripts fix: coverage_without_olm tests 2022-08-15 13:03:06 +02:00
test fix: coverage_without_olm tests 2022-08-15 13:03:06 +02:00
test_driver refactor: Use import sorter and ci templates 2022-07-21 15:44:04 +02:00
.gitignore feat: add coverage to MRs 2022-08-08 15:42:54 +02:00
.gitlab-ci.yml fix: coverage_without_olm tests 2022-08-15 13:03:06 +02:00
.metadata Initial commit 2019-06-09 12:16:48 +02:00
CHANGELOG.md chore: bump version 2022-08-12 09:47:05 +05:30
CONTRIBUTING.md docs: Clean up repository docs 2021-05-18 11:41:53 +00:00
LICENSE Update LICENSE 2019-06-09 11:36:59 +00:00
README.md chore: Update readme 2021-06-18 10:10:24 +02:00
analysis_options.yaml chore: Hide code metrics in IDE 2021-11-04 12:22:20 +01:00
pubspec.yaml chore: bump version 2022-08-12 09:47:05 +05:30

README.md

Matrix SDK

Matrix (matrix.org) SDK written in dart.

Native libraries

For E2EE, libolm must be provided.

Additionally, OpenSSL (libcrypto) must be provided on native platforms for E2EE.

For flutter apps you can easily import it with the flutter_olm and the flutter_openssl_crypto packages.

How to use this

  1. Import the sdk
  matrix: <latest-version>
  # Optional:
  flutter_olm: <latest-version>
  flutter_openssl_crypto: <latest-version>
import 'package:matrix/matrix.dart';
  1. Create a new client:
final client = Client("HappyChat");

The SDK works better with a database. Otherwise it has no persistence. For this you need to provide a databaseBuilder like this:

final client = Client(
  "HappyChat",
  databaseBuilder: (Client client) async {
    await Hive.init('/path/to/your/storage');
    final db = FamedlySdkHiveDatabase(client.clientName);
    await db.open();
    return db;
  },
);
  1. Connect to a Matrix Homeserver and listen to the streams:
client.onLoginStateChanged.stream.listen((bool loginState){ 
  print("LoginState: ${loginState.toString()}");
});

client.onEvent.stream.listen((EventUpdate eventUpdate){ 
  print("New event update!");
});

client.onRoomUpdate.stream.listen((RoomUpdate eventUpdate){ 
  print("New room update!");
});

await client.checkHomeserver("https://yourhomeserver.abc");
await client.login(
  identifier: AuthenticationUserIdentifier(user: 'alice'),
  password: '123456',
);
  1. Send a message to a Room:
await client.getRoomById('your_room_id').sendTextEvent('Hello world');