From e3ca3cebddeff7707baa8826ce7524c27cd7595a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Greg=C3=B3rio=20Granado=20Magalh=C3=A3es?= Date: Thu, 29 Jun 2023 14:07:58 -0300 Subject: [PATCH] Adds type checking to EIP1271 Magic Value (#160) --- packages/siwe/lib/utils.ts | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/packages/siwe/lib/utils.ts b/packages/siwe/lib/utils.ts index 0ec7c4de..b0725b7d 100644 --- a/packages/siwe/lib/utils.ts +++ b/packages/siwe/lib/utils.ts @@ -4,9 +4,12 @@ import { Contract, providers, Signer } from 'ethers'; import type { SiweMessage } from './client'; import { hashMessage } from './ethersCompat'; -const EIP1271_ABI = ["function isValidSignature(bytes32 _message, bytes _signature) public view returns (bytes4)"]; -const EIP1271_MAGICVALUE = "0x1626ba7e"; -const ISO8601 = /^(?[0-9]{4}-(0[1-9]|1[012])-(0[1-9]|[12][0-9]|3[01]))[Tt]([01][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9]|60)(.[0-9]+)?(([Zz])|([+|-]([01][0-9]|2[0-3]):[0-5][0-9]))$/; +const EIP1271_ABI = [ + 'function isValidSignature(bytes32 _message, bytes _signature) public view returns (bytes4)', +]; +const EIP1271_MAGICVALUE = '0x1626ba7e'; +const ISO8601 = + /^(?[0-9]{4}-(0[1-9]|1[012])-(0[1-9]|[12][0-9]|3[01]))[Tt]([01][0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9]|60)(.[0-9]+)?(([Zz])|([+|-]([01][0-9]|2[0-3]):[0-5][0-9]))$/; /** * This method calls the EIP-1271 method for Smart Contract wallets @@ -27,7 +30,7 @@ export const checkContractWalletSignature = async ( const walletContract = new Contract(message.address, EIP1271_ABI, provider); const hashedMessage = hashMessage(message.prepareMessage()); const res = await walletContract.isValidSignature(hashedMessage, signature); - return res == EIP1271_MAGICVALUE; + return res === EIP1271_MAGICVALUE; }; /** @@ -72,9 +75,12 @@ export const isValidISO8601Date = (inputDate: string): boolean => { /* Compare remaining fields */ return inputMatch.groups.date === parsedInputMatch.groups.date; -} +}; -export const checkInvalidKeys = (obj: T, keys: Array): Array => { +export const checkInvalidKeys = ( + obj: T, + keys: Array +): Array => { const invalidKeys: Array = []; Object.keys(obj).forEach(key => { if (!keys.includes(key as keyof T)) { @@ -82,4 +88,4 @@ export const checkInvalidKeys = (obj: T, keys: Array): Array