RootSoft / walletconnect-dart-sdk

Open protocol for connecting dApps to mobile wallets with QR code scanning or deep linking.
MIT License
104 stars 61 forks source link

[iOS][Android]Cannot disconnect wallet after use `killSession` #84

Open WingCH opened 1 year ago

WingCH commented 1 year ago

versions: walletconnect_dart: ^0.0.11

I just want to get the wallet address, so I use killSession after createSession returns the result, but I still see a connection in the wallet app.

i have tried this MR https://github.com/RootSoft/walletconnect-dart-sdk/pull/75 , but not work.

Reproduce step

  1. run sample code
  2. click Get Addresses button
  3. choose trust wallet (you can choose other wallet, i believe have same behavior)
  4. the wallet app will show authorize popup, click connect
  5. wallet app will back to sample app automatically and return some information including waller address
  6. After received the waller address, killSession will be executed
  7. back to wallet app manually
  8. find WalletConnect page, check connecting list

Expected result: not find sample app, since already killSession

Actual result: sample app in connecting list

Video

https://user-images.githubusercontent.com/19588517/200003359-750c0ba4-be1f-455b-86ec-3789330b6910.mp4

Sample code

class HomePage extends StatefulWidget {
  const HomePage({Key? key}) : super(key: key);

  @override
  State<HomePage> createState() => _HomePageState();
}

class _HomePageState extends State<HomePage> {
  final WalletConnect connector = WalletConnect(
    bridge: 'https://bridge.walletconnect.org',
    clientMeta: const PeerMeta(
      name: 'My App',
      // if description is null, trust wallet (iOS 7.20 (691)) will not show the connection request
      description: 'An app for converting pictures to NFT',
      url: 'https://walletconnect.org',
      icons: ['https://files.gitbook.com/v0/b/gitbook-legacy-files/o/spaces%2F-LJJeCjcLrr53DcT1Ml7%2Favatar.png?alt=media'],
    ),
  );

  void getAddresses() async {
    try {
      var session = await connector.createSession(
        onDisplayUri: (uri) async {
          await launchUrlString(
            uri.toString(),
            mode: LaunchMode.externalApplication,
          );
        },
      );

      print('address: ${session.accounts}');

      // kill session
      await connector.killSession();
    } catch (e) {}
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Center(
        child: TextButton(
          onPressed: getAddresses,
          child: const Text('Get Addresses'),
        ),
      ),
    );
  }
}

flutter doctor

[✓] Flutter (Channel stable, 3.3.7, on macOS 13.0 22A380 darwin-arm, locale zh-Hant-HK)
[✓] Android toolchain - develop for Android devices (Android SDK version 31.0.0)
[✓] Xcode - develop for iOS and macOS (Xcode 14.0.1)
[✓] Chrome - develop for the web
[✓] Android Studio (version 2021.3)
[✓] VS Code (version 1.72.2)
[✓] Connected device (4 available)
[✓] HTTP Host Availability
RootSoft commented 1 year ago

Can you try to add a delay or separate button to kill the session?

WingCH commented 1 year ago

i tried separate button to kill the session, but still not work.

TextButton(
  onPressed: () async {
    await connector.killSession();
  },
  child: const Text('Disconnect wallet'),
),

also i tried another wallet exodus, issue can be reproduce

WingCH commented 1 year ago

@RootSoft thanks for your reply, do you have the same issue? Maybe there is something wrong with the way I am using it

WingCH commented 1 year ago

@RootSoft I fix this bug and create PR https://github.com/RootSoft/walletconnect-dart-sdk/pull/85 , please take a look, thanks🙏🏻

RootSoft commented 1 year ago

@WingCH Thanks for this, and good catch! I'll do some additional testing as well this week and merge the changes asap

WingCH commented 1 year ago

Looking forward to your update!

gray-seven commented 1 year ago

Please update

ledoandailoc commented 1 year ago

Waiting for update!

RootSoft commented 1 year ago

Sorry for the delays everyone, been quite a few busy weeks lately. I'll update the package first thing next week.

buivanday96 commented 1 year ago

Please update