From 00bf60d568591586aee69557949f5770c3d54fe7 Mon Sep 17 00:00:00 2001
From: Alfreedom <00tango.bromine@icloud.com>
Date: Tue, 9 Jul 2024 12:35:14 +0200
Subject: [PATCH] bug fixes and ehancements
---
CHANGELOG.md | 2 +-
example/android/gradle.properties | 2 +-
example/ios/Runner.xcodeproj/project.pbxproj | 12 ++---
example/ios/Runner/Info.plist | 2 +-
example/lib/home_page.dart | 4 +-
example/pubspec.lock | 6 +--
.../coinbase_service/coinbase_service.dart | 21 +++++++--
.../siwe_service/utils/siwe_utils.dart | 45 +++++++++++++++++++
lib/services/w3m_service/i_w3m_service.dart | 2 -
lib/services/w3m_service/w3m_service.dart | 8 +---
lib/version.dart | 2 +-
lib/web3modal_flutter.dart | 4 +-
pubspec.lock | 4 +-
pubspec.yaml | 4 +-
test/mock_classes.mocks.dart | 17 +------
15 files changed, 87 insertions(+), 48 deletions(-)
create mode 100644 lib/services/siwe_service/utils/siwe_utils.dart
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 838b82ec..74403e95 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,4 +1,4 @@
-## 3.3.0-beta04
+## 3.3.0-beta05
- One-Click Auth + SIWE implementation
- Coinbase Wallet dependency update
diff --git a/example/android/gradle.properties b/example/android/gradle.properties
index 5b366352..7c06f16b 100644
--- a/example/android/gradle.properties
+++ b/example/android/gradle.properties
@@ -2,4 +2,4 @@ org.gradle.jvmargs=-Xmx1536M
android.useAndroidX=true
android.enableJetifier=true
versionName=3.3.0
-versionCode=65
+versionCode=66
diff --git a/example/ios/Runner.xcodeproj/project.pbxproj b/example/ios/Runner.xcodeproj/project.pbxproj
index fc4cb21b..34f67823 100644
--- a/example/ios/Runner.xcodeproj/project.pbxproj
+++ b/example/ios/Runner.xcodeproj/project.pbxproj
@@ -470,7 +470,7 @@
CLANG_ENABLE_MODULES = YES;
CODE_SIGN_ENTITLEMENTS = Runner/Runner.entitlements;
CODE_SIGN_STYLE = Manual;
- CURRENT_PROJECT_VERSION = 65;
+ CURRENT_PROJECT_VERSION = 66;
DEVELOPMENT_TEAM = "";
"DEVELOPMENT_TEAM[sdk=iphoneos*]" = W5R8AG9K22;
ENABLE_BITCODE = NO;
@@ -496,7 +496,7 @@
buildSettings = {
BUNDLE_LOADER = "$(TEST_HOST)";
CODE_SIGN_STYLE = Automatic;
- CURRENT_PROJECT_VERSION = 65;
+ CURRENT_PROJECT_VERSION = 66;
GENERATE_INFOPLIST_FILE = YES;
MARKETING_VERSION = 1.0;
PRODUCT_BUNDLE_IDENTIFIER = com.web3modal.flutterExample.RunnerTests;
@@ -514,7 +514,7 @@
buildSettings = {
BUNDLE_LOADER = "$(TEST_HOST)";
CODE_SIGN_STYLE = Automatic;
- CURRENT_PROJECT_VERSION = 65;
+ CURRENT_PROJECT_VERSION = 66;
GENERATE_INFOPLIST_FILE = YES;
MARKETING_VERSION = 1.0;
PRODUCT_BUNDLE_IDENTIFIER = com.web3modal.flutterExample.RunnerTests;
@@ -530,7 +530,7 @@
buildSettings = {
BUNDLE_LOADER = "$(TEST_HOST)";
CODE_SIGN_STYLE = Automatic;
- CURRENT_PROJECT_VERSION = 65;
+ CURRENT_PROJECT_VERSION = 66;
GENERATE_INFOPLIST_FILE = YES;
MARKETING_VERSION = 1.0;
PRODUCT_BUNDLE_IDENTIFIER = com.web3modal.flutterExample.RunnerTests;
@@ -655,7 +655,7 @@
CLANG_ENABLE_MODULES = YES;
CODE_SIGN_ENTITLEMENTS = Runner/Runner.entitlements;
CODE_SIGN_STYLE = Manual;
- CURRENT_PROJECT_VERSION = 65;
+ CURRENT_PROJECT_VERSION = 66;
DEVELOPMENT_TEAM = "";
"DEVELOPMENT_TEAM[sdk=iphoneos*]" = W5R8AG9K22;
ENABLE_BITCODE = NO;
@@ -686,7 +686,7 @@
CODE_SIGN_IDENTITY = "Apple Development";
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Distribution";
CODE_SIGN_STYLE = Manual;
- CURRENT_PROJECT_VERSION = 65;
+ CURRENT_PROJECT_VERSION = 66;
DEVELOPMENT_TEAM = "";
"DEVELOPMENT_TEAM[sdk=iphoneos*]" = W5R8AG9K22;
ENABLE_BITCODE = NO;
diff --git a/example/ios/Runner/Info.plist b/example/ios/Runner/Info.plist
index b6f6a39d..9565095f 100644
--- a/example/ios/Runner/Info.plist
+++ b/example/ios/Runner/Info.plist
@@ -36,7 +36,7 @@
CFBundleVersion
- 65
+ 66
ITSAppUsesNonExemptEncryption
LSApplicationQueriesSchemes
diff --git a/example/lib/home_page.dart b/example/lib/home_page.dart
index bd9a4169..29135810 100644
--- a/example/lib/home_page.dart
+++ b/example/lib/home_page.dart
@@ -68,7 +68,7 @@ class _MyHomePageState extends State {
} catch (error) {
debugPrint('[SIWEConfig] getNonce error: $error');
// Fallback patch for testing purposes in case SIWE backend has issues
- return AuthUtils.generateNonce();
+ return AuthSignature.generateNonce();
}
},
getMessageParams: () async {
@@ -86,7 +86,7 @@ class _MyHomePageState extends State {
// Create SIWE message to be signed.
// You can use our provided formatMessage() method of implement your own
debugPrint('[SIWEConfig] createMessage()');
- return _w3mService.formatMessage(args);
+ return AuthSignature.formatMessage(args);
},
verifyMessage: (SIWEVerifyMessageArgs args) async {
// Implement your verifyMessage to authenticate the user after it.
diff --git a/example/pubspec.lock b/example/pubspec.lock
index e7cdab56..d387e96f 100644
--- a/example/pubspec.lock
+++ b/example/pubspec.lock
@@ -1097,10 +1097,10 @@ packages:
dependency: transitive
description:
name: walletconnect_flutter_v2
- sha256: "7f6f66038ce0f559c5661c21b6485f0abfe42354605a628c2fb571a02ec1386e"
+ sha256: "67582d34a3ceaf8253870d624112562e6e0af730bedc7954bd4df0099c277ee4"
url: "https://pub.dev"
source: hosted
- version: "2.3.0-beta03"
+ version: "2.3.0-beta04"
watcher:
dependency: transitive
description:
@@ -1131,7 +1131,7 @@ packages:
path: ".."
relative: true
source: path
- version: "3.3.0-beta04"
+ version: "3.3.0-beta05"
web_socket_channel:
dependency: transitive
description:
diff --git a/lib/services/coinbase_service/coinbase_service.dart b/lib/services/coinbase_service/coinbase_service.dart
index 2d53c50f..bd06665b 100644
--- a/lib/services/coinbase_service/coinbase_service.dart
+++ b/lib/services/coinbase_service/coinbase_service.dart
@@ -7,6 +7,7 @@ import 'package:web3modal_flutter/services/coinbase_service/i_coinbase_service.d
import 'package:web3modal_flutter/services/coinbase_service/models/coinbase_data.dart';
import 'package:web3modal_flutter/services/coinbase_service/models/coinbase_events.dart';
import 'package:web3modal_flutter/services/explorer_service/explorer_service_singleton.dart';
+import 'package:web3modal_flutter/services/logger_service/logger_service_singleton.dart';
import 'package:web3modal_flutter/web3modal_flutter.dart';
import 'package:coinbase_wallet_sdk/currency.dart';
@@ -122,12 +123,24 @@ class CoinbaseService implements ICoinbaseService {
}
@override
- Future get ownPublicKey async =>
- await CoinbaseWalletSDK.shared.ownPublicKey();
+ Future get ownPublicKey async {
+ try {
+ return await CoinbaseWalletSDK.shared.ownPublicKey();
+ } catch (e) {
+ loggerService.instance.e('[$runtimeType] ownPublicKey $e');
+ return '';
+ }
+ }
@override
- Future get peerPublicKey async =>
- await CoinbaseWalletSDK.shared.peerPublicKey();
+ Future get peerPublicKey async {
+ try {
+ return await CoinbaseWalletSDK.shared.peerPublicKey();
+ } catch (e) {
+ loggerService.instance.e('[$runtimeType] peerPublicKey $e');
+ return '';
+ }
+ }
@override
Future getAccount() async {
diff --git a/lib/services/siwe_service/utils/siwe_utils.dart b/lib/services/siwe_service/utils/siwe_utils.dart
new file mode 100644
index 00000000..72aec9d8
--- /dev/null
+++ b/lib/services/siwe_service/utils/siwe_utils.dart
@@ -0,0 +1,45 @@
+import 'package:walletconnect_flutter_v2/apis/sign_api/models/auth/common_auth_models.dart';
+import 'package:walletconnect_flutter_v2/apis/sign_api/utils/auth/auth_signature.dart'
+ as wcfv2;
+import 'package:walletconnect_flutter_v2/apis/sign_api/utils/auth/auth_utils.dart';
+import 'package:web3modal_flutter/services/siwe_service/models/w3m_siwe.dart';
+import 'package:web3modal_flutter/services/siwe_service/siwe_service_singleton.dart';
+
+class AuthSignature {
+ /// Given SIWECreateMessageArgs will format message according to EIP-4361 https://docs.login.xyz/general-information/siwe-overview/eip-4361
+ static String formatMessage(SIWECreateMessageArgs params) {
+ return siweService.instance!.formatMessage(
+ params,
+ );
+ }
+
+ static String getAddressFromMessage(String message) {
+ return wcfv2.AuthSignature.getAddressFromMessage(message);
+ }
+
+ static String getChainIdFromMessage(String message) {
+ return wcfv2.AuthSignature.getChainIdFromMessage(message);
+ }
+
+ // verifies CACAO signature
+ // Used by the wallet after formatting the message
+ static Future verifySignature(
+ String address,
+ String message,
+ CacaoSignature cacaoSignature,
+ String chainId,
+ String projectId,
+ ) async {
+ return wcfv2.AuthSignature.verifySignature(
+ address,
+ message,
+ cacaoSignature,
+ chainId,
+ projectId,
+ );
+ }
+
+ static String generateNonce() {
+ return AuthUtils.generateNonce();
+ }
+}
diff --git a/lib/services/w3m_service/i_w3m_service.dart b/lib/services/w3m_service/i_w3m_service.dart
index 352076f8..c49d16bb 100644
--- a/lib/services/w3m_service/i_w3m_service.dart
+++ b/lib/services/w3m_service/i_w3m_service.dart
@@ -111,8 +111,6 @@ abstract class IW3MService with ChangeNotifier {
Future loadAccountData();
- String formatMessage(SIWECreateMessageArgs params);
-
/// Disconnects the session and pairing, if any.
/// If there is no session, this does nothing.
Future disconnect({bool disconnectAllSessions = true});
diff --git a/lib/services/w3m_service/w3m_service.dart b/lib/services/w3m_service/w3m_service.dart
index 4d18537a..eb030f7f 100644
--- a/lib/services/w3m_service/w3m_service.dart
+++ b/lib/services/w3m_service/w3m_service.dart
@@ -721,13 +721,6 @@ class W3MService with ChangeNotifier implements IW3MService {
}
}
- @override
- String formatMessage(SIWECreateMessageArgs params) {
- return siweService.instance!.formatMessage(
- params,
- );
- }
-
@override
Future buildConnectionUri() async {
if (!_isConnected) {
@@ -1002,6 +995,7 @@ class W3MService with ChangeNotifier implements IW3MService {
List parameters = const [],
}) async {
try {
+ // TODO use blockchain-api if possible.
return await _web3App.requestReadContract(
deployedContract: deployedContract,
functionName: functionName,
diff --git a/lib/version.dart b/lib/version.dart
index 635a83cf..3212ce43 100644
--- a/lib/version.dart
+++ b/lib/version.dart
@@ -1,2 +1,2 @@
// Generated code. Do not modify.
-const packageVersion = '3.3.0-beta04';
+const packageVersion = '3.3.0-beta05';
diff --git a/lib/web3modal_flutter.dart b/lib/web3modal_flutter.dart
index 02f49cfb..aad37a72 100644
--- a/lib/web3modal_flutter.dart
+++ b/lib/web3modal_flutter.dart
@@ -2,7 +2,8 @@
library web3modal_flutter;
/// libraries
-export 'package:walletconnect_flutter_v2/walletconnect_flutter_v2.dart';
+export 'package:walletconnect_flutter_v2/walletconnect_flutter_v2.dart'
+ hide AuthSignature;
/// Models
export 'models/w3m_chain_info.dart';
@@ -12,6 +13,7 @@ export 'services/siwe_service/models/w3m_siwe.dart';
/// Utils
export 'utils/w3m_chains_presets.dart';
export 'utils/util.dart';
+export 'services/siwe_service/utils/siwe_utils.dart';
/// Theme
export 'theme/w3m_theme.dart';
diff --git a/pubspec.lock b/pubspec.lock
index e08d1a4c..28040cbc 100644
--- a/pubspec.lock
+++ b/pubspec.lock
@@ -1073,10 +1073,10 @@ packages:
dependency: "direct main"
description:
name: walletconnect_flutter_v2
- sha256: "7f6f66038ce0f559c5661c21b6485f0abfe42354605a628c2fb571a02ec1386e"
+ sha256: "67582d34a3ceaf8253870d624112562e6e0af730bedc7954bd4df0099c277ee4"
url: "https://pub.dev"
source: hosted
- version: "2.3.0-beta03"
+ version: "2.3.0-beta04"
watcher:
dependency: transitive
description:
diff --git a/pubspec.yaml b/pubspec.yaml
index 5566c99e..70d859b3 100644
--- a/pubspec.yaml
+++ b/pubspec.yaml
@@ -1,6 +1,6 @@
name: web3modal_flutter
description: "WalletConnect Web3Modal: Simple, intuitive wallet login. With this drop-in UI SDK, enable any wallet's users to seamlessly log in to your app and enjoy a unified experience"
-version: 3.3.0-beta04
+version: 3.3.0-beta05
repository: https://github.com/WalletConnect/Web3ModalFlutter
environment:
@@ -24,7 +24,7 @@ dependencies:
shimmer: ^3.0.0
url_launcher: ^6.2.5
uuid: ^4.3.3
- walletconnect_flutter_v2: ^2.3.0-beta03
+ walletconnect_flutter_v2: ^2.3.0-beta04
webview_flutter: ^4.7.0
webview_flutter_android: ^3.16.0
webview_flutter_wkwebview: ^3.13.0
diff --git a/test/mock_classes.mocks.dart b/test/mock_classes.mocks.dart
index 8a780536..317be5b8 100644
--- a/test/mock_classes.mocks.dart
+++ b/test/mock_classes.mocks.dart
@@ -695,21 +695,6 @@ class MockW3MService extends _i1.Mock implements _i3.W3MService {
returnValueForMissingStub: _i14.Future.value(),
) as _i14.Future);
@override
- String formatMessage(_i3.SIWECreateMessageArgs? params) =>
- (super.noSuchMethod(
- Invocation.method(
- #formatMessage,
- [params],
- ),
- returnValue: _i13.dummyValue(
- this,
- Invocation.method(
- #formatMessage,
- [params],
- ),
- ),
- ) as String);
- @override
_i14.Future buildConnectionUri() => (super.noSuchMethod(
Invocation.method(
#buildConnectionUri,
@@ -1360,6 +1345,7 @@ class MockWeb3App extends _i1.Mock implements _i3.Web3App {
required _i3.DeployedContract? deployedContract,
required String? functionName,
required String? rpcUrl,
+ _i3.EthereumAddress? sender,
List? parameters = const [],
}) =>
(super.noSuchMethod(
@@ -1370,6 +1356,7 @@ class MockWeb3App extends _i1.Mock implements _i3.Web3App {
#deployedContract: deployedContract,
#functionName: functionName,
#rpcUrl: rpcUrl,
+ #sender: sender,
#parameters: parameters,
},
),