The core protocol of WoopChain
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
woop/proto/identity/identity.go

65 lines
1.6 KiB

package identity
import (
"bytes"
"errors"
"github.com/simple-rules/harmony-benchmark/proto"
)
// the number of bytes consensus message type occupies
const IDENTITY_MESSAGE_TYPE_BYTES = 1
type IdentityMessageType byte
const (
IDENTITY IdentityMessageType = iota
// TODO: add more types
)
type MessageType int
const (
REGISTER MessageType = iota
ANNOUNCE
CONFIG
)
// Returns string name for the MessageType enum
func (msgType MessageType) String() string {
names := [...]string{
"REGISTER",
"ANNOUNCE",
"CONFIG",
}
if msgType < REGISTER || msgType > CONFIG {
return "Unknown"
}
return names[msgType]
}
// GetIdentityMessageType Get the identity message type from the identity message
func GetIdentityMessageType(message []byte) (MessageType, error) {
if len(message) < 1 {
return 0, errors.New("Failed to get identity message type: no data available.")
}
return MessageType(message[0]), nil
}
// GetIdentityMessagePayload message payload from the identity message
func GetIdentityMessagePayload(message []byte) ([]byte, error) {
if len(message) < 2 {
return []byte{}, errors.New("Failed to get identity message payload: no data available.")
}
return message[IDENTITY_MESSAGE_TYPE_BYTES:], nil
}
// Concatenate msgType as one byte with payload, and return the whole byte array
func ConstructIdentityMessage(identityMessageType MessageType, payload []byte) []byte {
byteBuffer := bytes.NewBuffer([]byte{byte(proto.IDENTITY)})
byteBuffer.WriteByte(byte(IDENTITY))
byteBuffer.WriteByte(byte(identityMessageType))
byteBuffer.Write(payload)
return byteBuffer.Bytes()
}