walletconnect-dart-sdk icon indicating copy to clipboard operation
walletconnect-dart-sdk copied to clipboard

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

Open WingCH opened this issue 3 years ago • 10 comments

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

WingCH avatar Nov 04 '22 14:11 WingCH

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

RootSoft avatar Nov 04 '22 15:11 RootSoft

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 avatar Nov 04 '22 15:11 WingCH

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

WingCH avatar Nov 04 '22 15:11 WingCH

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

WingCH avatar Nov 05 '22 16:11 WingCH

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

RootSoft avatar Nov 07 '22 18:11 RootSoft

Looking forward to your update!

WingCH avatar Nov 07 '22 23:11 WingCH

Please update

gray-seven avatar Nov 08 '22 07:11 gray-seven

Waiting for update!

ledoandailoc avatar Nov 22 '22 03:11 ledoandailoc

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

RootSoft avatar Nov 25 '22 15:11 RootSoft

Please update

buivanday96 avatar Dec 15 '22 04:12 buivanday96