2016-06-13 22:52:49 -04:00
|
|
|
package convert
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
2016-06-17 22:01:18 -04:00
|
|
|
"time"
|
2016-06-13 22:52:49 -04:00
|
|
|
|
2016-09-06 14:18:12 -04:00
|
|
|
types "github.com/docker/docker/api/types/swarm"
|
2016-06-13 22:52:49 -04:00
|
|
|
swarmapi "github.com/docker/swarmkit/api"
|
|
|
|
"github.com/docker/swarmkit/protobuf/ptypes"
|
|
|
|
)
|
|
|
|
|
|
|
|
// SwarmFromGRPC converts a grpc Cluster to a Swarm.
|
|
|
|
func SwarmFromGRPC(c swarmapi.Cluster) types.Swarm {
|
|
|
|
swarm := types.Swarm{
|
2016-07-27 15:06:00 -04:00
|
|
|
ClusterInfo: types.ClusterInfo{
|
|
|
|
ID: c.ID,
|
|
|
|
Spec: types.Spec{
|
|
|
|
Orchestration: types.OrchestrationConfig{
|
2016-08-26 00:08:53 -04:00
|
|
|
TaskHistoryRetentionLimit: &c.Spec.Orchestration.TaskHistoryRetentionLimit,
|
2016-07-27 15:06:00 -04:00
|
|
|
},
|
|
|
|
Raft: types.RaftConfig{
|
|
|
|
SnapshotInterval: c.Spec.Raft.SnapshotInterval,
|
2016-11-02 15:29:51 -04:00
|
|
|
KeepOldSnapshots: &c.Spec.Raft.KeepOldSnapshots,
|
2016-07-27 15:06:00 -04:00
|
|
|
LogEntriesForSlowFollowers: c.Spec.Raft.LogEntriesForSlowFollowers,
|
2016-08-31 11:25:14 -04:00
|
|
|
HeartbeatTick: int(c.Spec.Raft.HeartbeatTick),
|
|
|
|
ElectionTick: int(c.Spec.Raft.ElectionTick),
|
2016-07-27 15:06:00 -04:00
|
|
|
},
|
2016-10-27 21:50:49 -04:00
|
|
|
EncryptionConfig: types.EncryptionConfig{
|
|
|
|
AutoLockManagers: c.Spec.EncryptionConfig.AutoLockManagers,
|
|
|
|
},
|
2016-06-13 22:52:49 -04:00
|
|
|
},
|
|
|
|
},
|
2016-07-20 14:15:08 -04:00
|
|
|
JoinTokens: types.JoinTokens{
|
|
|
|
Worker: c.RootCA.JoinTokens.Worker,
|
|
|
|
Manager: c.RootCA.JoinTokens.Manager,
|
|
|
|
},
|
2016-06-13 22:52:49 -04:00
|
|
|
}
|
|
|
|
|
2016-06-17 22:01:18 -04:00
|
|
|
heartbeatPeriod, _ := ptypes.Duration(c.Spec.Dispatcher.HeartbeatPeriod)
|
2016-08-31 11:25:14 -04:00
|
|
|
swarm.Spec.Dispatcher.HeartbeatPeriod = heartbeatPeriod
|
2016-06-17 22:01:18 -04:00
|
|
|
|
2016-06-13 22:52:49 -04:00
|
|
|
swarm.Spec.CAConfig.NodeCertExpiry, _ = ptypes.Duration(c.Spec.CAConfig.NodeCertExpiry)
|
|
|
|
|
2016-06-30 17:39:39 -04:00
|
|
|
for _, ca := range c.Spec.CAConfig.ExternalCAs {
|
|
|
|
swarm.Spec.CAConfig.ExternalCAs = append(swarm.Spec.CAConfig.ExternalCAs, &types.ExternalCA{
|
|
|
|
Protocol: types.ExternalCAProtocol(strings.ToLower(ca.Protocol.String())),
|
|
|
|
URL: ca.URL,
|
|
|
|
Options: ca.Options,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2016-06-13 22:52:49 -04:00
|
|
|
// Meta
|
|
|
|
swarm.Version.Index = c.Meta.Version.Index
|
|
|
|
swarm.CreatedAt, _ = ptypes.Timestamp(c.Meta.CreatedAt)
|
|
|
|
swarm.UpdatedAt, _ = ptypes.Timestamp(c.Meta.UpdatedAt)
|
|
|
|
|
|
|
|
// Annotations
|
|
|
|
swarm.Spec.Name = c.Spec.Annotations.Name
|
|
|
|
swarm.Spec.Labels = c.Spec.Annotations.Labels
|
|
|
|
|
|
|
|
return swarm
|
|
|
|
}
|
|
|
|
|
2016-07-20 14:15:08 -04:00
|
|
|
// SwarmSpecToGRPC converts a Spec to a grpc ClusterSpec.
|
|
|
|
func SwarmSpecToGRPC(s types.Spec) (swarmapi.ClusterSpec, error) {
|
2016-08-26 00:08:53 -04:00
|
|
|
return MergeSwarmSpecToGRPC(s, swarmapi.ClusterSpec{})
|
|
|
|
}
|
|
|
|
|
|
|
|
// MergeSwarmSpecToGRPC merges a Spec with an initial grpc ClusterSpec
|
|
|
|
func MergeSwarmSpecToGRPC(s types.Spec, spec swarmapi.ClusterSpec) (swarmapi.ClusterSpec, error) {
|
|
|
|
// We take the initSpec (either created from scratch, or returned by swarmkit),
|
|
|
|
// and will only change the value if the one taken from types.Spec is not nil or 0.
|
|
|
|
// In other words, if the value taken from types.Spec is nil or 0, we will maintain the status quo.
|
|
|
|
if s.Annotations.Name != "" {
|
|
|
|
spec.Annotations.Name = s.Annotations.Name
|
|
|
|
}
|
|
|
|
if len(s.Annotations.Labels) != 0 {
|
|
|
|
spec.Annotations.Labels = s.Annotations.Labels
|
|
|
|
}
|
|
|
|
|
|
|
|
if s.Orchestration.TaskHistoryRetentionLimit != nil {
|
|
|
|
spec.Orchestration.TaskHistoryRetentionLimit = *s.Orchestration.TaskHistoryRetentionLimit
|
|
|
|
}
|
|
|
|
if s.Raft.SnapshotInterval != 0 {
|
|
|
|
spec.Raft.SnapshotInterval = s.Raft.SnapshotInterval
|
|
|
|
}
|
2016-11-02 15:29:51 -04:00
|
|
|
if s.Raft.KeepOldSnapshots != nil {
|
|
|
|
spec.Raft.KeepOldSnapshots = *s.Raft.KeepOldSnapshots
|
2016-08-26 00:08:53 -04:00
|
|
|
}
|
|
|
|
if s.Raft.LogEntriesForSlowFollowers != 0 {
|
|
|
|
spec.Raft.LogEntriesForSlowFollowers = s.Raft.LogEntriesForSlowFollowers
|
|
|
|
}
|
|
|
|
if s.Raft.HeartbeatTick != 0 {
|
|
|
|
spec.Raft.HeartbeatTick = uint32(s.Raft.HeartbeatTick)
|
|
|
|
}
|
|
|
|
if s.Raft.ElectionTick != 0 {
|
|
|
|
spec.Raft.ElectionTick = uint32(s.Raft.ElectionTick)
|
|
|
|
}
|
|
|
|
if s.Dispatcher.HeartbeatPeriod != 0 {
|
|
|
|
spec.Dispatcher.HeartbeatPeriod = ptypes.DurationProto(time.Duration(s.Dispatcher.HeartbeatPeriod))
|
|
|
|
}
|
|
|
|
if s.CAConfig.NodeCertExpiry != 0 {
|
|
|
|
spec.CAConfig.NodeCertExpiry = ptypes.DurationProto(s.CAConfig.NodeCertExpiry)
|
2016-06-13 22:52:49 -04:00
|
|
|
}
|
|
|
|
|
2016-06-30 17:39:39 -04:00
|
|
|
for _, ca := range s.CAConfig.ExternalCAs {
|
|
|
|
protocol, ok := swarmapi.ExternalCA_CAProtocol_value[strings.ToUpper(string(ca.Protocol))]
|
|
|
|
if !ok {
|
|
|
|
return swarmapi.ClusterSpec{}, fmt.Errorf("invalid protocol: %q", ca.Protocol)
|
|
|
|
}
|
|
|
|
spec.CAConfig.ExternalCAs = append(spec.CAConfig.ExternalCAs, &swarmapi.ExternalCA{
|
|
|
|
Protocol: swarmapi.ExternalCA_CAProtocol(protocol),
|
|
|
|
URL: ca.URL,
|
|
|
|
Options: ca.Options,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2016-10-27 21:50:49 -04:00
|
|
|
spec.EncryptionConfig.AutoLockManagers = s.EncryptionConfig.AutoLockManagers
|
|
|
|
|
2016-06-13 22:52:49 -04:00
|
|
|
return spec, nil
|
|
|
|
}
|