577 lines
13 KiB
Go
577 lines
13 KiB
Go
|
package netmap
|
||
|
|
||
|
import (
|
||
|
netmap "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/api/netmap/grpc"
|
||
|
"git.frostfs.info/TrueCloudLab/frostfs-sdk-go/api/rpc/message"
|
||
|
protoutil "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/api/util/proto"
|
||
|
)
|
||
|
|
||
|
const (
|
||
|
nameFilterField = 1
|
||
|
keyFilterField = 2
|
||
|
opFilterField = 3
|
||
|
valueFilterField = 4
|
||
|
filtersFilterField = 5
|
||
|
|
||
|
nameSelectorField = 1
|
||
|
countSelectorField = 2
|
||
|
clauseSelectorField = 3
|
||
|
attributeSelectorField = 4
|
||
|
filterSelectorField = 5
|
||
|
|
||
|
countReplicaField = 1
|
||
|
selectorReplicaField = 2
|
||
|
ecDataCountReplicaField = 3
|
||
|
ecParityCountReplicaField = 4
|
||
|
|
||
|
replicasPolicyField = 1
|
||
|
backupPolicyField = 2
|
||
|
selectorsPolicyField = 3
|
||
|
filtersPolicyField = 4
|
||
|
uniquePolicyField = 5
|
||
|
|
||
|
keyAttributeField = 1
|
||
|
valueAttributeField = 2
|
||
|
parentsAttributeField = 3
|
||
|
|
||
|
keyNodeInfoField = 1
|
||
|
addressNodeInfoField = 2
|
||
|
attributesNodeInfoField = 3
|
||
|
stateNodeInfoField = 4
|
||
|
|
||
|
versionInfoResponseBodyField = 1
|
||
|
nodeInfoResponseBodyField = 2
|
||
|
)
|
||
|
|
||
|
func (f *Filter) StableMarshal(buf []byte) []byte {
|
||
|
if f == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, f.StableSize())
|
||
|
}
|
||
|
|
||
|
var offset int
|
||
|
|
||
|
offset += protoutil.StringMarshal(nameFilterField, buf[offset:], f.name)
|
||
|
offset += protoutil.StringMarshal(keyFilterField, buf[offset:], f.key)
|
||
|
offset += protoutil.EnumMarshal(opFilterField, buf[offset:], int32(f.op))
|
||
|
offset += protoutil.StringMarshal(valueFilterField, buf[offset:], f.value)
|
||
|
|
||
|
for i := range f.filters {
|
||
|
offset += protoutil.NestedStructureMarshal(filtersFilterField, buf[offset:], &f.filters[i])
|
||
|
}
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (f *Filter) StableSize() (size int) {
|
||
|
if f == nil {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
size += protoutil.StringSize(nameFilterField, f.name)
|
||
|
size += protoutil.StringSize(keyFilterField, f.key)
|
||
|
size += protoutil.EnumSize(opFilterField, int32(f.op))
|
||
|
size += protoutil.StringSize(valueFilterField, f.value)
|
||
|
for i := range f.filters {
|
||
|
size += protoutil.NestedStructureSize(filtersFilterField, &f.filters[i])
|
||
|
}
|
||
|
|
||
|
return size
|
||
|
}
|
||
|
|
||
|
func (f *Filter) Unmarshal(data []byte) error {
|
||
|
return message.Unmarshal(f, data, new(netmap.Filter))
|
||
|
}
|
||
|
|
||
|
func (s *Selector) StableMarshal(buf []byte) []byte {
|
||
|
if s == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, s.StableSize())
|
||
|
}
|
||
|
|
||
|
var offset int
|
||
|
|
||
|
offset += protoutil.StringMarshal(nameSelectorField, buf[offset:], s.name)
|
||
|
offset += protoutil.UInt32Marshal(countSelectorField, buf[offset:], s.count)
|
||
|
offset += protoutil.EnumMarshal(clauseSelectorField, buf[offset:], int32(s.clause))
|
||
|
offset += protoutil.StringMarshal(attributeSelectorField, buf[offset:], s.attribute)
|
||
|
protoutil.StringMarshal(filterSelectorField, buf[offset:], s.filter)
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (s *Selector) StableSize() (size int) {
|
||
|
if s == nil {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
size += protoutil.StringSize(nameSelectorField, s.name)
|
||
|
size += protoutil.UInt32Size(countSelectorField, s.count)
|
||
|
size += protoutil.EnumSize(countSelectorField, int32(s.clause))
|
||
|
size += protoutil.StringSize(attributeSelectorField, s.attribute)
|
||
|
size += protoutil.StringSize(filterSelectorField, s.filter)
|
||
|
|
||
|
return size
|
||
|
}
|
||
|
|
||
|
func (s *Selector) Unmarshal(data []byte) error {
|
||
|
return message.Unmarshal(s, data, new(netmap.Selector))
|
||
|
}
|
||
|
|
||
|
func (r *Replica) StableMarshal(buf []byte) []byte {
|
||
|
if r == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, r.StableSize())
|
||
|
}
|
||
|
|
||
|
var offset int
|
||
|
|
||
|
offset += protoutil.UInt32Marshal(countReplicaField, buf[offset:], r.count)
|
||
|
offset += protoutil.StringMarshal(selectorReplicaField, buf[offset:], r.selector)
|
||
|
offset += protoutil.UInt32Marshal(ecDataCountReplicaField, buf[offset:], r.ecDataCount)
|
||
|
protoutil.UInt32Marshal(ecParityCountReplicaField, buf[offset:], r.ecParityCount)
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (r *Replica) StableSize() (size int) {
|
||
|
if r == nil {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
size += protoutil.UInt32Size(countReplicaField, r.count)
|
||
|
size += protoutil.StringSize(selectorReplicaField, r.selector)
|
||
|
size += protoutil.UInt32Size(ecDataCountReplicaField, r.ecDataCount)
|
||
|
size += protoutil.UInt32Size(ecParityCountReplicaField, r.ecParityCount)
|
||
|
|
||
|
return size
|
||
|
}
|
||
|
|
||
|
func (r *Replica) Unmarshal(data []byte) error {
|
||
|
return message.Unmarshal(r, data, new(netmap.Replica))
|
||
|
}
|
||
|
|
||
|
func (p *PlacementPolicy) StableMarshal(buf []byte) []byte {
|
||
|
if p == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, p.StableSize())
|
||
|
}
|
||
|
|
||
|
var offset int
|
||
|
|
||
|
for i := range p.replicas {
|
||
|
offset += protoutil.NestedStructureMarshal(replicasPolicyField, buf[offset:], &p.replicas[i])
|
||
|
}
|
||
|
|
||
|
offset += protoutil.UInt32Marshal(backupPolicyField, buf[offset:], p.backupFactor)
|
||
|
|
||
|
for i := range p.selectors {
|
||
|
offset += protoutil.NestedStructureMarshal(selectorsPolicyField, buf[offset:], &p.selectors[i])
|
||
|
}
|
||
|
|
||
|
for i := range p.filters {
|
||
|
offset += protoutil.NestedStructureMarshal(filtersPolicyField, buf[offset:], &p.filters[i])
|
||
|
}
|
||
|
|
||
|
protoutil.BoolMarshal(uniquePolicyField, buf[offset:], p.unique)
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (p *PlacementPolicy) StableSize() (size int) {
|
||
|
if p == nil {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
for i := range p.replicas {
|
||
|
size += protoutil.NestedStructureSize(replicasPolicyField, &p.replicas[i])
|
||
|
}
|
||
|
|
||
|
size += protoutil.UInt32Size(backupPolicyField, p.backupFactor)
|
||
|
|
||
|
for i := range p.selectors {
|
||
|
size += protoutil.NestedStructureSize(selectorsPolicyField, &p.selectors[i])
|
||
|
}
|
||
|
|
||
|
for i := range p.filters {
|
||
|
size += protoutil.NestedStructureSize(filtersPolicyField, &p.filters[i])
|
||
|
}
|
||
|
|
||
|
size += protoutil.BoolSize(uniquePolicyField, p.unique)
|
||
|
|
||
|
return size
|
||
|
}
|
||
|
|
||
|
func (p *PlacementPolicy) Unmarshal(data []byte) error {
|
||
|
return message.Unmarshal(p, data, new(netmap.PlacementPolicy))
|
||
|
}
|
||
|
|
||
|
func (a *Attribute) StableMarshal(buf []byte) []byte {
|
||
|
if a == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, a.StableSize())
|
||
|
}
|
||
|
|
||
|
var offset int
|
||
|
|
||
|
offset += protoutil.StringMarshal(keyAttributeField, buf[offset:], a.key)
|
||
|
offset += protoutil.StringMarshal(valueAttributeField, buf[offset:], a.value)
|
||
|
|
||
|
for i := range a.parents {
|
||
|
offset += protoutil.StringMarshal(parentsAttributeField, buf[offset:], a.parents[i])
|
||
|
}
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (a *Attribute) StableSize() (size int) {
|
||
|
if a == nil {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
size += protoutil.StringSize(keyAttributeField, a.key)
|
||
|
size += protoutil.StringSize(valueAttributeField, a.value)
|
||
|
|
||
|
for i := range a.parents {
|
||
|
size += protoutil.StringSize(parentsAttributeField, a.parents[i])
|
||
|
}
|
||
|
|
||
|
return size
|
||
|
}
|
||
|
|
||
|
func (a *Attribute) Unmarshal(data []byte) error {
|
||
|
return message.Unmarshal(a, data, new(netmap.NodeInfo_Attribute))
|
||
|
}
|
||
|
|
||
|
func (ni *NodeInfo) StableMarshal(buf []byte) []byte {
|
||
|
if ni == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, ni.StableSize())
|
||
|
}
|
||
|
|
||
|
var offset int
|
||
|
|
||
|
offset += protoutil.BytesMarshal(keyNodeInfoField, buf[offset:], ni.publicKey)
|
||
|
offset += protoutil.RepeatedStringMarshal(addressNodeInfoField, buf[offset:], ni.addresses)
|
||
|
|
||
|
for i := range ni.attributes {
|
||
|
offset += protoutil.NestedStructureMarshal(attributesNodeInfoField, buf[offset:], &ni.attributes[i])
|
||
|
}
|
||
|
|
||
|
protoutil.EnumMarshal(stateNodeInfoField, buf[offset:], int32(ni.state))
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (ni *NodeInfo) StableSize() (size int) {
|
||
|
if ni == nil {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
size += protoutil.BytesSize(keyNodeInfoField, ni.publicKey)
|
||
|
size += protoutil.RepeatedStringSize(addressNodeInfoField, ni.addresses)
|
||
|
|
||
|
for i := range ni.attributes {
|
||
|
size += protoutil.NestedStructureSize(attributesNodeInfoField, &ni.attributes[i])
|
||
|
}
|
||
|
|
||
|
size += protoutil.EnumSize(stateNodeInfoField, int32(ni.state))
|
||
|
|
||
|
return size
|
||
|
}
|
||
|
|
||
|
func (ni *NodeInfo) Unmarshal(data []byte) error {
|
||
|
return message.Unmarshal(ni, data, new(netmap.NodeInfo))
|
||
|
}
|
||
|
|
||
|
func (l *LocalNodeInfoRequestBody) StableMarshal(_ []byte) []byte {
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (l *LocalNodeInfoRequestBody) StableSize() (size int) {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
func (l *LocalNodeInfoRequestBody) Unmarshal([]byte) error {
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (l *LocalNodeInfoResponseBody) StableMarshal(buf []byte) []byte {
|
||
|
if l == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, l.StableSize())
|
||
|
}
|
||
|
|
||
|
var offset int
|
||
|
|
||
|
offset += protoutil.NestedStructureMarshal(versionInfoResponseBodyField, buf[offset:], l.version)
|
||
|
protoutil.NestedStructureMarshal(nodeInfoResponseBodyField, buf[offset:], l.nodeInfo)
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (l *LocalNodeInfoResponseBody) StableSize() (size int) {
|
||
|
if l == nil {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
size += protoutil.NestedStructureSize(versionInfoResponseBodyField, l.version)
|
||
|
size += protoutil.NestedStructureSize(nodeInfoResponseBodyField, l.nodeInfo)
|
||
|
|
||
|
return size
|
||
|
}
|
||
|
|
||
|
func (l *LocalNodeInfoResponseBody) Unmarshal(data []byte) error {
|
||
|
return message.Unmarshal(l, data, new(netmap.LocalNodeInfoResponse_Body))
|
||
|
}
|
||
|
|
||
|
const (
|
||
|
_ = iota
|
||
|
netPrmKeyFNum
|
||
|
netPrmValFNum
|
||
|
)
|
||
|
|
||
|
func (x *NetworkParameter) StableMarshal(buf []byte) []byte {
|
||
|
if x == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, x.StableSize())
|
||
|
}
|
||
|
|
||
|
var offset int
|
||
|
|
||
|
offset += protoutil.BytesMarshal(netPrmKeyFNum, buf[offset:], x.k)
|
||
|
protoutil.BytesMarshal(netPrmValFNum, buf[offset:], x.v)
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (x *NetworkParameter) StableSize() (size int) {
|
||
|
if x == nil {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
size += protoutil.BytesSize(netPrmKeyFNum, x.k)
|
||
|
size += protoutil.BytesSize(netPrmValFNum, x.v)
|
||
|
|
||
|
return size
|
||
|
}
|
||
|
|
||
|
const (
|
||
|
_ = iota
|
||
|
netCfgPrmsFNum
|
||
|
)
|
||
|
|
||
|
func (x *NetworkConfig) StableMarshal(buf []byte) []byte {
|
||
|
if x == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, x.StableSize())
|
||
|
}
|
||
|
|
||
|
var offset int
|
||
|
|
||
|
for i := range x.ps {
|
||
|
offset += protoutil.NestedStructureMarshal(netCfgPrmsFNum, buf[offset:], &x.ps[i])
|
||
|
}
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (x *NetworkConfig) StableSize() (size int) {
|
||
|
if x == nil {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
for i := range x.ps {
|
||
|
size += protoutil.NestedStructureSize(netCfgPrmsFNum, &x.ps[i])
|
||
|
}
|
||
|
|
||
|
return size
|
||
|
}
|
||
|
|
||
|
const (
|
||
|
_ = iota
|
||
|
netInfoCurEpochFNum
|
||
|
netInfoMagicNumFNum
|
||
|
netInfoMSPerBlockFNum
|
||
|
netInfoCfgFNum
|
||
|
)
|
||
|
|
||
|
func (i *NetworkInfo) StableMarshal(buf []byte) []byte {
|
||
|
if i == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, i.StableSize())
|
||
|
}
|
||
|
|
||
|
var offset int
|
||
|
|
||
|
offset += protoutil.UInt64Marshal(netInfoCurEpochFNum, buf[offset:], i.curEpoch)
|
||
|
offset += protoutil.UInt64Marshal(netInfoMagicNumFNum, buf[offset:], i.magicNum)
|
||
|
offset += protoutil.Int64Marshal(netInfoMSPerBlockFNum, buf[offset:], i.msPerBlock)
|
||
|
protoutil.NestedStructureMarshal(netInfoCfgFNum, buf[offset:], i.netCfg)
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (i *NetworkInfo) StableSize() (size int) {
|
||
|
if i == nil {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
size += protoutil.UInt64Size(netInfoCurEpochFNum, i.curEpoch)
|
||
|
size += protoutil.UInt64Size(netInfoMagicNumFNum, i.magicNum)
|
||
|
size += protoutil.Int64Size(netInfoMSPerBlockFNum, i.msPerBlock)
|
||
|
size += protoutil.NestedStructureSize(netInfoCfgFNum, i.netCfg)
|
||
|
|
||
|
return size
|
||
|
}
|
||
|
|
||
|
func (i *NetworkInfo) Unmarshal(data []byte) error {
|
||
|
return message.Unmarshal(i, data, new(netmap.NetworkInfo))
|
||
|
}
|
||
|
|
||
|
func (l *NetworkInfoRequestBody) StableMarshal(_ []byte) []byte {
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (l *NetworkInfoRequestBody) StableSize() (size int) {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
func (l *NetworkInfoRequestBody) Unmarshal(data []byte) error {
|
||
|
return message.Unmarshal(l, data, new(netmap.NetworkInfoRequest_Body))
|
||
|
}
|
||
|
|
||
|
const (
|
||
|
_ = iota
|
||
|
netInfoRespBodyNetInfoFNum
|
||
|
)
|
||
|
|
||
|
func (i *NetworkInfoResponseBody) StableMarshal(buf []byte) []byte {
|
||
|
if i == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, i.StableSize())
|
||
|
}
|
||
|
|
||
|
protoutil.NestedStructureMarshal(netInfoRespBodyNetInfoFNum, buf, i.netInfo)
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (i *NetworkInfoResponseBody) StableSize() (size int) {
|
||
|
if i == nil {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
size += protoutil.NestedStructureSize(netInfoRespBodyNetInfoFNum, i.netInfo)
|
||
|
|
||
|
return size
|
||
|
}
|
||
|
|
||
|
func (i *NetworkInfoResponseBody) Unmarshal(data []byte) error {
|
||
|
return message.Unmarshal(i, data, new(netmap.NetworkInfoResponse_Body))
|
||
|
}
|
||
|
|
||
|
const (
|
||
|
_ = iota
|
||
|
fNumNetMapEpoch
|
||
|
fNumNetMapNodes
|
||
|
)
|
||
|
|
||
|
func (x *NetMap) StableMarshal(buf []byte) []byte {
|
||
|
if x == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, x.StableSize())
|
||
|
}
|
||
|
|
||
|
offset := protoutil.UInt64Marshal(fNumNetMapEpoch, buf, x.epoch)
|
||
|
|
||
|
for i := range x.nodes {
|
||
|
offset += protoutil.NestedStructureMarshal(fNumNetMapNodes, buf[offset:], &x.nodes[i])
|
||
|
}
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (x *NetMap) StableSize() (size int) {
|
||
|
if x != nil {
|
||
|
size = protoutil.UInt64Size(fNumNetMapEpoch, x.epoch)
|
||
|
|
||
|
for i := range x.nodes {
|
||
|
size += protoutil.NestedStructureSize(fNumNetMapNodes, &x.nodes[i])
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return
|
||
|
}
|
||
|
|
||
|
func (x *SnapshotRequestBody) StableMarshal([]byte) []byte {
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (x *SnapshotRequestBody) StableSize() int {
|
||
|
return 0
|
||
|
}
|
||
|
|
||
|
const (
|
||
|
_ = iota
|
||
|
fNumSnapshotResponseBodyNetMap
|
||
|
)
|
||
|
|
||
|
func (x *SnapshotResponseBody) StableMarshal(buf []byte) []byte {
|
||
|
if x == nil {
|
||
|
return []byte{}
|
||
|
}
|
||
|
|
||
|
if buf == nil {
|
||
|
buf = make([]byte, x.StableSize())
|
||
|
}
|
||
|
|
||
|
protoutil.NestedStructureMarshal(fNumSnapshotResponseBodyNetMap, buf, x.netMap)
|
||
|
|
||
|
return buf
|
||
|
}
|
||
|
|
||
|
func (x *SnapshotResponseBody) StableSize() (size int) {
|
||
|
if x != nil {
|
||
|
size = protoutil.NestedStructureSize(fNumSnapshotResponseBodyNetMap, x.netMap)
|
||
|
}
|
||
|
|
||
|
return
|
||
|
}
|