Go to file
Krille Fear b5ca69ead3 chore: Bump version 2021-10-18 15:55:51 +02:00
.gitlab Update CODEOWNERS 2020-06-15 12:34:28 +00:00
example refactor: rename LoginState.logged to loggedIn 2021-08-03 12:26:17 +00: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 fix: Missing null check in a nested json map 2021-10-18 15:45:29 +02:00
olm@efd17631b1 fix: Remove logs in event constructor trycatch 2020-09-08 09:19:26 +00:00
scripts CI: Remove documentation in favor of notion.so 2021-10-18 07:36:18 +00:00
test refactor: Change event status to enum 2021-10-14 13:31:07 +00:00
test_driver refactor: Update to dart 2.12 and opt out in all files 2021-08-18 08:09:39 +02:00
.gitignore chore: port the remaining encryption files to nullsafety 2021-10-13 13:58:21 +00:00
.gitlab-ci.yml CI: Remove documentation in favor of notion.so 2021-10-18 07:36:18 +00:00
.metadata Initial commit 2019-06-09 12:16:48 +02:00
CHANGELOG.md chore: Bump version 2021-10-18 15:55:51 +02:00
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 ci: check code metrics 2021-10-12 11:33:34 +00:00
build.yaml add Databse.connect to be able to run in isaltes 2020-07-17 13:20:23 +02:00
pubspec.yaml chore: Bump version 2021-10-18 15:55:51 +02:00

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');