-
Notifications
You must be signed in to change notification settings - Fork 33
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat(rfq-relayer): support FastBridgeV2 with arbitrary calls [SLT-320] #3258
base: master
Are you sure you want to change the base?
Changes from 81 commits
36a42bd
919a0a9
867d5d9
c93c403
9575246
7872f2a
ad7dd4c
5ca5ad1
e8355c3
eb2bbb8
c50042a
9fb4461
156e333
2b77b4a
271f59d
2317a58
c6a1fdc
e5e8646
ab63286
93d9b7d
e34a08b
1056ef1
1301270
1081e0a
467d5c7
f456bb7
de621a7
e3c1604
bff4f72
4ed813b
5b6ec12
d3dbeb0
0bc22c5
117ce59
6dee3d1
f57312b
4b8dc68
b24d31d
91a6b8f
b6a4609
05ab3dd
94ee810
337782c
8759318
f44c7ae
978313d
95ea295
23d4a7a
83cef1d
14ed93d
9dd3998
8ece825
d3be2ff
8edcb7b
884d9ae
5a6cb3c
aac6885
8f9d8ec
2132369
57efbd0
fab0b9e
c1f57ef
e2dfc5a
731a83c
a7bb3a3
1add668
ac79f4d
6dac46b
9ff5bf3
231bbea
1a12f35
bf8b443
f113504
bff2348
442be53
96055a7
b7c4f20
ba5afb9
3ba6dda
e160c45
ac4c1a0
d80847e
62e17de
15858f7
cd6015f
a90924e
67f7e14
19b24c6
551083b
d4b7d23
df72ef2
0aaf37e
15c2598
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -275,6 +275,7 @@ func (c *clientImpl) processWebsocket(ctx context.Context, conn *websocket.Conn, | |
case <-ctx.Done(): | ||
return nil | ||
case msg, ok := <-reqChan: | ||
fmt.Printf("recved message from reqChan: %+v\n", msg) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 🛠️ Refactor suggestion Replace fmt.Printf with structured logging The debug logging should use the existing logger instance with appropriate log levels instead of fmt.Printf. This ensures consistent logging across the codebase and better control over log levels in production. -fmt.Printf("recved message from reqChan: %+v\n", msg)
+logger.Debugf("received message from reqChan: %+v", msg)
|
||
if !ok { | ||
return fmt.Errorf("error reading from reqChan: %w", ctx.Err()) | ||
} | ||
|
@@ -283,6 +284,7 @@ func (c *clientImpl) processWebsocket(ctx context.Context, conn *websocket.Conn, | |
return fmt.Errorf("error sending message to websocket: %w", err) | ||
} | ||
case msg, ok := <-readChan: | ||
fmt.Printf("recved message from readChan: %+v\n", msg) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 🛠️ Refactor suggestion Replace fmt.Printf with structured logging Similar to the previous comment, use the logger instance for consistent logging practices. -fmt.Printf("recved message from readChan: %+v\n", msg)
+logger.Debugf("received message from readChan: %+v", msg)
|
||
if !ok { | ||
return nil | ||
} | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,9 @@ | ||
package model | ||
|
||
import "time" | ||
import ( | ||
"fmt" | ||
"time" | ||
) | ||
|
||
// PutRelayerQuoteRequest contains the schema for a PUT /quote request. | ||
type PutRelayerQuoteRequest struct { | ||
|
@@ -55,8 +58,12 @@ type QuoteData struct { | |
DestChainID int `json:"dest_chain_id"` | ||
OriginTokenAddr string `json:"origin_token_addr"` | ||
DestTokenAddr string `json:"dest_token_addr"` | ||
OriginAmountExact string `json:"origin_amount_exact"` | ||
ExpirationWindow int64 `json:"expiration_window"` | ||
ZapData string `json:"zap_data"` | ||
ZapNative string `json:"zap_native"` | ||
OriginAmountExact string `json:"origin_amount_exact"` | ||
OriginSender string `json:"origin_sender"` | ||
DestRecipient string `json:"dest_recipient"` | ||
Comment on lines
+61
to
+65
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 💡 Codebase verification Input validation needed for new FastBridgeV2 fields Based on the codebase analysis, there is only basic validation for ZapNative (checking if it's a valid big.Int and non-zero), but no validation for:
Suggested validation points:
🔗 Analysis chainVerify input validation for new fields The new fields support FastBridgeV2's arbitrary call functionality, but there's no apparent validation for these fields. Consider adding validation to ensure:
🏁 Scripts executedThe following scripts were executed for the analysis: Script: #!/bin/bash
# Check if validation exists for the new fields
rg -A 5 "func.*validate.*Quote"
ast-grep --pattern 'if $COND {
$$$
$ERR = $$$
$$$
}'
Length of output: 66715 Script: #!/bin/bash
# Search for validation functions in the codebase
rg -A 10 "func.*validate.*Quote|func.*validate.*Request" services/rfq/api/
# Search for validation patterns in request.go
rg -A 5 "if.*invalid|if.*err.*=.*validate" services/rfq/api/model/request.go
# Look for validation in handler code
rg -A 10 "func.*Handle.*Quote.*Request" services/rfq/api/rest/
Length of output: 2919 Script: #!/bin/bash
# Search for validation in the request handling flow
rg -A 10 "func.*PutQuote|func.*PostQuote" services/rfq/api/rest/
# Look for validation in the model package
rg -A 10 "func.*Validate|func.*Check" services/rfq/api/model/
# Search for any validation related to zap or bridge data
rg -A 5 "zap|bridge.*valid" services/rfq/api/
Length of output: 2876 |
||
DestAmount *string `json:"dest_amount"` | ||
RelayerAddress *string `json:"relayer_address"` | ||
QuoteID *string `json:"quote_id"` | ||
|
@@ -78,6 +85,7 @@ type SubscribeActiveRFQRequest struct { | |
|
||
// NewWsRFQRequest creates a new WsRFQRequest. | ||
func NewWsRFQRequest(data QuoteData, requestID string) *WsRFQRequest { | ||
fmt.Printf("NewWsRFQRequest with data: %+v\n", data) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Replace fmt.Printf with structured logging Using fmt.Printf for debugging can expose sensitive data and doesn't provide proper log levels or structured output. - fmt.Printf("NewWsRFQRequest with data: %+v\n", data)
+ logger.Debug("Creating new WsRFQRequest",
+ "origin_chain_id", data.OriginChainID,
+ "dest_chain_id", data.DestChainID,
+ "origin_token_addr", data.OriginTokenAddr,
+ "dest_token_addr", data.DestTokenAddr)
|
||
return &WsRFQRequest{ | ||
RequestID: requestID, | ||
Data: data, | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -41,10 +41,12 @@ type PutRelayAckResponse struct { | |
RelayerAddress string `json:"relayer_address"` | ||
} | ||
|
||
// GetContractsResponse contains the schema for a GET /contract response. | ||
// GetContractsResponse contains the schema for a GET /contracts response. | ||
type GetContractsResponse struct { | ||
// Contracts is a map of chain id to contract address | ||
Contracts map[uint32]string `json:"contracts"` | ||
// ContractsV1 is a map of chain id to contract address for v1 fast bridge contracts | ||
ContractsV1 map[uint32]string `json:"contracts_v1"` | ||
// ContractsV2 is a map of chain id to contract address for v2 fast bridge contracts | ||
ContractsV2 map[uint32]string `json:"contracts_v2"` | ||
Comment on lines
+44
to
+49
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 💡 Codebase verification Breaking change confirmed: Multiple impacted components require updates The breaking change impacts several components that need to be updated:
🔗 Analysis chainBreaking Change: GetContractsResponse structure has been modified The separation of contracts into V1 and V2 maps is a breaking change that will require updates from API consumers. Ensure this change is properly documented in the API changelog and communicated to consumers. Let's verify if there are any direct API consumers that need to be updated: 🏁 Scripts executedThe following scripts were executed for the analysis: Script: #!/bin/bash
# Search for direct usage of the GetContractsResponse struct
rg -l "GetContractsResponse" | grep -v "response.go"
Length of output: 281 Script: #!/bin/bash
# Let's check the usage of GetContractsResponse in these files to understand the impact
echo "=== Checking client.go ==="
rg -A 5 "GetContractsResponse" services/rfq/api/client/client.go
echo -e "\n=== Checking handler.go ==="
rg -A 5 "GetContractsResponse" services/rfq/api/rest/handler.go
echo -e "\n=== Checking client.gen.go ==="
rg -A 5 "GetContractsResponse" contrib/restclient/client.gen.go
Length of output: 3607 |
||
} | ||
|
||
// ActiveRFQMessage represents the general structure of WebSocket messages for Active RFQ. | ||
|
Original file line number | Diff line number | Diff line change | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
@@ -6,6 +6,7 @@ import ( | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
"strconv" | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
"time" | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
"github.com/ethereum/go-ethereum/common" | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
"github.com/synapsecns/sanguine/services/rfq/api/config" | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
"github.com/gin-gonic/gin" | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
@@ -69,7 +70,7 @@ func (h *Handler) ModifyQuote(c *gin.Context) { | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
return | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
dbQuote, err := parseDBQuote(*putRequest, relayerAddr) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
dbQuote, err := parseDBQuote(h.cfg, *putRequest, relayerAddr) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
if err != nil { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()}) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
return | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
@@ -117,7 +118,7 @@ func (h *Handler) ModifyBulkQuotes(c *gin.Context) { | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
dbQuotes := []*db.Quote{} | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
for _, quoteReq := range putRequest.Quotes { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
dbQuote, err := parseDBQuote(quoteReq, relayerAddr) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
dbQuote, err := parseDBQuote(h.cfg, quoteReq, relayerAddr) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
if err != nil { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
c.JSON(http.StatusBadRequest, gin.H{"error": "Invalid quote request"}) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
return | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
@@ -134,7 +135,7 @@ func (h *Handler) ModifyBulkQuotes(c *gin.Context) { | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
//nolint:gosec | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
func parseDBQuote(putRequest model.PutRelayerQuoteRequest, relayerAddr interface{}) (*db.Quote, error) { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
func parseDBQuote(cfg config.Config, putRequest model.PutRelayerQuoteRequest, relayerAddr interface{}) (*db.Quote, error) { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
destAmount, err := decimal.NewFromString(putRequest.DestAmount) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
if err != nil { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
return nil, fmt.Errorf("invalid DestAmount") | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
@@ -147,6 +148,12 @@ func parseDBQuote(putRequest model.PutRelayerQuoteRequest, relayerAddr interface | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
if err != nil { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
return nil, fmt.Errorf("invalid FixedFee") | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
err = validateFastBridgeAddresses(cfg, putRequest) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
if err != nil { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
return nil, fmt.Errorf("invalid fast bridge addresses: %w", err) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
// nolint: forcetypeassert | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
return &db.Quote{ | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
OriginChainID: uint64(putRequest.OriginChainID), | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
@@ -163,6 +170,24 @@ func parseDBQuote(putRequest model.PutRelayerQuoteRequest, relayerAddr interface | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
}, nil | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
//nolint:gosec | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
func validateFastBridgeAddresses(cfg config.Config, putRequest model.PutRelayerQuoteRequest) error { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
// Check V1 contracts | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
isV1Origin := common.HexToAddress(cfg.FastBridgeContractsV1[uint32(putRequest.OriginChainID)]) == common.HexToAddress(putRequest.OriginFastBridgeAddress) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
isV1Dest := common.HexToAddress(cfg.FastBridgeContractsV1[uint32(putRequest.DestChainID)]) == common.HexToAddress(putRequest.DestFastBridgeAddress) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
// Check V2 contracts | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
isV2Origin := common.HexToAddress(cfg.FastBridgeContractsV2[uint32(putRequest.OriginChainID)]) == common.HexToAddress(putRequest.OriginFastBridgeAddress) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
isV2Dest := common.HexToAddress(cfg.FastBridgeContractsV2[uint32(putRequest.DestChainID)]) == common.HexToAddress(putRequest.DestFastBridgeAddress) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
// Valid if both addresses match either V1 or V2 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
if (isV1Origin && isV1Dest) || (isV2Origin && isV2Dest) { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
return nil | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
return fmt.Errorf("origin and destination fast bridge addresses must match either V1 or V2") | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Comment on lines
+173
to
+189
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Add zero address validation and improve error messages While the contract version validation is good, consider these improvements:
Here's the suggested implementation: func validateFastBridgeAddresses(cfg config.Config, putRequest model.PutRelayerQuoteRequest) error {
+ // Validate non-zero addresses
+ if common.HexToAddress(putRequest.OriginFastBridgeAddress) == common.Address{} ||
+ common.HexToAddress(putRequest.DestFastBridgeAddress) == common.Address{} {
+ return fmt.Errorf("fast bridge addresses cannot be zero")
+ }
+
// Check V1 contracts
isV1Origin := common.HexToAddress(cfg.FastBridgeContractsV1[uint32(putRequest.OriginChainID)]) == common.HexToAddress(putRequest.OriginFastBridgeAddress)
isV1Dest := common.HexToAddress(cfg.FastBridgeContractsV1[uint32(putRequest.DestChainID)]) == common.HexToAddress(putRequest.DestFastBridgeAddress)
// Check V2 contracts
isV2Origin := common.HexToAddress(cfg.FastBridgeContractsV2[uint32(putRequest.OriginChainID)]) == common.HexToAddress(putRequest.OriginFastBridgeAddress)
isV2Dest := common.HexToAddress(cfg.FastBridgeContractsV2[uint32(putRequest.DestChainID)]) == common.HexToAddress(putRequest.DestFastBridgeAddress)
// Valid if both addresses match either V1 or V2
if (isV1Origin && isV1Dest) || (isV2Origin && isV2Dest) {
return nil
}
- return fmt.Errorf("origin and destination fast bridge addresses must match either V1 or V2")
+ return fmt.Errorf("mismatched fast bridge versions: origin=%s, destination=%s",
+ putRequest.OriginFastBridgeAddress, putRequest.DestFastBridgeAddress)
} 📝 Committable suggestion
Suggested change
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
//nolint:gosec | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
func quoteResponseFromDBQuote(dbQuote *db.Quote) *model.GetQuoteResponse { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
return &model.GetQuoteResponse{ | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
@@ -301,12 +326,10 @@ func dbActiveQuoteRequestToModel(dbQuote *db.ActiveQuoteRequest) *model.GetOpenQ | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
// @Header 200 {string} X-Api-Version "API Version Number - See docs for more info" | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
// @Router /contracts [get]. | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
func (h *Handler) GetContracts(c *gin.Context) { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
// Convert quotes from db model to api model | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
contracts := make(map[uint32]string) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
for chainID, address := range h.cfg.Bridges { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
contracts[chainID] = address | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
c.JSON(http.StatusOK, model.GetContractsResponse{Contracts: contracts}) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
c.JSON(http.StatusOK, model.GetContractsResponse{ | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
ContractsV1: h.cfg.FastBridgeContractsV1, | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
ContractsV2: h.cfg.FastBridgeContractsV2, | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
}) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
func filterQuoteAge(cfg config.Config, dbQuotes []*db.Quote) []*db.Quote { | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -20,6 +20,7 @@ import ( | |
const collectionTimeout = 1 * time.Minute | ||
|
||
func (r *QuoterAPIServer) handleActiveRFQ(ctx context.Context, request *model.PutRFQRequest, requestID string) (quote *model.QuoteData) { | ||
fmt.Printf("handleActiveRFQ with request data: %+v\n", request.Data) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Use structured logging consistently Debug logging should use the application's logger with appropriate log levels and structured fields. - fmt.Printf("handleActiveRFQ with request data: %+v\n", request.Data)
+ logger.Debug("Handling active RFQ request",
+ "request_id", requestID,
+ "origin_chain_id", request.Data.OriginChainID,
+ "dest_chain_id", request.Data.DestChainID)
// ... existing code ...
- fmt.Printf("parsed websocket request: %+v\n", relayerReq.Data)
+ logger.Debug("Parsed websocket request",
+ "request_id", relayerReq.RequestID,
+ "origin_chain_id", relayerReq.Data.OriginChainID,
+ "dest_chain_id", relayerReq.Data.DestChainID) Also applies to: 34-34 |
||
ctx, span := r.handler.Tracer().Start(ctx, "handleActiveRFQ", trace.WithAttributes( | ||
attribute.String("user_address", request.UserAddress), | ||
attribute.String("request_id", requestID), | ||
|
@@ -30,16 +31,20 @@ func (r *QuoterAPIServer) handleActiveRFQ(ctx context.Context, request *model.Pu | |
|
||
// publish the quote request to all connected clients | ||
relayerReq := model.NewWsRFQRequest(request.Data, requestID) | ||
fmt.Printf("parsed websocket request: %+v\n", relayerReq.Data) | ||
r.wsClients.Range(func(relayerAddr string, client WsClient) bool { | ||
fmt.Printf("sending quote request to client with address %v: %v\n", relayerAddr, client) | ||
sendCtx, sendSpan := r.handler.Tracer().Start(ctx, "sendQuoteRequest", trace.WithAttributes( | ||
attribute.String("relayer_address", relayerAddr), | ||
attribute.String("request_id", requestID), | ||
)) | ||
defer metrics.EndSpan(sendSpan) | ||
|
||
subscribed := r.pubSubManager.IsSubscribed(relayerAddr, request.Data.OriginChainID, request.Data.DestChainID) | ||
fmt.Printf("relayer %v subscribed: %v\n", relayerAddr, subscribed) | ||
span.SetAttributes(attribute.Bool("subscribed", subscribed)) | ||
if subscribed { | ||
fmt.Printf("sending request to relayer %v: %+v\n", relayerAddr, relayerReq) | ||
err := client.SendQuoteRequest(sendCtx, relayerReq) | ||
if err != nil { | ||
logger.Errorf("Error sending quote request to %s: %v", relayerAddr, err) | ||
|
@@ -55,10 +60,12 @@ func (r *QuoterAPIServer) handleActiveRFQ(ctx context.Context, request *model.Pu | |
// collect the responses and determine the best quote | ||
responses := r.collectRelayerResponses(ctx, request, requestID) | ||
for r, resp := range responses { | ||
fmt.Printf("considering response: %+v\n", resp) | ||
relayerAddr := r | ||
quote = getBestQuote(quote, getRelayerQuoteData(request, resp)) | ||
quote.RelayerAddress = &relayerAddr | ||
} | ||
fmt.Printf("best quote: %+v\n", quote) | ||
err = r.recordActiveQuote(ctx, quote, requestID) | ||
if err != nil { | ||
logger.Errorf("Error recording active quote: %v", err) | ||
|
@@ -68,6 +75,7 @@ func (r *QuoterAPIServer) handleActiveRFQ(ctx context.Context, request *model.Pu | |
} | ||
|
||
func (r *QuoterAPIServer) collectRelayerResponses(ctx context.Context, request *model.PutRFQRequest, requestID string) (responses map[string]*model.WsRFQResponse) { | ||
fmt.Printf("collectRelayerResponses with request data: %+v\n", request.Data) | ||
ctx, span := r.handler.Tracer().Start(ctx, "collectRelayerResponses", trace.WithAttributes( | ||
attribute.String("user_address", request.UserAddress), | ||
attribute.String("request_id", requestID), | ||
|
@@ -85,6 +93,7 @@ func (r *QuoterAPIServer) collectRelayerResponses(ctx context.Context, request * | |
respMux := sync.Mutex{} | ||
responses = map[string]*model.WsRFQResponse{} | ||
r.wsClients.Range(func(relayerAddr string, client WsClient) bool { | ||
fmt.Printf("processing ws client with addr: %v: client: %v\n", relayerAddr, client) | ||
wg.Add(1) | ||
go func(client WsClient) { | ||
var respStatus db.ActiveQuoteResponseStatus | ||
|
@@ -100,6 +109,7 @@ func (r *QuoterAPIServer) collectRelayerResponses(ctx context.Context, request * | |
|
||
defer wg.Done() | ||
resp, err := client.ReceiveQuoteResponse(collectionCtx, requestID) | ||
fmt.Printf("recved quote resp: %+v\n", resp) | ||
if err != nil { | ||
logger.Errorf("Error receiving quote response: %v", err) | ||
return | ||
|
@@ -119,6 +129,7 @@ func (r *QuoterAPIServer) collectRelayerResponses(ctx context.Context, request * | |
} | ||
|
||
// record the response | ||
fmt.Printf("recording resp: %+v\n", resp) | ||
err = r.db.InsertActiveQuoteResponse(collectionCtx, resp, relayerAddr, respStatus) | ||
if err != nil { | ||
logger.Errorf("Error inserting active quote response: %v", err) | ||
|
@@ -130,6 +141,7 @@ func (r *QuoterAPIServer) collectRelayerResponses(ctx context.Context, request * | |
// wait for all responses to be received, or expiration | ||
select { | ||
case <-expireCtx.Done(): | ||
fmt.Println("request expired") | ||
// request expired before all responses were received | ||
case <-func() chan struct{} { | ||
ch := make(chan struct{}) | ||
|
@@ -142,6 +154,9 @@ func (r *QuoterAPIServer) collectRelayerResponses(ctx context.Context, request * | |
// all responses received | ||
} | ||
|
||
fmt.Printf("responses received: %+v\n", responses) | ||
fmt.Printf("num responses: %v\n", len(responses)) | ||
|
||
return responses | ||
} | ||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
TODO comment needs to be addressed before merging
The TODO comment indicates that v2 contract handling is missing, which is a critical component given that this PR is titled "support FastBridgeV2". This functionality should be implemented before merging.
Would you like me to help implement the v2 contract handling logic?