Documentation ¶
Index ¶
- Constants
- type CachedPayload
- type ID
- type Payload
- func FromBytes(bytes []byte, optionalTargetObject ...*Payload) (result *Payload, consumedBytes int, err error)
- func FromStorageKey(key []byte, optionalTargetObject ...*Payload) (result *Payload, consumedBytes int, err error)
- func New(trunkPayloadID, branchPayloadID ID, valueTransfer *transaction.Transaction) *Payload
- func Parse(marshalUtil *marshalutil.MarshalUtil, optionalTargetObject ...*Payload) (result *Payload, err error)
- func (payload *Payload) BranchID() ID
- func (payload *Payload) Bytes() []byte
- func (payload *Payload) ID() ID
- func (payload *Payload) ObjectStorageKey() []byte
- func (payload *Payload) ObjectStorageValue() (bytes []byte)
- func (payload *Payload) String() string
- func (payload *Payload) Transaction() *transaction.Transaction
- func (payload *Payload) TrunkID() ID
- func (payload *Payload) Type() payload.Type
- func (payload *Payload) Unmarshal(data []byte) (err error)
- func (payload *Payload) UnmarshalObjectStorageValue(data []byte) (consumedBytes int, err error)
- func (payload *Payload) Update(other objectstorage.StorableObject)
Examples ¶
Constants ¶
const IDLength = 32
IDLength defined the amount of bytes in a payload id (32 bytes hash value).
const (
// ObjectName defines the name of the value object.
ObjectName = "value"
)
const Type = payload.Type(1)
Type represents the identifier which addresses the value Payload type.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type CachedPayload ¶
type CachedPayload struct {
objectstorage.CachedObject
}
CachedPayload is a wrapper for the object storage, that takes care of type casting the managed objects. Since go does not have generics (yet), the object storage works based on the generic "interface{}" type, which means that we have to regularly type cast the returned objects, to match the expected type. To reduce the burden of manually managing these type, we create a wrapper that does this for us. This way, we can consistently handle the specialized types of CachedObjects, without having to manually type cast over and over again.
func (*CachedPayload) Consume ¶
func (cachedPayload *CachedPayload) Consume(consumer func(payload *Payload)) bool
Consume wraps the underlying method to return the correctly typed objects in the callback.
func (*CachedPayload) Retain ¶
func (cachedPayload *CachedPayload) Retain() *CachedPayload
Retain wraps the underlying method to return a new "wrapped object".
func (*CachedPayload) Unwrap ¶
func (cachedPayload *CachedPayload) Unwrap() *Payload
Unwrap provides a way to "Get" a type casted version of the underlying object.
type ID ¶
ID represents the hash of a payload that is used to identify the given payload.
var GenesisID ID
GenesisID contains the zero value of this ID which represents the genesis.
func IDFromBytes ¶
func IDFromBytes(bytes []byte, optionalTargetObject ...*ID) (result ID, consumedBytes int, err error)
IDFromBytes unmarshals a payload id from a sequence of bytes. It either creates a new payload id or fills the optionally provided object with the parsed information.
func ParseID ¶
func ParseID(marshalUtil *marshalutil.MarshalUtil) (ID, error)
ParseID is a wrapper for simplified unmarshaling in a byte stream using the marshalUtil package.
type Payload ¶
type Payload struct { objectstorage.StorableObjectFlags // contains filtered or unexported fields }
Payload represents the entity that forms the Tangle by referencing other Payloads using their trunk and branch. A Payload contains a transaction and defines, where in the Tangle a transaction is attached.
Example ¶
// 1. create value transfer (user provides this) valueTransfer := transaction.New( // inputs transaction.NewInputs( transaction.NewOutputID(address.Random(), transaction.RandomID()), transaction.NewOutputID(address.Random(), transaction.RandomID()), ), // outputs transaction.NewOutputs(map[address.Address][]*balance.Balance{ address.Random(): { balance.New(balance.ColorIOTA, 1337), }, }), ) // 2. create value payload (the ontology creates this and wraps the user provided transfer accordingly) valuePayload := New( // trunk in "value transfer ontology" (filled by ontology tipSelector) GenesisID, // branch in "value transfer ontology" (filled by ontology tipSelector) GenesisID, // value transfer valueTransfer, ) // 3. build actual transaction (the base layer creates this and wraps the ontology provided payload) tx := message.New( // trunk in "network tangle" ontology (filled by tipSelector) message.EmptyId, // branch in "network tangle" ontology (filled by tipSelector) message.EmptyId, // the time when the transaction was created time.Now(), // public key of the issuer ed25519.PublicKey{}, // the ever increasing sequence number of this transaction 0, // payload valuePayload, // nonce to check PoW 0, // signature ed25519.Signature{}, ) fmt.Println(tx)
Output:
func FromBytes ¶
func FromBytes(bytes []byte, optionalTargetObject ...*Payload) (result *Payload, consumedBytes int, err error)
FromBytes parses the marshaled version of a Payload into an object. It either returns a new Payload or fills an optionally provided Payload with the parsed information.
func FromStorageKey ¶
func FromStorageKey(key []byte, optionalTargetObject ...*Payload) (result *Payload, consumedBytes int, err error)
FromStorageKey is a factory method that creates a new Payload instance from a storage key of the objectstorage. It is used by the objectstorage, to create new instances of this entity.
func New ¶
func New(trunkPayloadID, branchPayloadID ID, valueTransfer *transaction.Transaction) *Payload
New is the constructor of a Payload and creates a new Payload object from the given details.
func Parse ¶
func Parse(marshalUtil *marshalutil.MarshalUtil, optionalTargetObject ...*Payload) (result *Payload, err error)
Parse unmarshals a Payload using the given marshalUtil (for easier marshaling/unmarshaling).
func (*Payload) ObjectStorageKey ¶
ObjectStorageKey returns the bytes that are used a key when storing the Branch in an objectstorage.
func (*Payload) ObjectStorageValue ¶
ObjectStorageValue returns the bytes that represent all remaining information (not stored in the key) of a marshaled Branch.
func (*Payload) Transaction ¶
func (payload *Payload) Transaction() *transaction.Transaction
Transaction returns the Transaction that is being attached in this Payload.
func (*Payload) Unmarshal ¶
Unmarshal unmarshals a given slice of bytes and fills the object with the.
func (*Payload) UnmarshalObjectStorageValue ¶
UnmarshalObjectStorageValue unmarshals the bytes that are stored in the value of the objectstorage.
func (*Payload) Update ¶
func (payload *Payload) Update(other objectstorage.StorableObject)
Update is disabled but needs to be implemented to be compatible with the objectstorage.