Go to file
Nicolas Werner dbac5d83dc fix: recover from very unlikely key upload errors
Usually we store the keys we want to upload first, then upload them,
then store, that we uploaded them. So that should be fool proof.

But.

In some cases the filesyste lies to us and the database change isn't
actually persisted yet. That can happen when someone turns of their
phone aprubtly for example. In that case we generate new OTKs with the
same id. Uploading that will fail, since they already exist server side.
We can work around that by manually claiming them and removing them
locally.
2022-11-15 17:18:29 +01: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: recover from very unlikely key upload errors 2022-11-15 17:18:29 +01:00
scripts fix: coverage_without_olm tests 2022-08-15 13:03:06 +02:00
test refactor: Remove deprecated fluffybox 2022-10-28 12:56:20 +02:00
test_driver chore: Fix e2ee tests by login with username instead of mxid 2022-08-15 15:24:31 +02:00
.gitignore Merge branch 'nico/lints' into 'main' 2022-08-15 14:15:51 +00:00
.gitlab-ci.yml fix: remove tag from CI 2022-10-26 11:35:01 +02:00
.metadata Initial commit 2019-06-09 12:16:48 +02:00
CHANGELOG.md chore: bump version 2022-11-14 12:00:36 +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 2021-06-18 10:10:24 +02:00
analysis_options.yaml feat: switch from pedantic to lints 2022-08-15 14:15:51 +00:00
pubspec.yaml chore: bump version 2022-11-14 12:00:36 +01: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');