// unmarshal deserializes from a protobuf representation. func (data *Data) unmarshal(pb *internal.Data) { data.Term = pb.GetTerm() data.Index = pb.GetIndex() data.ClusterID = pb.GetClusterID() data.MaxShardGroupID = pb.GetMaxShardGroupID() data.MaxShardID = pb.GetMaxShardID() data.Databases = make([]DatabaseInfo, len(pb.GetDatabases())) for i, x := range pb.GetDatabases() { data.Databases[i].unmarshal(x) } data.Users = make([]UserInfo, len(pb.GetUsers())) for i, x := range pb.GetUsers() { data.Users[i].unmarshal(x) } }
// unmarshal deserializes from a protobuf representation. func (data *Data) unmarshal(pb *internal.Data) { data.Term = pb.GetTerm() data.Index = pb.GetIndex() data.ClusterID = pb.GetClusterID() data.MaxNodeID = pb.GetMaxNodeID() data.MaxShardGroupID = pb.GetMaxShardGroupID() data.MaxShardID = pb.GetMaxShardID() // TODO: Nodes is deprecated. This is being left here to make migration from 0.9.x to 0.10.0 possible if len(pb.GetNodes()) > 0 { data.DataNodes = make([]NodeInfo, len(pb.GetNodes())) for i, x := range pb.GetNodes() { data.DataNodes[i].unmarshal(x) } } else { data.DataNodes = make([]NodeInfo, len(pb.GetDataNodes())) for i, x := range pb.GetDataNodes() { data.DataNodes[i].unmarshal(x) } } data.MetaNodes = make([]NodeInfo, len(pb.GetMetaNodes())) for i, x := range pb.GetMetaNodes() { data.MetaNodes[i].unmarshal(x) } data.Databases = make([]DatabaseInfo, len(pb.GetDatabases())) for i, x := range pb.GetDatabases() { data.Databases[i].unmarshal(x) } data.Users = make([]UserInfo, len(pb.GetUsers())) for i, x := range pb.GetUsers() { data.Users[i].unmarshal(x) } }