forked from TrueCloudLab/frostfs-sdk-go
43 lines
1 KiB
Go
43 lines
1 KiB
Go
package message
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-sdk-go/api/rpc/grpc"
|
|
)
|
|
|
|
// Message represents raw Protobuf message
|
|
// that can be transmitted via several
|
|
// transport protocols.
|
|
type Message interface {
|
|
// Must return gRPC message that can
|
|
// be used for gRPC protocol transmission.
|
|
ToGRPCMessage() grpc.Message
|
|
|
|
// Must restore the message from related
|
|
// gRPC message.
|
|
//
|
|
// If gRPC message is not a related one,
|
|
// ErrUnexpectedMessageType can be returned
|
|
// to indicate this.
|
|
FromGRPCMessage(grpc.Message) error
|
|
}
|
|
|
|
// ErrUnexpectedMessageType is an error that
|
|
// is used to indicate message mismatch.
|
|
type ErrUnexpectedMessageType struct {
|
|
exp, act any
|
|
}
|
|
|
|
// NewUnexpectedMessageType initializes an error about message mismatch
|
|
// between act and exp.
|
|
func NewUnexpectedMessageType(act, exp any) ErrUnexpectedMessageType {
|
|
return ErrUnexpectedMessageType{
|
|
exp: exp,
|
|
act: act,
|
|
}
|
|
}
|
|
|
|
func (e ErrUnexpectedMessageType) Error() string {
|
|
return fmt.Sprintf("unexpected message type %T: expected %T", e.act, e.exp)
|
|
}
|