mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-09-13 13:00:10 +00:00

* Make kaspawallet ignore outputs that exist in the mempool * Make kaspawallet ignore outputs that exist in the mempool * Add comment
98 lines
3.3 KiB
Go
98 lines
3.3 KiB
Go
package rpchandlers
|
|
|
|
import (
|
|
"github.com/kaspanet/kaspad/app/appmessage"
|
|
"github.com/kaspanet/kaspad/app/rpc/rpccontext"
|
|
"github.com/kaspanet/kaspad/domain/consensus/utils/consensushashing"
|
|
"github.com/kaspanet/kaspad/domain/consensus/utils/txscript"
|
|
"github.com/kaspanet/kaspad/infrastructure/network/netadapter/router"
|
|
"github.com/kaspanet/kaspad/util"
|
|
)
|
|
|
|
// HandleGetMempoolEntriesByAddresses handles the respectively named RPC command
|
|
func HandleGetMempoolEntriesByAddresses(context *rpccontext.Context, _ *router.Router, request appmessage.Message) (appmessage.Message, error) {
|
|
|
|
transactions := context.Domain.MiningManager().AllTransactions()
|
|
getMempoolEntriesByAddressesRequest := request.(*appmessage.GetMempoolEntriesByAddressesRequestMessage)
|
|
mempoolEntriesByAddresses := make([]*appmessage.MempoolEntryByAddress, 0)
|
|
|
|
for _, addressString := range getMempoolEntriesByAddressesRequest.Addresses {
|
|
|
|
_, err := util.DecodeAddress(addressString, context.Config.ActiveNetParams.Prefix)
|
|
if err != nil {
|
|
errorMessage := &appmessage.GetUTXOsByAddressesResponseMessage{}
|
|
errorMessage.Error = appmessage.RPCErrorf("Could not decode address '%s': %s", addressString, err)
|
|
return errorMessage, nil
|
|
}
|
|
|
|
sending := make([]*appmessage.MempoolEntry, 0)
|
|
receiving := make([]*appmessage.MempoolEntry, 0)
|
|
|
|
for _, transaction := range transactions {
|
|
|
|
for i, input := range transaction.Inputs {
|
|
// TODO: Fix this
|
|
if input.UTXOEntry == nil {
|
|
log.Errorf("Couldn't find UTXO entry for input %d in mempool transaction %s. This is a bug and should be fixed.", i, consensushashing.TransactionID(transaction))
|
|
continue
|
|
}
|
|
|
|
_, transactionSendingAddress, err := txscript.ExtractScriptPubKeyAddress(
|
|
input.UTXOEntry.ScriptPublicKey(),
|
|
context.Config.ActiveNetParams)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if addressString == transactionSendingAddress.String() {
|
|
rpcTransaction := appmessage.DomainTransactionToRPCTransaction(transaction)
|
|
sending = append(
|
|
sending,
|
|
&appmessage.MempoolEntry{
|
|
Fee: transaction.Fee,
|
|
Transaction: rpcTransaction,
|
|
},
|
|
)
|
|
break //one input is enough
|
|
}
|
|
}
|
|
|
|
for _, output := range transaction.Outputs {
|
|
_, transactionReceivingAddress, err := txscript.ExtractScriptPubKeyAddress(
|
|
output.ScriptPublicKey,
|
|
context.Config.ActiveNetParams,
|
|
)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if addressString == transactionReceivingAddress.String() {
|
|
rpcTransaction := appmessage.DomainTransactionToRPCTransaction(transaction)
|
|
receiving = append(
|
|
receiving,
|
|
&appmessage.MempoolEntry{
|
|
Fee: transaction.Fee,
|
|
Transaction: rpcTransaction,
|
|
},
|
|
)
|
|
break //one output is enough
|
|
}
|
|
}
|
|
|
|
//Only append mempoolEntriesByAddress, if at least 1 mempoolEntry for the address is found.
|
|
//This mimics the behaviour of GetUtxosByAddresses RPC call.
|
|
if len(sending) > 0 || len(receiving) > 0 {
|
|
mempoolEntriesByAddresses = append(
|
|
mempoolEntriesByAddresses,
|
|
&appmessage.MempoolEntryByAddress{
|
|
Address: addressString,
|
|
Sending: sending,
|
|
Receiving: receiving,
|
|
},
|
|
)
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
return appmessage.NewGetMempoolEntriesByAddressesResponseMessage(mempoolEntriesByAddresses), nil
|
|
}
|