cdb1293eea
Added code to correctly retrieve and convert the Topology from the gRPC Swarm Node. Signed-off-by: Drew Erny <derny@mirantis.com>
113 lines
3.7 KiB
Go
113 lines
3.7 KiB
Go
package convert // import "github.com/docker/docker/daemon/cluster/convert"
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
|
|
types "github.com/docker/docker/api/types/swarm"
|
|
gogotypes "github.com/gogo/protobuf/types"
|
|
swarmapi "github.com/moby/swarmkit/v2/api"
|
|
)
|
|
|
|
// NodeFromGRPC converts a grpc Node to a Node.
|
|
func NodeFromGRPC(n swarmapi.Node) types.Node {
|
|
node := types.Node{
|
|
ID: n.ID,
|
|
Spec: types.NodeSpec{
|
|
Role: types.NodeRole(strings.ToLower(n.Spec.DesiredRole.String())),
|
|
Availability: types.NodeAvailability(strings.ToLower(n.Spec.Availability.String())),
|
|
},
|
|
Status: types.NodeStatus{
|
|
State: types.NodeState(strings.ToLower(n.Status.State.String())),
|
|
Message: n.Status.Message,
|
|
Addr: n.Status.Addr,
|
|
},
|
|
}
|
|
|
|
// Meta
|
|
node.Version.Index = n.Meta.Version.Index
|
|
node.CreatedAt, _ = gogotypes.TimestampFromProto(n.Meta.CreatedAt)
|
|
node.UpdatedAt, _ = gogotypes.TimestampFromProto(n.Meta.UpdatedAt)
|
|
|
|
// Annotations
|
|
node.Spec.Annotations = annotationsFromGRPC(n.Spec.Annotations)
|
|
|
|
// Description
|
|
if n.Description != nil {
|
|
node.Description.Hostname = n.Description.Hostname
|
|
if n.Description.Platform != nil {
|
|
node.Description.Platform.Architecture = n.Description.Platform.Architecture
|
|
node.Description.Platform.OS = n.Description.Platform.OS
|
|
}
|
|
if n.Description.Resources != nil {
|
|
node.Description.Resources.NanoCPUs = n.Description.Resources.NanoCPUs
|
|
node.Description.Resources.MemoryBytes = n.Description.Resources.MemoryBytes
|
|
node.Description.Resources.GenericResources = GenericResourcesFromGRPC(n.Description.Resources.Generic)
|
|
}
|
|
if n.Description.Engine != nil {
|
|
node.Description.Engine.EngineVersion = n.Description.Engine.EngineVersion
|
|
node.Description.Engine.Labels = n.Description.Engine.Labels
|
|
for _, plugin := range n.Description.Engine.Plugins {
|
|
node.Description.Engine.Plugins = append(node.Description.Engine.Plugins, types.PluginDescription{Type: plugin.Type, Name: plugin.Name})
|
|
}
|
|
}
|
|
if n.Description.TLSInfo != nil {
|
|
node.Description.TLSInfo.TrustRoot = string(n.Description.TLSInfo.TrustRoot)
|
|
node.Description.TLSInfo.CertIssuerPublicKey = n.Description.TLSInfo.CertIssuerPublicKey
|
|
node.Description.TLSInfo.CertIssuerSubject = n.Description.TLSInfo.CertIssuerSubject
|
|
}
|
|
for _, csi := range n.Description.CSIInfo {
|
|
if csi != nil {
|
|
convertedInfo := types.NodeCSIInfo{
|
|
PluginName: csi.PluginName,
|
|
NodeID: csi.NodeID,
|
|
MaxVolumesPerNode: csi.MaxVolumesPerNode,
|
|
}
|
|
|
|
if csi.AccessibleTopology != nil {
|
|
convertedInfo.AccessibleTopology = &types.Topology{
|
|
Segments: csi.AccessibleTopology.Segments,
|
|
}
|
|
}
|
|
|
|
node.Description.CSIInfo = append(
|
|
node.Description.CSIInfo, convertedInfo,
|
|
)
|
|
}
|
|
}
|
|
}
|
|
|
|
// Manager
|
|
if n.ManagerStatus != nil {
|
|
node.ManagerStatus = &types.ManagerStatus{
|
|
Leader: n.ManagerStatus.Leader,
|
|
Reachability: types.Reachability(strings.ToLower(n.ManagerStatus.Reachability.String())),
|
|
Addr: n.ManagerStatus.Addr,
|
|
}
|
|
}
|
|
|
|
return node
|
|
}
|
|
|
|
// NodeSpecToGRPC converts a NodeSpec to a grpc NodeSpec.
|
|
func NodeSpecToGRPC(s types.NodeSpec) (swarmapi.NodeSpec, error) {
|
|
spec := swarmapi.NodeSpec{
|
|
Annotations: swarmapi.Annotations{
|
|
Name: s.Name,
|
|
Labels: s.Labels,
|
|
},
|
|
}
|
|
if role, ok := swarmapi.NodeRole_value[strings.ToUpper(string(s.Role))]; ok {
|
|
spec.DesiredRole = swarmapi.NodeRole(role)
|
|
} else {
|
|
return swarmapi.NodeSpec{}, fmt.Errorf("invalid Role: %q", s.Role)
|
|
}
|
|
|
|
if availability, ok := swarmapi.NodeSpec_Availability_value[strings.ToUpper(string(s.Availability))]; ok {
|
|
spec.Availability = swarmapi.NodeSpec_Availability(availability)
|
|
} else {
|
|
return swarmapi.NodeSpec{}, fmt.Errorf("invalid Availability: %q", s.Availability)
|
|
}
|
|
|
|
return spec, nil
|
|
}
|