-
Notifications
You must be signed in to change notification settings - Fork 84
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: adds way to handle optional signing via viem signer
- Loading branch information
1 parent
8e624ba
commit fc63d15
Showing
10 changed files
with
778 additions
and
27 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
export * from './signer'; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
import type { chains } from '@lens-network/sdk/viem'; | ||
import type { | ||
SelfFundedTransactionRequest, | ||
SponsoredTransactionRequest, | ||
} from '@lens-protocol/graphql'; | ||
import { | ||
ResultAsync, | ||
type TxHash, | ||
errAsync, | ||
invariant, | ||
okAsync, | ||
txHash, | ||
} from '@lens-protocol/types'; | ||
import type { Account, Hash, Transport, WalletClient } from 'viem'; | ||
import { sendTransaction as sendEip1559Transaction } from 'viem/actions'; | ||
import { sendEip712Transaction } from 'viem/zksync'; | ||
import { SigningError, ValidationError } from '../errors'; | ||
import { | ||
type DelegableOperationHandler, | ||
type OperationHandler, | ||
type OperationResult, | ||
type RestrictedOperationHandler, | ||
isTransactionRequest, | ||
} from '../types'; | ||
|
||
async function sendTransaction( | ||
walletClient: WalletClient<Transport, chains.LensNetworkChain, Account>, | ||
request: SponsoredTransactionRequest | SelfFundedTransactionRequest, | ||
): Promise<Hash> { | ||
invariant( | ||
walletClient.account.address === request.raw.from, | ||
`Account mismatch: ${walletClient.account} !== ${request.raw.from}`, | ||
); | ||
|
||
if (request.__typename === 'SponsoredTransactionRequest') { | ||
return sendEip712Transaction(walletClient, { | ||
account: walletClient.account, | ||
data: request.raw.data, | ||
gas: BigInt(request.raw.gasLimit), | ||
|
||
// TODO Replace this workaround hack once the gas price estimation is clarified. | ||
maxFeePerGas: BigInt(request.raw.gasPrice), | ||
maxPriorityFeePerGas: BigInt(request.raw.gasPrice), | ||
// gasPrice: BigInt(request.raw.gasPrice), | ||
nonce: request.raw.nonce, | ||
paymaster: request.raw.customData.paymasterParams?.paymaster, | ||
paymasterInput: request.raw.customData.paymasterParams?.paymasterInput, | ||
to: request.raw.to, | ||
value: BigInt(request.raw.value), | ||
}); | ||
} | ||
|
||
return sendEip1559Transaction(walletClient, { | ||
account: walletClient.account, | ||
data: request.raw.data, | ||
gas: BigInt(request.raw.gasLimit), | ||
maxFeePerGas: BigInt(request.raw.maxFeePerGas), | ||
maxPriorityFeePerGas: BigInt(request.raw.maxPriorityFeePerGas), | ||
nonce: request.raw.nonce, | ||
to: request.raw.to, | ||
type: 'eip1559', | ||
value: BigInt(request.raw.value), | ||
}); | ||
} | ||
|
||
function signWith( | ||
walletClient: WalletClient<Transport, chains.LensNetworkChain, Account>, | ||
request: SponsoredTransactionRequest | SelfFundedTransactionRequest, | ||
): ResultAsync<TxHash, SigningError> { | ||
return ResultAsync.fromPromise(sendTransaction(walletClient, request).then(txHash), (err) => | ||
SigningError.from(err), | ||
); | ||
} | ||
|
||
export function handleWith<T extends string, E extends string>( | ||
walletClient: WalletClient<Transport, chains.LensNetworkChain, Account>, | ||
): DelegableOperationHandler<T, E>; | ||
export function handleWith<E extends string>( | ||
walletClient: WalletClient<Transport, chains.LensNetworkChain, Account>, | ||
): RestrictedOperationHandler<E>; | ||
export function handleWith<T extends string, E extends string>( | ||
walletClient: WalletClient<Transport, chains.LensNetworkChain, Account>, | ||
): OperationHandler<T, E> { | ||
return <T extends string, E extends string>( | ||
result: OperationResult<T, E>, | ||
): ResultAsync<TxHash, SigningError | ValidationError<E>> => { | ||
if ('hash' in result) { | ||
return okAsync(result.hash); | ||
} | ||
|
||
if (isTransactionRequest(result)) { | ||
return signWith(walletClient, result); | ||
} | ||
|
||
return errAsync(ValidationError.fromErrorResponse(result)); | ||
}; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.