mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-11-24 06:25:55 +00:00
finish handlers
This commit is contained in:
parent
e8e57fc2be
commit
4c9aa952cb
@ -36,7 +36,7 @@ func HandleGetAcceptingBlockHashesOfTxs(context *rpccontext.Context, _ *router.R
|
|||||||
if !errors.As(err, &rpcError) {
|
if !errors.As(err, &rpcError) {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
errorMessage := &appmessage.GetUTXOsByAddressesResponseMessage{}
|
errorMessage := &appmessage.GetAcceptingBlockHashesOfTxsResponseMessage{}
|
||||||
errorMessage.Error = rpcError
|
errorMessage.Error = rpcError
|
||||||
return errorMessage, nil
|
return errorMessage, nil
|
||||||
}
|
}
|
||||||
|
|||||||
@ -37,7 +37,7 @@ func HandleGetAcceptingBlocksOfTx(context *rpccontext.Context, _ *router.Router,
|
|||||||
if !errors.As(err, &rpcError) {
|
if !errors.As(err, &rpcError) {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
errorMessage := &appmessage.GetUTXOsByAddressesResponseMessage{}
|
errorMessage := &appmessage.GetAcceptingBlocksOfTxsResponseMessage{}
|
||||||
errorMessage.Error = rpcError
|
errorMessage.Error = rpcError
|
||||||
return errorMessage, nil
|
return errorMessage, nil
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,12 +1,81 @@
|
|||||||
package rpchandlers
|
package rpchandlers
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
|
|
||||||
"github.com/kaspanet/kaspad/app/appmessage"
|
"github.com/kaspanet/kaspad/app/appmessage"
|
||||||
"github.com/kaspanet/kaspad/app/rpc/rpccontext"
|
"github.com/kaspanet/kaspad/app/rpc/rpccontext"
|
||||||
|
"github.com/kaspanet/kaspad/domain/consensus/model/externalapi"
|
||||||
|
"github.com/kaspanet/kaspad/domain/consensus/utils/consensushashing"
|
||||||
"github.com/kaspanet/kaspad/infrastructure/network/netadapter/router"
|
"github.com/kaspanet/kaspad/infrastructure/network/netadapter/router"
|
||||||
)
|
)
|
||||||
|
|
||||||
// HandleGetTxs handles the respectively named RPC command
|
// HandleGetTxs handles the respectively named RPC command
|
||||||
func HandleGetTxs(context *rpccontext.Context, _ *router.Router, request appmessage.Message) (appmessage.Message, error) {
|
func HandleGetTxs(context *rpccontext.Context, _ *router.Router, request appmessage.Message) (appmessage.Message, error) {
|
||||||
return nil, nil
|
var err error
|
||||||
|
|
||||||
|
if !context.Config.TXIndex {
|
||||||
|
errorMessage := &appmessage.GetTxsResponseMessage{}
|
||||||
|
errorMessage.Error = appmessage.RPCErrorf("Method unavailable when kaspad is run without --txindex")
|
||||||
|
return errorMessage, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
getTxsRequest := request.(*appmessage.GetTxsRequestMessage)
|
||||||
|
|
||||||
|
domainTxIDs := make([]*externalapi.DomainTransactionID, len(getTxsRequest.TxIDs))
|
||||||
|
|
||||||
|
for i := range domainTxIDs {
|
||||||
|
domainTxIDs[i], err = externalapi.NewDomainTransactionIDFromString(getTxsRequest.TxIDs[i])
|
||||||
|
if err != nil {
|
||||||
|
errorMessage := &appmessage.GetTxsConfirmationsResponseMessage{}
|
||||||
|
errorMessage.Error = appmessage.RPCErrorf("error parsing txID: %s", getTxsRequest.TxIDs[i])
|
||||||
|
return errorMessage, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
transactions, _, err := context.TXIndex.GetTXs(domainTxIDs)
|
||||||
|
if err != nil {
|
||||||
|
rpcError := &appmessage.RPCError{}
|
||||||
|
if !errors.As(err, &rpcError) {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
errorMessage := &appmessage.GetTxsResponseMessage{}
|
||||||
|
errorMessage.Error = rpcError
|
||||||
|
return errorMessage, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
rpcTransactions := make([]*appmessage.RPCTransaction, len(transactions))
|
||||||
|
|
||||||
|
for i := range transactions {
|
||||||
|
rpcTransactions[i] = appmessage.DomainTransactionToRPCTransaction(transactions[i])
|
||||||
|
blockForVerboseData, found, err := context.TXIndex.TXAcceptingBlock(consensushashing.TransactionID(transactions[i]))
|
||||||
|
if err != nil {
|
||||||
|
rpcError := &appmessage.RPCError{}
|
||||||
|
if !errors.As(err, &rpcError) {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
errorMessage := &appmessage.GetTxsResponseMessage{}
|
||||||
|
errorMessage.Error = rpcError
|
||||||
|
return errorMessage, nil
|
||||||
|
}
|
||||||
|
if !found {
|
||||||
|
errorMessage := &appmessage.GetTxsResponseMessage{}
|
||||||
|
errorMessage.Error = appmessage.RPCErrorf("Could not find accepting block in the txindex database for txID: %s", consensushashing.TransactionID(transactions[i]).String())
|
||||||
|
return errorMessage, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
err = context.PopulateTransactionWithVerboseData(rpcTransactions[i], blockForVerboseData.Header)
|
||||||
|
if err != nil {
|
||||||
|
if errors.Is(err, rpccontext.ErrBuildBlockVerboseDataInvalidBlock) {
|
||||||
|
errorMessage := &appmessage.GetTxsResponseMessage{}
|
||||||
|
errorMessage.Error = appmessage.RPCErrorf("Block %s is invalid", consensushashing.BlockHash(blockForVerboseData).String())
|
||||||
|
return errorMessage, nil
|
||||||
|
}
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
response := appmessage.NewGetTxsResponse(rpcTransactions)
|
||||||
|
|
||||||
|
return response, nil
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,12 +1,60 @@
|
|||||||
package rpchandlers
|
package rpchandlers
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
|
|
||||||
"github.com/kaspanet/kaspad/app/appmessage"
|
"github.com/kaspanet/kaspad/app/appmessage"
|
||||||
"github.com/kaspanet/kaspad/app/rpc/rpccontext"
|
"github.com/kaspanet/kaspad/app/rpc/rpccontext"
|
||||||
|
"github.com/kaspanet/kaspad/domain/consensus/model/externalapi"
|
||||||
"github.com/kaspanet/kaspad/infrastructure/network/netadapter/router"
|
"github.com/kaspanet/kaspad/infrastructure/network/netadapter/router"
|
||||||
)
|
)
|
||||||
|
|
||||||
// HandleGetTxsConfirmations handles the respectively named RPC command
|
// HandleGetTxsConfirmations handles the respectively named RPC command
|
||||||
func HandleGetTxsConfirmations(context *rpccontext.Context, _ *router.Router, request appmessage.Message) (appmessage.Message, error) {
|
func HandleGetTxsConfirmations(context *rpccontext.Context, _ *router.Router, request appmessage.Message) (appmessage.Message, error) {
|
||||||
return nil, nil
|
var err error
|
||||||
|
|
||||||
|
if !context.Config.TXIndex {
|
||||||
|
errorMessage := &appmessage.GetTxsConfirmationsResponseMessage{}
|
||||||
|
errorMessage.Error = appmessage.RPCErrorf("Method unavailable when kaspad is run without --txindex")
|
||||||
|
return errorMessage, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
getTxsConfirmationsRequest := request.(*appmessage.GetTxsConfirmationsRequestMessage)
|
||||||
|
|
||||||
|
domainTxIDs := make([]*externalapi.DomainTransactionID, len(getTxsConfirmationsRequest.TxIDs))
|
||||||
|
|
||||||
|
for i := range domainTxIDs {
|
||||||
|
domainTxIDs[i], err = externalapi.NewDomainTransactionIDFromString(getTxsConfirmationsRequest.TxIDs[i])
|
||||||
|
if err != nil {
|
||||||
|
errorMessage := &appmessage.GetTxsConfirmationsResponseMessage{}
|
||||||
|
errorMessage.Error = appmessage.RPCErrorf("error parsing txID: %s", getTxsConfirmationsRequest.TxIDs[i])
|
||||||
|
return errorMessage, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
txIDsToConfirmations, _, err := context.TXIndex.GetTXsConfirmations(domainTxIDs)
|
||||||
|
if err != nil {
|
||||||
|
rpcError := &appmessage.RPCError{}
|
||||||
|
if !errors.As(err, &rpcError) {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
errorMessage := &appmessage.GetTxsConfirmationsResponseMessage{}
|
||||||
|
errorMessage.Error = rpcError
|
||||||
|
return errorMessage, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
txIDConfirmationPairs := make([]*appmessage.TxIDConfirmationsPair, len(txIDsToConfirmations))
|
||||||
|
|
||||||
|
i := 0
|
||||||
|
for txID, Confirmations := range txIDsToConfirmations {
|
||||||
|
txIDConfirmationPairs[i] = &appmessage.TxIDConfirmationsPair{
|
||||||
|
TxID: txID.String(),
|
||||||
|
Confirmations: Confirmations,
|
||||||
|
}
|
||||||
|
i++
|
||||||
|
}
|
||||||
|
|
||||||
|
response := appmessage.NewGetTxsConfirmationsResponse(txIDConfirmationPairs)
|
||||||
|
|
||||||
|
return response, nil
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user