From a2550f73154ba5a1eeb1941318cf82082bc6c106 Mon Sep 17 00:00:00 2001 From: jkrvivian Date: Tue, 19 Sep 2023 15:19:50 +0800 Subject: [PATCH] Include OutputMetadata in output response --- components/inx/server_utxo.go | 98 +++++++++-------------------------- 1 file changed, 25 insertions(+), 73 deletions(-) diff --git a/components/inx/server_utxo.go b/components/inx/server_utxo.go index 45a9db64b..a043b31b1 100644 --- a/components/inx/server_utxo.go +++ b/components/inx/server_utxo.go @@ -15,7 +15,9 @@ import ( ) func NewLedgerOutput(o *utxoledger.Output) (*inx.LedgerOutput, error) { - return &inx.LedgerOutput{ + latestCommitment := deps.Protocol.MainEngineInstance().SyncManager.LatestCommitment() + + l := &inx.LedgerOutput{ OutputId: inx.NewOutputId(o.OutputID()), BlockId: inx.NewBlockId(o.BlockID()), SlotBooked: uint64(o.SlotBooked()), @@ -23,7 +25,18 @@ func NewLedgerOutput(o *utxoledger.Output) (*inx.LedgerOutput, error) { Output: &inx.RawOutput{ Data: o.Bytes(), }, - }, nil + } + + includedSlotIndex := o.SlotBooked() + if includedSlotIndex <= latestCommitment.Index() { + includedCommitment, err := deps.Protocol.MainEngineInstance().Storage.Commitments().Load(includedSlotIndex) + if err != nil { + return nil, ierrors.Wrapf(err, "failed to load commitment with index: %d", includedSlotIndex) + } + l.CommitmentIdIncluded = inx.NewCommitmentId(includedCommitment.ID()) + } + + return l, nil } func NewLedgerSpent(s *utxoledger.Spent) (*inx.LedgerSpent, error) { @@ -38,6 +51,16 @@ func NewLedgerSpent(s *utxoledger.Spent) (*inx.LedgerSpent, error) { SlotSpent: uint64(s.SlotIndexSpent()), } + latestCommitment := deps.Protocol.MainEngineInstance().SyncManager.LatestCommitment() + spentSlotIndex := s.SlotIndexSpent() + if spentSlotIndex <= latestCommitment.Index() { + spentCommitment, err := deps.Protocol.MainEngineInstance().Storage.Commitments().Load(spentSlotIndex) + if err != nil { + return nil, ierrors.Wrapf(err, "failed to load commitment with index: %d", spentSlotIndex) + } + l.CommitmentIdSpent = inx.NewCommitmentId(spentCommitment.ID()) + } + return l, nil } @@ -165,21 +188,6 @@ func (s *Server) ReadUnspentOutputs(_ *inx.NoParams, srv inx.INX_ReadUnspentOutp return err } -func (s *Server) ReadOutputMetadata(_ context.Context, id *inx.OutputId) (*inx.OutputMetadata, error) { - outputID := id.Unwrap() - - output, spent, err := deps.Protocol.MainEngineInstance().Ledger.OutputOrSpent(outputID) - if err != nil { - return nil, err - } - - if spent != nil { - return newSpentMetadataResponse(spent) - } - - return newOutputMetadataResponse(output) -} - func (s *Server) ListenToLedgerUpdates(req *inx.SlotRangeRequest, srv inx.INX_ListenToLedgerUpdatesServer) error { createLedgerUpdatePayloadAndSend := func(slot iotago.SlotIndex, outputs utxoledger.Outputs, spents utxoledger.Spents) error { // Send Begin @@ -331,59 +339,3 @@ func (s *Server) ListenToLedgerUpdates(req *inx.SlotRangeRequest, srv inx.INX_Li return innerErr } - -func newOutputMetadataResponse(output *utxoledger.Output) (*inx.OutputMetadata, error) { - latestCommitment := deps.Protocol.MainEngineInstance().SyncManager.LatestCommitment() - - metadata := &inx.OutputMetadata{ - BlockId: inx.NewBlockId(output.BlockID()), - TransactionId: inx.NewTransactionId(output.OutputID().TransactionID()), - OutputIndex: uint32(output.OutputID().Index()), - IsSpent: false, - LatestCommitmentId: inx.NewCommitmentId(latestCommitment.ID()), - } - - includedSlotIndex := output.SlotBooked() - if includedSlotIndex <= latestCommitment.Index() { - includedCommitment, err := deps.Protocol.MainEngineInstance().Storage.Commitments().Load(includedSlotIndex) - if err != nil { - return nil, ierrors.Wrapf(err, "failed to load commitment with index: %d", includedSlotIndex) - } - metadata.CommitmentIdIncluded = inx.NewCommitmentId(includedCommitment.ID()) - } - - return metadata, nil -} - -func newSpentMetadataResponse(spent *utxoledger.Spent) (*inx.OutputMetadata, error) { - latestCommitment := deps.Protocol.MainEngineInstance().SyncManager.LatestCommitment() - - metadata := &inx.OutputMetadata{ - BlockId: inx.NewBlockId(spent.BlockID()), - TransactionId: inx.NewTransactionId(spent.OutputID().TransactionID()), - OutputIndex: uint32(spent.OutputID().Index()), - IsSpent: true, - TransactionIdSpent: inx.NewTransactionId(spent.TransactionIDSpent()), - LatestCommitmentId: inx.NewCommitmentId(latestCommitment.ID()), - } - - includedSlotIndex := spent.Output().SlotBooked() - if includedSlotIndex <= latestCommitment.Index() { - includedCommitment, err := deps.Protocol.MainEngineInstance().Storage.Commitments().Load(includedSlotIndex) - if err != nil { - return nil, ierrors.Wrapf(err, "failed to load commitment with index: %d", includedSlotIndex) - } - metadata.CommitmentIdIncluded = inx.NewCommitmentId(includedCommitment.ID()) - } - - spentSlotIndex := spent.SlotIndexSpent() - if spentSlotIndex <= latestCommitment.Index() { - spentCommitment, err := deps.Protocol.MainEngineInstance().Storage.Commitments().Load(spentSlotIndex) - if err != nil { - return nil, ierrors.Wrapf(err, "failed to load commitment with index: %d", spentSlotIndex) - } - metadata.CommitmentIdSpent = inx.NewCommitmentId(spentCommitment.ID()) - } - - return metadata, nil -}