Skip to content

Commit

Permalink
Merge pull request #12 from takenet/feature/450009-performance
Browse files Browse the repository at this point in the history
[Feature] 450009 - Improve Performance
  • Loading branch information
mpamaro authored Jul 12, 2023
2 parents d18251d + d8d4c5d commit 8e0fee9
Show file tree
Hide file tree
Showing 4 changed files with 53 additions and 39 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
## 0.0.24

- Improved client connect readability and performance.

## 0.0.23

- Updated Lime version from 0.0.21 to 0.0.23
Expand Down
52 changes: 31 additions & 21 deletions lib/src/client.dart
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
import 'dart:async';
import 'dart:math';

import 'package:lime/lime.dart';

import 'application.dart';
import 'extensions/base.extension.dart';
import 'extensions/enums/extension_type.enum.dart';
Expand Down Expand Up @@ -82,22 +84,29 @@ class Client {

_connectionTryCount++;
_closing = false;
return transport
.open(uri, useMtls: useMtls)
.then(
(_) => _clientChannel.establishSession(
application.identifier + '@' + application.domain,
application.instance,
application.authentication,
),
)
.then((session) => _sendPresenceCommand().then((_) => session))
.then((session) => _sendReceiptsCommand().then((_) => session))
.then((session) {
_listening = true;
_connectionTryCount = 0;
return session;
});

await transport.open(
uri,
useMtls: useMtls,
);

final session = await _clientChannel.establishSession(
application.identifier + '@' + application.domain,
application.instance,
application.authentication,
);

await Future.wait(
<Future>[
_sendPresenceCommand(),
_sendReceiptsCommand(),
],
);

_listening = true;
_connectionTryCount = 0;

return session;
}

/// Start listening to streams
Expand Down Expand Up @@ -238,11 +247,12 @@ class Client {
}
return sendCommand(
Command(
id: guid(),
method: CommandMethod.set,
uri: '/presence',
type: 'application/vnd.lime.presence+json',
resource: application.presence),
id: guid(),
method: CommandMethod.set,
uri: '/presence',
type: 'application/vnd.lime.presence+json',
resource: application.presence,
),
);
}

Expand Down
34 changes: 17 additions & 17 deletions pubspec.lock
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,10 @@ packages:
dependency: transitive
description:
name: async
sha256: bfe67ef28df125b7dddcea62755991f807aa39a2492a23e1550161692950bbe0
sha256: "947bfcf187f74dbc5e146c9eb9c0f10c9f8b30743e341481c1e2ed3ecc18c20c"
url: "https://pub.dev"
source: hosted
version: "2.10.0"
version: "2.11.0"
boolean_selector:
dependency: transitive
description:
Expand All @@ -21,10 +21,10 @@ packages:
dependency: transitive
description:
name: characters
sha256: e6a326c8af69605aec75ed6c187d06b349707a27fbff8222ca9cc2cff167975c
sha256: "04a925763edad70e8443c99234dc3328f442e811f1d8fd1a72f1c8ad0f69a605"
url: "https://pub.dev"
source: hosted
version: "1.2.1"
version: "1.3.0"
clock:
dependency: transitive
description:
Expand All @@ -37,10 +37,10 @@ packages:
dependency: transitive
description:
name: collection
sha256: cfc915e6923fe5ce6e153b0723c753045de46de1b4d63771530504004a45fae0
sha256: "4a07be6cb69c84d677a6c3096fcf960cc3285a8330b4603e0d463d15d9bd934c"
url: "https://pub.dev"
source: hosted
version: "1.17.0"
version: "1.17.1"
crypto:
dependency: transitive
description:
Expand Down Expand Up @@ -79,10 +79,10 @@ packages:
dependency: transitive
description:
name: js
sha256: "5528c2f391ededb7775ec1daa69e65a2d61276f7552de2b5f7b8d34ee9fd4ab7"
sha256: f2c445dce49627136094980615a031419f7f3eb393237e4ecd97ac15dea343f3
url: "https://pub.dev"
source: hosted
version: "0.6.5"
version: "0.6.7"
lime:
dependency: "direct main"
description:
Expand Down Expand Up @@ -111,10 +111,10 @@ packages:
dependency: transitive
description:
name: matcher
sha256: "16db949ceee371e9b99d22f88fa3a73c4e59fd0afed0bd25fc336eb76c198b72"
sha256: "6501fbd55da300384b768785b83e5ce66991266cec21af89ab9ae7f5ce1c4cbb"
url: "https://pub.dev"
source: hosted
version: "0.12.13"
version: "0.12.15"
material_color_utilities:
dependency: transitive
description:
Expand All @@ -127,18 +127,18 @@ packages:
dependency: transitive
description:
name: meta
sha256: "6c268b42ed578a53088d834796959e4a1814b5e9e164f147f580a386e5decf42"
sha256: "3c74dbf8763d36539f114c799d8a2d87343b5067e9d796ca22b5eb8437090ee3"
url: "https://pub.dev"
source: hosted
version: "1.8.0"
version: "1.9.1"
path:
dependency: transitive
description:
name: path
sha256: db9d4f58c908a4ba5953fcee2ae317c94889433e5024c27ce74a37f94267945b
sha256: "8829d8a55c13fc0e37127c29fedf290c102f4e40ae94ada574091fe0ff96c917"
url: "https://pub.dev"
source: hosted
version: "1.8.2"
version: "1.8.3"
pretty_json:
dependency: transitive
description:
Expand Down Expand Up @@ -204,10 +204,10 @@ packages:
dependency: transitive
description:
name: test_api
sha256: ad540f65f92caa91bf21dfc8ffb8c589d6e4dc0c2267818b4cc2792857706206
sha256: eb6ac1540b26de412b3403a163d919ba86f6a973fe6cc50ae3541b80092fdcfb
url: "https://pub.dev"
source: hosted
version: "0.4.16"
version: "0.5.1"
typed_data:
dependency: transitive
description:
Expand All @@ -233,5 +233,5 @@ packages:
source: hosted
version: "2.1.4"
sdks:
dart: ">=2.18.0 <3.0.0"
dart: ">=3.0.0-0 <4.0.0"
flutter: ">=1.17.0"
2 changes: 1 addition & 1 deletion pubspec.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
name: blip_sdk
description: A simple SDK built for BLiP using Flutter/Dart
version: 0.0.23
version: 0.0.24
homepage: https://github.com/takenet/blip-sdk-dart#readme
repository: https://github.com/takenet/blip-sdk-dart

Expand Down

0 comments on commit 8e0fee9

Please sign in to comment.