SIWX Custom Usage
This feature is currently under experimental stage.
Alternatively from the Default Implementation, you can create your own implementation of the SIWX feature to suit your specific requirements.
SIWX is developed to work as a plugin system for AppKit and to enable correctly it you need to fulfill the expected interface within the createAppKit
function.
SWIXConfig interface
This is the interface that you need to implement to create your own SIWX feature.
interface SIWXConfig {
createMessage: (input: SIWXMessage.Input) => Promise<SIWXMessage>
addSession: (session: SIWXSession) => Promise<void>
revokeSession: (chainId: CaipNetworkId, address: string) => Promise<void>
setSessions: (sessions: SIWXSession[]) => Promise<void>
getSessions: (chainId: CaipNetworkId, address: string) => Promise<SIWXSession[]>
}
All the typings used are exposed by @reown/appkit-core
package. You may check the source code here.
Constraints
You are able to implement the SIWXConfig
in the way you would like, but some constraints MUST be followed to make sure that AppKit can interact with it correctly and it will work as expected:
createMessage
This method will be called to create a new message to be signed by the user.
- The message MUST be unique and contain all the necessary information to verify the user's identity.