102 lines
4.8 KiB
TypeScript
102 lines
4.8 KiB
TypeScript
import { COSMOS_SIGNING_METHODS } from '@/data/COSMOSData'
|
|
import { EIP155_SIGNING_METHODS } from '@/data/EIP155Data'
|
|
import { SOLANA_SIGNING_METHODS } from '@/data/SolanaData'
|
|
import { POLKADOT_SIGNING_METHODS } from '@/data/PolkadotData'
|
|
import { ELROND_SIGNING_METHODS } from '@/data/ElrondData'
|
|
import ModalStore from '@/store/ModalStore'
|
|
import { signClient } from '@/utils/WalletConnectUtil'
|
|
import { SignClientTypes } from '@walletconnect/types'
|
|
import { useCallback, useEffect } from 'react'
|
|
import { NEAR_SIGNING_METHODS } from '@/data/NEARData'
|
|
import { approveNearRequest } from '@/utils/NearRequestHandlerUtil'
|
|
|
|
export default function useWalletConnectEventsManager(initialized: boolean) {
|
|
/******************************************************************************
|
|
* 1. Open session proposal modal for confirmation / rejection
|
|
*****************************************************************************/
|
|
const onSessionProposal = useCallback(
|
|
(proposal: SignClientTypes.EventArguments['session_proposal']) => {
|
|
ModalStore.open('SessionProposalModal', { proposal })
|
|
},
|
|
[]
|
|
)
|
|
|
|
/******************************************************************************
|
|
* 3. Open request handling modal based on method that was used
|
|
*****************************************************************************/
|
|
const onSessionRequest = useCallback(
|
|
async (requestEvent: SignClientTypes.EventArguments['session_request']) => {
|
|
console.log('session_request', requestEvent)
|
|
const { topic, params } = requestEvent
|
|
const { request } = params
|
|
const requestSession = signClient.session.get(topic)
|
|
|
|
switch (request.method) {
|
|
case EIP155_SIGNING_METHODS.ETH_SIGN:
|
|
case EIP155_SIGNING_METHODS.PERSONAL_SIGN:
|
|
return ModalStore.open('SessionSignModal', { requestEvent, requestSession })
|
|
|
|
case EIP155_SIGNING_METHODS.ETH_SIGN_TYPED_DATA:
|
|
case EIP155_SIGNING_METHODS.ETH_SIGN_TYPED_DATA_V3:
|
|
case EIP155_SIGNING_METHODS.ETH_SIGN_TYPED_DATA_V4:
|
|
return ModalStore.open('SessionSignTypedDataModal', { requestEvent, requestSession })
|
|
|
|
case EIP155_SIGNING_METHODS.ETH_SEND_TRANSACTION:
|
|
case EIP155_SIGNING_METHODS.ETH_SIGN_TRANSACTION:
|
|
return ModalStore.open('SessionSendTransactionModal', { requestEvent, requestSession })
|
|
|
|
case COSMOS_SIGNING_METHODS.COSMOS_SIGN_DIRECT:
|
|
case COSMOS_SIGNING_METHODS.COSMOS_SIGN_AMINO:
|
|
return ModalStore.open('SessionSignCosmosModal', { requestEvent, requestSession })
|
|
|
|
case SOLANA_SIGNING_METHODS.SOLANA_SIGN_MESSAGE:
|
|
case SOLANA_SIGNING_METHODS.SOLANA_SIGN_TRANSACTION:
|
|
return ModalStore.open('SessionSignSolanaModal', { requestEvent, requestSession })
|
|
|
|
case POLKADOT_SIGNING_METHODS.POLKADOT_SIGN_MESSAGE:
|
|
case POLKADOT_SIGNING_METHODS.POLKADOT_SIGN_TRANSACTION:
|
|
return ModalStore.open('SessionSignPolkadotModal', { requestEvent, requestSession })
|
|
|
|
case NEAR_SIGNING_METHODS.NEAR_SIGN_IN:
|
|
case NEAR_SIGNING_METHODS.NEAR_SIGN_OUT:
|
|
case NEAR_SIGNING_METHODS.NEAR_SIGN_TRANSACTION:
|
|
case NEAR_SIGNING_METHODS.NEAR_SIGN_AND_SEND_TRANSACTION:
|
|
case NEAR_SIGNING_METHODS.NEAR_SIGN_TRANSACTIONS:
|
|
case NEAR_SIGNING_METHODS.NEAR_SIGN_AND_SEND_TRANSACTIONS:
|
|
case NEAR_SIGNING_METHODS.NEAR_VERIFY_OWNER:
|
|
return ModalStore.open('SessionSignNearModal', { requestEvent, requestSession })
|
|
|
|
case ELROND_SIGNING_METHODS.ELROND_SIGN_MESSAGE:
|
|
case ELROND_SIGNING_METHODS.ELROND_SIGN_TRANSACTION:
|
|
case ELROND_SIGNING_METHODS.ELROND_SIGN_TRANSACTIONS:
|
|
case ELROND_SIGNING_METHODS.ELROND_SIGN_LOGIN_TOKEN:
|
|
return ModalStore.open('SessionSignElrondModal', { requestEvent, requestSession })
|
|
|
|
case NEAR_SIGNING_METHODS.NEAR_GET_ACCOUNTS:
|
|
return signClient.respond({
|
|
topic,
|
|
response: await approveNearRequest(requestEvent)
|
|
})
|
|
default:
|
|
return ModalStore.open('SessionUnsuportedMethodModal', { requestEvent, requestSession })
|
|
}
|
|
},
|
|
[]
|
|
)
|
|
|
|
/******************************************************************************
|
|
* Set up WalletConnect event listeners
|
|
*****************************************************************************/
|
|
useEffect(() => {
|
|
if (initialized) {
|
|
signClient.on('session_proposal', onSessionProposal)
|
|
signClient.on('session_request', onSessionRequest)
|
|
// TODOs
|
|
signClient.on('session_ping', data => console.log('ping', data))
|
|
signClient.on('session_event', data => console.log('event', data))
|
|
signClient.on('session_update', data => console.log('update', data))
|
|
signClient.on('session_delete', data => console.log('delete', data))
|
|
}
|
|
}, [initialized, onSessionProposal, onSessionRequest])
|
|
}
|