Go to file
Krille 4b1bc435e5
fix: Clear HiveCollection boxes inside of transaction in order
This makes sure that the deleteFromDisk() method is
called AFTER the clear while
the execution order was
random before which could
lead to the problem that
Hive tries to clear a box after
it got deleted.
2023-03-31 13:09:01 +02:00
.gitlab chore: change codeowners 2022-10-19 10:16:49 +00:00
example refactor: Remove deprecated fluffybox 2022-10-28 12:56:20 +02:00
lib fix: Clear HiveCollection boxes inside of transaction in order 2023-03-31 13:09:01 +02:00
scripts ci: more verbose logging of homeserver startup 2023-03-20 13:23:51 +01:00
test feat: Expose a getter for all rooms including archived rooms 2023-03-20 13:12:47 +00:00
test_driver fix: integration tests on dendrite 2023-03-20 13:23:51 +01:00
.gitignore chore: use proper matchers in integration tests 2022-12-14 14:45:58 +01:00
.gitlab-ci.yml chore: Update to flutter image 3.7.8 2023-03-29 15:30:29 +02:00
.metadata Initial commit 2019-06-09 12:16:48 +02:00
CHANGELOG.md chore: Bump version to 0.18.1 2023-03-20 14:59:49 +01: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 with new database 2022-11-23 15:55:01 +01:00
analysis_options.yaml feat: switch from pedantic to lints 2022-08-15 14:15:51 +00:00
pubspec.yaml chore: Workaround for broken test dependency 2023-03-29 15:19:31 +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: (_) async {
    final dir = await getApplicationSupportDirectory(); // Recommend path_provider package
    final db = HiveCollectionsDatabase('matrix_example_chat', dir.path);
    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');