2020-05-18 15:52:30 +00:00
|
|
|
/*
|
|
|
|
Package transaction provides functions to work with transactions.
|
|
|
|
*/
|
2018-08-21 10:57:48 +00:00
|
|
|
package transaction
|
|
|
|
|
|
|
|
import (
|
2020-03-03 14:21:42 +00:00
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/attribute"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/input"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/output"
|
2020-05-18 16:04:20 +00:00
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/witness"
|
2018-08-21 10:57:48 +00:00
|
|
|
)
|
|
|
|
|
2020-05-18 15:52:30 +00:00
|
|
|
// Transaction represents a NEO transaction, it's an opaque data structure
|
|
|
|
// that can be used with functions from this package. It's similar to
|
|
|
|
// Transaction class in Neo .net framework.
|
2018-08-21 10:57:48 +00:00
|
|
|
type Transaction struct{}
|
|
|
|
|
2020-05-18 15:52:30 +00:00
|
|
|
// GetHash returns the hash (256 bit BE value in a 32 byte slice) of the given
|
|
|
|
// transaction (which also is its ID). Is uses `Neo.Transaction.GetHash` syscall.
|
2018-08-21 10:57:48 +00:00
|
|
|
func GetHash(t Transaction) []byte {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-05-18 15:52:30 +00:00
|
|
|
// GetAttributes returns a slice of attributes for agiven transaction. Refer to
|
|
|
|
// attribute package on how to use them. This function uses
|
|
|
|
// `Neo.Transaction.GetAttributes` syscall.
|
2018-08-21 10:57:48 +00:00
|
|
|
func GetAttributes(t Transaction) []attribute.Attribute {
|
|
|
|
return []attribute.Attribute{}
|
|
|
|
}
|
|
|
|
|
2020-05-18 15:52:30 +00:00
|
|
|
// GetReferences returns a slice of references for a given Transaction. Elements
|
|
|
|
// of this slice can be casted to any of input.Input or output.Output, depending
|
|
|
|
// on which information you're interested in (as reference technically contains
|
|
|
|
// both input and corresponding output), refer to input and output package on
|
|
|
|
// how to use them. This function uses `Neo.Transaction.GetReferences` syscall.
|
2018-10-23 08:23:03 +00:00
|
|
|
func GetReferences(t Transaction) []interface{} {
|
|
|
|
return []interface{}{}
|
2018-08-21 10:57:48 +00:00
|
|
|
}
|
|
|
|
|
2020-05-22 09:18:03 +00:00
|
|
|
// GetUnspentCoins returns a slice of not yet spent ouputs of a given transaction.
|
|
|
|
// This function uses `Neo.Transaction.GetUnspentCoint` syscall.
|
|
|
|
func GetUnspentCoins(t Transaction) []output.Output {
|
|
|
|
return []output.Output{}
|
|
|
|
}
|
|
|
|
|
2020-05-18 15:52:30 +00:00
|
|
|
// GetInputs returns a slice of inputs of a given Transaction. Refer to input
|
|
|
|
// package on how to use them. This function uses `Neo.Transaction.GetInputs`
|
|
|
|
// syscall.
|
2018-08-21 10:57:48 +00:00
|
|
|
func GetInputs(t Transaction) []input.Input {
|
|
|
|
return []input.Input{}
|
|
|
|
}
|
|
|
|
|
2020-05-18 15:52:30 +00:00
|
|
|
// GetOutputs returns a slice of outputs of a given Transaction. Refer to output
|
|
|
|
// package on how to use them. This function uses `Neo.Transaction.GetOutputs`
|
|
|
|
// syscall.
|
2018-08-21 10:57:48 +00:00
|
|
|
func GetOutputs(t Transaction) []output.Output {
|
|
|
|
return []output.Output{}
|
|
|
|
}
|
2020-05-18 15:22:07 +00:00
|
|
|
|
2020-05-18 16:04:20 +00:00
|
|
|
// GetWitnesses returns a slice of witnesses of a given Transaction. Refer to
|
|
|
|
// witness package on how to use them. This function uses
|
|
|
|
// `Neo.Transaction.GetWitnesses` syscall.
|
|
|
|
func GetWitnesses(t Transaction) []witness.Witness {
|
|
|
|
return []witness.Witness{}
|
|
|
|
}
|