mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-19 00:54:12 +00:00
212 lines
7.4 KiB
Go
212 lines
7.4 KiB
Go
package graph
|
|
|
|
// This file will be automatically regenerated based on the schema, any resolver implementations
|
|
// will be copied through when generating and any unknown code will be moved to the end.
|
|
// Code generated by github.com/99designs/gqlgen version v0.17.26
|
|
|
|
import (
|
|
"context"
|
|
"encoding/hex"
|
|
"fmt"
|
|
"strconv"
|
|
"strings"
|
|
|
|
"github.com/ledgerwatch/erigon/cmd/rpcdaemon/graphql/graph/model"
|
|
"github.com/ledgerwatch/erigon/common/hexutil"
|
|
"github.com/ledgerwatch/erigon/core/types"
|
|
"github.com/ledgerwatch/erigon/rpc"
|
|
)
|
|
|
|
// SendRawTransaction is the resolver for the sendRawTransaction field.
|
|
func (r *mutationResolver) SendRawTransaction(ctx context.Context, data string) (string, error) {
|
|
panic(fmt.Errorf("not implemented: SendRawTransaction - sendRawTransaction"))
|
|
}
|
|
|
|
// Block is the resolver for the block field.
|
|
func (r *queryResolver) Block(ctx context.Context, number *string, hash *string) (*model.Block, error) {
|
|
var blockNumber rpc.BlockNumber
|
|
|
|
if number != nil {
|
|
// Block number is not null, test for a positive long integer
|
|
bNum, err := strconv.ParseUint(*number, 10, 64)
|
|
if err == nil {
|
|
// Positive integer, go ahead
|
|
blockNumber = rpc.BlockNumber(bNum)
|
|
} else {
|
|
bNum, err := hexutil.DecodeUint64(*number)
|
|
if err == nil {
|
|
// Hexadecimal, 0x prefixed
|
|
blockNumber = rpc.BlockNumber(bNum)
|
|
} else {
|
|
var err error
|
|
return nil, err
|
|
}
|
|
}
|
|
} else {
|
|
if hash != nil {
|
|
blockHash, _ := hexutil.DecodeBig(*hash)
|
|
fmt.Println("TODO/GraphQL/Implement me, get Block by hash=", blockHash)
|
|
hash = nil
|
|
}
|
|
}
|
|
|
|
if number == nil && hash == nil {
|
|
// If neither number or hash is specified (nil), we should deliver "latest" block
|
|
/*
|
|
rpc.LatestExecutedBlockNumber = BlockNumber(-5)
|
|
rpc.FinalizedBlockNumber = BlockNumber(-4)
|
|
rpc.SafeBlockNumber = BlockNumber(-3)
|
|
rpc.PendingBlockNumber = BlockNumber(-2)
|
|
rpc.LatestBlockNumber = BlockNumber(-1)
|
|
*/
|
|
blockNumber = rpc.LatestBlockNumber
|
|
}
|
|
|
|
res, err := r.GraphQLAPI.GetBlockDetails(ctx, blockNumber)
|
|
if err != nil {
|
|
fmt.Println(err)
|
|
return nil, err
|
|
}
|
|
|
|
block := &model.Block{}
|
|
absBlk := res["block"]
|
|
|
|
if absBlk != nil {
|
|
blk := absBlk.(map[string]interface{})
|
|
|
|
block.Difficulty = *convertDataToStringP(blk, "difficulty")
|
|
block.ExtraData = *convertDataToStringP(blk, "extraData")
|
|
block.GasLimit = uint64(*convertDataToUint64P(blk, "gasLimit"))
|
|
block.GasUsed = *convertDataToUint64P(blk, "gasUsed")
|
|
block.Hash = *convertDataToStringP(blk, "hash")
|
|
block.Miner = &model.Account{}
|
|
address := convertDataToStringP(blk, "miner")
|
|
if address != nil {
|
|
block.Miner.Address = strings.ToLower(*address)
|
|
}
|
|
mixHash := convertDataToStringP(blk, "mixHash")
|
|
if mixHash != nil {
|
|
block.MixHash = *mixHash
|
|
}
|
|
blockNonce := convertDataToStringP(blk, "nonce")
|
|
if blockNonce != nil {
|
|
block.Nonce = *blockNonce
|
|
}
|
|
block.Number = *convertDataToUint64P(blk, "number")
|
|
block.Ommers = []*model.Block{}
|
|
block.Parent = &model.Block{}
|
|
block.Parent.Hash = *convertDataToStringP(blk, "parentHash")
|
|
block.ReceiptsRoot = *convertDataToStringP(blk, "receiptsRoot")
|
|
block.StateRoot = *convertDataToStringP(blk, "stateRoot")
|
|
block.Timestamp = *convertDataToStringP(blk, "timestamp")
|
|
block.TransactionCount = convertDataToIntP(blk, "transactionCount")
|
|
block.TransactionsRoot = *convertDataToStringP(blk, "transactionsRoot")
|
|
block.TotalDifficulty = *convertDataToStringP(blk, "totalDifficulty")
|
|
block.Transactions = []*model.Transaction{}
|
|
|
|
block.LogsBloom = "0x" + *convertDataToStringP(blk, "logsBloom")
|
|
block.OmmerHash = *convertDataToStringP(blk, "sha3Uncles")
|
|
|
|
absRcp := res["receipts"]
|
|
rcp := absRcp.([]map[string]interface{})
|
|
for _, transReceipt := range rcp {
|
|
trans := &model.Transaction{}
|
|
trans.CumulativeGasUsed = convertDataToUint64P(transReceipt, "cumulativeGasUsed")
|
|
trans.InputData = *convertDataToStringP(transReceipt, "data")
|
|
trans.EffectiveGasPrice = convertDataToStringP(transReceipt, "effectiveGasPrice")
|
|
trans.GasPrice = *convertDataToStringP(transReceipt, "effectiveGasPrice")
|
|
trans.GasUsed = convertDataToUint64P(transReceipt, "gasUsed")
|
|
trans.Hash = *convertDataToStringP(transReceipt, "transactionHash")
|
|
trans.Index = convertDataToIntP(transReceipt, "transactionIndex")
|
|
transNonce := convertDataToStringP(transReceipt, "nonce")
|
|
if transNonce != nil {
|
|
trans.Nonce = *transNonce
|
|
}
|
|
trans.Status = convertDataToUint64P(transReceipt, "status")
|
|
trans.Type = convertDataToIntP(transReceipt, "type")
|
|
trans.Value = *convertDataToStringP(transReceipt, "value")
|
|
|
|
trans.Logs = make([]*model.Log, 0)
|
|
for _, rlog := range transReceipt["logs"].(types.Logs) {
|
|
tlog := model.Log{
|
|
Index: int(rlog.Index),
|
|
Data: "0x" + hex.EncodeToString(rlog.Data),
|
|
}
|
|
tlog.Account = &model.Account{}
|
|
tlog.Account.Address = strings.ToLower(rlog.Address.String())
|
|
|
|
for _, rtopic := range rlog.Topics {
|
|
tlog.Topics = append(tlog.Topics, rtopic.String())
|
|
}
|
|
|
|
trans.Logs = append(trans.Logs, &tlog)
|
|
}
|
|
|
|
trans.From = &model.Account{}
|
|
trans.From.Address = strings.ToLower(*convertDataToStringP(transReceipt, "from"))
|
|
|
|
trans.To = &model.Account{}
|
|
address := convertDataToStringP(transReceipt, "to")
|
|
// To address could be nil in case of contract creation
|
|
if address != nil {
|
|
trans.To.Address = strings.ToLower(*convertDataToStringP(transReceipt, "to"))
|
|
}
|
|
|
|
block.Transactions = append(block.Transactions, trans)
|
|
}
|
|
}
|
|
|
|
return block, ctx.Err()
|
|
}
|
|
|
|
// Blocks is the resolver for the blocks field.
|
|
func (r *queryResolver) Blocks(ctx context.Context, from *uint64, to *uint64) ([]*model.Block, error) {
|
|
panic(fmt.Errorf("not implemented: Blocks - blocks"))
|
|
}
|
|
|
|
// Pending is the resolver for the pending field.
|
|
func (r *queryResolver) Pending(ctx context.Context) (*model.Pending, error) {
|
|
panic(fmt.Errorf("not implemented: Pending - pending"))
|
|
}
|
|
|
|
// Transaction is the resolver for the transaction field.
|
|
func (r *queryResolver) Transaction(ctx context.Context, hash string) (*model.Transaction, error) {
|
|
panic(fmt.Errorf("not implemented: Transaction - transaction"))
|
|
}
|
|
|
|
// Logs is the resolver for the logs field.
|
|
func (r *queryResolver) Logs(ctx context.Context, filter model.FilterCriteria) ([]*model.Log, error) {
|
|
panic(fmt.Errorf("not implemented: Logs - logs"))
|
|
}
|
|
|
|
// GasPrice is the resolver for the gasPrice field.
|
|
func (r *queryResolver) GasPrice(ctx context.Context) (string, error) {
|
|
panic(fmt.Errorf("not implemented: GasPrice - gasPrice"))
|
|
}
|
|
|
|
// MaxPriorityFeePerGas is the resolver for the maxPriorityFeePerGas field.
|
|
func (r *queryResolver) MaxPriorityFeePerGas(ctx context.Context) (string, error) {
|
|
panic(fmt.Errorf("not implemented: MaxPriorityFeePerGas - maxPriorityFeePerGas"))
|
|
}
|
|
|
|
// Syncing is the resolver for the syncing field.
|
|
func (r *queryResolver) Syncing(ctx context.Context) (*model.SyncState, error) {
|
|
panic(fmt.Errorf("not implemented: Syncing - syncing"))
|
|
}
|
|
|
|
// ChainID is the resolver for the chainID field.
|
|
func (r *queryResolver) ChainID(ctx context.Context) (string, error) {
|
|
chainID, err := r.GraphQLAPI.GetChainID(ctx)
|
|
|
|
return "0x" + strconv.FormatUint(chainID.Uint64(), 16), err
|
|
}
|
|
|
|
// Mutation returns MutationResolver implementation.
|
|
func (r *Resolver) Mutation() MutationResolver { return &mutationResolver{r} }
|
|
|
|
// Query returns QueryResolver implementation.
|
|
func (r *Resolver) Query() QueryResolver { return &queryResolver{r} }
|
|
|
|
type mutationResolver struct{ *Resolver }
|
|
type queryResolver struct{ *Resolver }
|