Skip to content

Commit

Permalink
feat: init WC events guide
Browse files Browse the repository at this point in the history
  • Loading branch information
IsaccoSordo committed May 6, 2024
1 parent 11af219 commit 7d277f8
Show file tree
Hide file tree
Showing 3 changed files with 38 additions and 1 deletion.
1 change: 1 addition & 0 deletions sidebars.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ module.exports = {
"guides/fa2-transfer",
"guides/contract-error-handling",
"guides/subscribe-to-event",
"guides/WC-events",
"guides/standalone-delegation",
"guides/metrics",
"guides/bug-report",
Expand Down
36 changes: 36 additions & 0 deletions src/docs/guides/WC-events.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
---
title: WalletConnect events
---

#### Overview

In Beacon we use [signClient](https://www.npmjs.com/package/@walletconnect/sign-client) to manage all WalletConnect's connections.

`signClient` manages the lifecycle and communication of sessions between a dApp and
a wallet.

This page outlines the various events that Beacon handles through `signClient`.

#### Session Events

1. **session_event**: Triggered by any significant occurrence within a session not explicitly covered by more specific events. It can be used for logging, debugging, or extending functionality.

In Beacon we use this event to acknowledge requests sent to a wallet.

2. **session_update**: Occurs when a session's state changes, such as updating permissions, accounts, or chain information. This is crucial for dApps to adjust their state in response to changes in the session parameters.

3. **session_expire**: Fired when a session reaches its expiry time and is no longer valid. This event is critical for managing session lifecycle and ensuring that expired sessions are refreshed or terminated as needed.

4. **session_delete**: This event is fired when a session is terminated either by the user, the dApp, or due to external factors leading to a disconnection.

# Pairing Events

1. **pairing_delete**: This event is triggered when a pairing is intentionally deleted, either by user action or programmatically by the dApp or wallet. This is used to manage the list of available pairings, ensuring that only valid or required pairings are maintained.

2. **pairing_expire**: Occurs when a pairing reaches its defined expiry time. Since pairings are typically temporary connections before establishing a full session, this event handles the automatic cleanup of these temporary states.

### References

1. [Session Events](https://specs.walletconnect.com/2.0/specs/clients/sign/session-events): This document outlines the various session events that can be handled by WalletConnect's `signClient`, providing details on each event's significance and usage.

2. [Pairing API](https://docs.walletconnect.com/api/core/pairing): A guide to understanding the pairing process within WalletConnect, explaining how dApps can establish preliminary connections with wallets before initiating a full session.
2 changes: 1 addition & 1 deletion src/docs/guides/disconnecting-a-wallet.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ dAppClient
`clearActiveAccount` manages the process of clearing the currently active account and only its associated active transport.
This method ensures that all data linked to the active account is removed, and the active transport connection is terminated.

> Note: Only for walletconnect, `clearActiveAccount` will also resets all transport refreneces behaving similarly to `disconnect`
> Note: Only for WalletConnect, `clearActiveAccount` will also resets all transport refreneces behaving similarly to `disconnect`
<Tabs
groupId="beaconOrTaquitoDAW"
Expand Down

0 comments on commit 7d277f8

Please sign in to comment.