From ced08197cfcad2f3048f7c4f5acdc7af2c9ab190 Mon Sep 17 00:00:00 2001 From: Matt Johnstone Date: Wed, 2 Oct 2024 14:56:38 +0200 Subject: [PATCH] refactored GetVoteAccounts --- cmd/solana_exporter/exporter.go | 7 +----- cmd/solana_exporter/exporter_test.go | 8 +++++-- pkg/rpc/client.go | 36 +++++++++++++++++----------- 3 files changed, 29 insertions(+), 22 deletions(-) diff --git a/cmd/solana_exporter/exporter.go b/cmd/solana_exporter/exporter.go index 343b010..f2fae3d 100644 --- a/cmd/solana_exporter/exporter.go +++ b/cmd/solana_exporter/exporter.go @@ -114,12 +114,7 @@ func (c *solanaCollector) Describe(ch chan<- *prometheus.Desc) { } func (c *solanaCollector) collectVoteAccounts(ctx context.Context, ch chan<- prometheus.Metric) { - params := map[string]string{"commitment": string(rpc.CommitmentProcessed)} - if *votePubkey != "" { - params = map[string]string{"commitment": string(rpc.CommitmentProcessed), "votePubkey": *votePubkey} - } - - voteAccounts, err := c.rpcClient.GetVoteAccounts(ctx, []interface{}{params}) + voteAccounts, err := c.rpcClient.GetVoteAccounts(ctx, rpc.CommitmentProcessed, votePubkey) if err != nil { ch <- prometheus.NewInvalidMetric(c.totalValidatorsDesc, err) ch <- prometheus.NewInvalidMetric(c.validatorActivatedStake, err) diff --git a/cmd/solana_exporter/exporter_test.go b/cmd/solana_exporter/exporter_test.go index 4f7ad58..df11fb9 100644 --- a/cmd/solana_exporter/exporter_test.go +++ b/cmd/solana_exporter/exporter_test.go @@ -129,7 +129,9 @@ func (c *staticRPCClient) GetVersion(ctx context.Context) (string, error) { } //goland:noinspection GoUnusedParameter -func (c *staticRPCClient) GetVoteAccounts(ctx context.Context, params []interface{}) (*rpc.VoteAccounts, error) { +func (c *staticRPCClient) GetVoteAccounts( + ctx context.Context, commitment rpc.Commitment, votePubkey *string, +) (*rpc.VoteAccounts, error) { return &staticVoteAccounts, nil } @@ -266,7 +268,9 @@ func (c *dynamicRPCClient) GetVersion(ctx context.Context) (string, error) { } //goland:noinspection GoUnusedParameter -func (c *dynamicRPCClient) GetVoteAccounts(ctx context.Context, params []interface{}) (*rpc.VoteAccounts, error) { +func (c *dynamicRPCClient) GetVoteAccounts( + ctx context.Context, commitment rpc.Commitment, votePubkey *string, +) (*rpc.VoteAccounts, error) { var currentVoteAccounts, delinquentVoteAccounts []rpc.VoteAccount for identity, vote := range identityVotes { info := c.ValidatorInfos[identity] diff --git a/pkg/rpc/client.go b/pkg/rpc/client.go index df65b4d..5ad6c5d 100644 --- a/pkg/rpc/client.go +++ b/pkg/rpc/client.go @@ -22,10 +22,10 @@ type ( } rpcRequest struct { - Version string `json:"jsonrpc"` - ID int `json:"id"` - Method string `json:"method"` - Params []interface{} `json:"params"` + Version string `json:"jsonrpc"` + ID int `json:"id"` + Method string `json:"method"` + Params []any `json:"params"` } Commitment string @@ -56,7 +56,7 @@ type Provider interface { // The method takes a context for cancellation and a slice of parameters to filter the vote accounts. // It returns a pointer to a VoteAccounts struct containing the vote accounts details, // or an error if the operation fails. - GetVoteAccounts(ctx context.Context, params []interface{}) (*VoteAccounts, error) + GetVoteAccounts(ctx context.Context, commitment Commitment, votePubkey *string) (*VoteAccounts, error) // GetVersion retrieves the version of the Solana node. // The method takes a context for cancellation. @@ -87,7 +87,7 @@ func NewRPCClient(rpcAddr string) *Client { return &Client{httpClient: http.Client{}, rpcAddr: rpcAddr} } -func (c *Client) getResponse(ctx context.Context, method string, params []interface{}, result HasRPCError) error { +func (c *Client) getResponse(ctx context.Context, method string, params []any, result HasRPCError) error { // format request: request := &rpcRequest{Version: "2.0", ID: 1, Method: method, Params: params} buffer, err := json.Marshal(request) @@ -132,15 +132,23 @@ func (c *Client) getResponse(ctx context.Context, method string, params []interf func (c *Client) GetEpochInfo(ctx context.Context, commitment Commitment) (*EpochInfo, error) { var resp response[EpochInfo] - if err := c.getResponse(ctx, "getEpochInfo", []interface{}{commitment}, &resp); err != nil { + if err := c.getResponse(ctx, "getEpochInfo", []any{commitment}, &resp); err != nil { return nil, err } return &resp.Result, nil } -func (c *Client) GetVoteAccounts(ctx context.Context, params []interface{}) (*VoteAccounts, error) { +func (c *Client) GetVoteAccounts( + ctx context.Context, commitment Commitment, votePubkey *string, +) (*VoteAccounts, error) { + // format params: + config := map[string]string{"commitment": string(commitment)} + if votePubkey != nil { + config["votePubkey"] = *votePubkey + } + var resp response[VoteAccounts] - if err := c.getResponse(ctx, "getVoteAccounts", params, &resp); err != nil { + if err := c.getResponse(ctx, "getVoteAccounts", []any{config}, &resp); err != nil { return nil, err } return &resp.Result, nil @@ -150,7 +158,7 @@ func (c *Client) GetVersion(ctx context.Context) (string, error) { var resp response[struct { Version string `json:"solana-core"` }] - if err := c.getResponse(ctx, "getVersion", []interface{}{}, &resp); err != nil { + if err := c.getResponse(ctx, "getVersion", []any{}, &resp); err != nil { return "", err } return resp.Result.Version, nil @@ -158,7 +166,7 @@ func (c *Client) GetVersion(ctx context.Context) (string, error) { func (c *Client) GetSlot(ctx context.Context) (int64, error) { var resp response[int64] - if err := c.getResponse(ctx, "getSlot", []interface{}{}, &resp); err != nil { + if err := c.getResponse(ctx, "getSlot", []any{}, &resp); err != nil { return 0, err } return resp.Result, nil @@ -173,7 +181,7 @@ func (c *Client) GetBlockProduction( } // format params: - config := make(map[string]interface{}) + config := make(map[string]any) if identity != nil { config["identity"] = *identity } @@ -185,7 +193,7 @@ func (c *Client) GetBlockProduction( config["range"] = blockRange } - var params []interface{} + var params []any if len(config) > 0 { params = append(params, config) } @@ -200,7 +208,7 @@ func (c *Client) GetBlockProduction( func (c *Client) GetBalance(ctx context.Context, address string) (float64, error) { var resp response[contextualResult[int64]] - if err := c.getResponse(ctx, "getBalance", []interface{}{address}, &resp); err != nil { + if err := c.getResponse(ctx, "getBalance", []any{address}, &resp); err != nil { return 0, err } return float64(resp.Result.Value / 1_000_000_000), nil