payload

package
v0.2.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 27, 2020 License: Apache-2.0, BSD-2-Clause Imports: 10 Imported by: 0

Documentation

Index

Examples

Constants

View Source
const IDLength = 32

IDLength defined the amount of bytes in a payload id (32 bytes hash value).

View Source
const (
	// ObjectName defines the name of the value object.
	ObjectName = "value"
)
View Source
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

type ID [IDLength]byte

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 NewID

func NewID(base58EncodedString string) (result ID, err error)

NewID creates a payload id from a base58 encoded string.

func ParseID

func ParseID(marshalUtil *marshalutil.MarshalUtil) (ID, error)

ParseID is a wrapper for simplified unmarshaling in a byte stream using the marshalUtil package.

func RandomID

func RandomID() (id ID)

RandomID creates a random payload id which can for example be used in unit tests.

func (ID) Bytes

func (id ID) Bytes() []byte

Bytes returns a marshaled version of this ID.

func (ID) String

func (id ID) String() string

String returns a base58 encoded version of the payload id.

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) BranchID

func (payload *Payload) BranchID() ID

BranchID returns the second Payload that is referenced by this Payload.

func (*Payload) Bytes

func (payload *Payload) Bytes() []byte

Bytes returns a marshaled version of this Payload.

func (*Payload) ID

func (payload *Payload) ID() ID

ID returns the identifier if the Payload.

func (*Payload) ObjectStorageKey

func (payload *Payload) ObjectStorageKey() []byte

ObjectStorageKey returns the bytes that are used a key when storing the Branch in an objectstorage.

func (*Payload) ObjectStorageValue

func (payload *Payload) ObjectStorageValue() (bytes []byte)

ObjectStorageValue returns the bytes that represent all remaining information (not stored in the key) of a marshaled Branch.

func (*Payload) String

func (payload *Payload) String() string

func (*Payload) Transaction

func (payload *Payload) Transaction() *transaction.Transaction

Transaction returns the Transaction that is being attached in this Payload.

func (*Payload) TrunkID

func (payload *Payload) TrunkID() ID

TrunkID returns the first Payload that is referenced by this Payload.

func (*Payload) Type

func (payload *Payload) Type() payload.Type

Type returns the type of the Payload.

func (*Payload) Unmarshal

func (payload *Payload) Unmarshal(data []byte) (err error)

Unmarshal unmarshals a given slice of bytes and fills the object with the.

func (*Payload) UnmarshalObjectStorageValue

func (payload *Payload) UnmarshalObjectStorageValue(data []byte) (consumedBytes int, err error)

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.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL