2018-03-21 16:11:04 +00:00
|
|
|
package transaction
|
|
|
|
|
|
|
|
import (
|
2019-08-27 13:29:42 +00:00
|
|
|
"github.com/CityOfZion/neo-go/pkg/crypto/keys"
|
2019-09-16 09:18:13 +00:00
|
|
|
"github.com/CityOfZion/neo-go/pkg/io"
|
2018-03-21 16:11:04 +00:00
|
|
|
)
|
|
|
|
|
2019-09-03 14:51:37 +00:00
|
|
|
// EnrollmentTX transaction represents an enrollment form, which indicates
|
2018-03-21 16:11:04 +00:00
|
|
|
// that the sponsor of the transaction would like to sign up as a validator.
|
|
|
|
// The way to sign up is: To construct an EnrollmentTransaction type of transaction,
|
|
|
|
// and send a deposit to the address of the PublicKey.
|
|
|
|
// The way to cancel the registration is: Spend the deposit on the address of the PublicKey.
|
|
|
|
type EnrollmentTX struct {
|
2019-10-22 14:56:03 +00:00
|
|
|
// PublicKey of the validator.
|
2019-08-27 13:29:42 +00:00
|
|
|
PublicKey *keys.PublicKey
|
2018-03-21 16:11:04 +00:00
|
|
|
}
|
|
|
|
|
2019-09-16 16:31:49 +00:00
|
|
|
// DecodeBinary implements Serializable interface.
|
|
|
|
func (tx *EnrollmentTX) DecodeBinary(r *io.BinReader) {
|
2019-08-27 13:29:42 +00:00
|
|
|
tx.PublicKey = &keys.PublicKey{}
|
2019-09-16 16:31:49 +00:00
|
|
|
tx.PublicKey.DecodeBinary(r)
|
2018-03-21 16:11:04 +00:00
|
|
|
}
|
|
|
|
|
2019-09-16 16:31:49 +00:00
|
|
|
// EncodeBinary implements Serializable interface.
|
|
|
|
func (tx *EnrollmentTX) EncodeBinary(w *io.BinWriter) {
|
|
|
|
tx.PublicKey.EncodeBinary(w)
|
2018-03-21 16:11:04 +00:00
|
|
|
}
|