From c1f24a7cc3ee4ecec6d9be011bf0b63ba62e50e7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C5=BDiga=20Kokelj?= Date: Wed, 10 Apr 2024 12:56:00 +0200 Subject: [PATCH 1/2] fix the EIP712 getmessage response --- tools/walletextension/httpapi/routes.go | 63 +++++++++++++++++++++---- 1 file changed, 53 insertions(+), 10 deletions(-) diff --git a/tools/walletextension/httpapi/routes.go b/tools/walletextension/httpapi/routes.go index 3ddbd3e073..a536e82ac7 100644 --- a/tools/walletextension/httpapi/routes.go +++ b/tools/walletextension/httpapi/routes.go @@ -387,8 +387,14 @@ func getMessageRequestHandler(walletExt *rpcapi.Services, conn UserConn) { return } - // create the response structure - type JSONResponse struct { + // create the response structure for EIP712 message where the message is a JSON object + type JSONResponseEIP712 struct { + Message json.RawMessage `json:"message"` + Type string `json:"type"` + } + + // create the response structure for personal sign message where the message is a string + type JSONResponsePersonal struct { Message string `json:"message"` Type string `json:"type"` } @@ -396,16 +402,53 @@ func getMessageRequestHandler(walletExt *rpcapi.Services, conn UserConn) { // get string representation of the message format messageFormat := viewingkey.GetBestFormat(formatsSlice) messageFormatString := viewingkey.GetSignatureTypeString(messageFormat) + responseBytes := []byte{} + if messageFormat == viewingkey.PersonalSign { + response := JSONResponsePersonal{ + Message: message, + Type: messageFormatString, + } - response := JSONResponse{ - Message: message, - Type: messageFormatString, - } + responseBytes, err = json.Marshal(response) + if err != nil { + handleError(conn, walletExt.Logger(), fmt.Errorf("error marshaling JSON response: %w", err)) + return + } + } else if messageFormat == viewingkey.EIP712Signature { - responseBytes, err := json.Marshal(response) - if err != nil { - walletExt.Logger().Error("error marshaling JSON response", log.ErrKey, err) - return + var messageMap map[string]interface{} + err = json.Unmarshal([]byte(message), &messageMap) + if err != nil { + handleError(conn, walletExt.Logger(), fmt.Errorf("error unmarshaling JSON: %w", err)) + return + } + + if domainMap, ok := messageMap["domain"].(map[string]interface{}); ok { + delete(domainMap, "salt") + delete(domainMap, "verifyingContract") + } + + if typesMap, ok := messageMap["types"].(map[string]interface{}); ok { + delete(typesMap, "EIP712Domain") + } + + // Marshal the modified map back to JSON + modifiedMessage, err := json.Marshal(messageMap) + if err != nil { + handleError(conn, walletExt.Logger(), fmt.Errorf("error marshaling modified JSON: %w", err)) + return + } + + response := JSONResponseEIP712{ + Message: modifiedMessage, + Type: messageFormatString, + } + + responseBytes, err = json.Marshal(response) + if err != nil { + handleError(conn, walletExt.Logger(), fmt.Errorf("error marshaling JSON response: %w", err)) + return + } } err = conn.WriteResponse(responseBytes) From 246efe385b6f15b499068dfa9dd11c9acf83f303 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C5=BDiga=20Kokelj?= Date: Wed, 10 Apr 2024 12:58:04 +0200 Subject: [PATCH 2/2] lint --- tools/walletextension/httpapi/routes.go | 1 - 1 file changed, 1 deletion(-) diff --git a/tools/walletextension/httpapi/routes.go b/tools/walletextension/httpapi/routes.go index a536e82ac7..883d96d9ed 100644 --- a/tools/walletextension/httpapi/routes.go +++ b/tools/walletextension/httpapi/routes.go @@ -415,7 +415,6 @@ func getMessageRequestHandler(walletExt *rpcapi.Services, conn UserConn) { return } } else if messageFormat == viewingkey.EIP712Signature { - var messageMap map[string]interface{} err = json.Unmarshal([]byte(message), &messageMap) if err != nil {