2022-03-22 11:03:15 -04:00
|
|
|
package state
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
|
|
|
|
cmdc "github.com/edgelesssys/constellation/cli/cmd"
|
|
|
|
"github.com/edgelesssys/constellation/cli/gcp"
|
|
|
|
configc "github.com/edgelesssys/constellation/internal/config"
|
|
|
|
"github.com/edgelesssys/constellation/internal/state"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Code in this file is mostly copied from constellation-coordinator
|
|
|
|
// TODO: import as package from coordinator once it is properly refactored
|
|
|
|
|
|
|
|
func GetScalingGroupsFromConfig(stat state.ConstellationState, config *configc.Config) (coordinators, nodes cmdc.ScalingGroup, err error) {
|
|
|
|
switch {
|
|
|
|
case len(stat.EC2Instances) != 0:
|
|
|
|
return getAWSInstances(stat, config)
|
|
|
|
case len(stat.GCPCoordinators) != 0:
|
|
|
|
return getGCPInstances(stat, config)
|
|
|
|
case len(stat.AzureCoordinators) != 0:
|
|
|
|
return getAzureInstances(stat, config)
|
2022-05-24 03:44:00 -04:00
|
|
|
case len(stat.QEMUCoordinators) != 0:
|
|
|
|
return getQEMUInstances(stat, config)
|
2022-03-22 11:03:15 -04:00
|
|
|
default:
|
|
|
|
return cmdc.ScalingGroup{}, cmdc.ScalingGroup{}, errors.New("no instances to init")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-25 07:50:07 -04:00
|
|
|
func getAWSInstances(stat state.ConstellationState, _ *configc.Config) (coordinators, nodes cmdc.ScalingGroup, err error) {
|
2022-04-25 11:21:32 -04:00
|
|
|
coordinatorID, _, err := stat.EC2Instances.GetOne()
|
2022-03-22 11:03:15 -04:00
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
2022-04-25 11:21:32 -04:00
|
|
|
coordinatorMap := stat.EC2Instances
|
|
|
|
var coordinatorInstances cmdc.Instances
|
|
|
|
for _, node := range coordinatorMap {
|
|
|
|
coordinatorInstances = append(coordinatorInstances, cmdc.Instance(node))
|
|
|
|
}
|
2022-03-22 11:03:15 -04:00
|
|
|
// GroupID of coordinators is empty, since they currently do not scale.
|
2022-04-25 11:21:32 -04:00
|
|
|
coordinators = cmdc.ScalingGroup{
|
|
|
|
Instances: coordinatorInstances,
|
|
|
|
GroupID: "",
|
|
|
|
}
|
2022-03-22 11:03:15 -04:00
|
|
|
nodeMap := stat.EC2Instances.GetOthers(coordinatorID)
|
|
|
|
if len(nodeMap) == 0 {
|
|
|
|
return cmdc.ScalingGroup{}, cmdc.ScalingGroup{}, errors.New("no nodes available, can't create Constellation with one instance")
|
|
|
|
}
|
|
|
|
|
|
|
|
var nodeInstances cmdc.Instances
|
|
|
|
for _, node := range nodeMap {
|
|
|
|
nodeInstances = append(nodeInstances, cmdc.Instance(node))
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: make min / max configurable and abstract autoscaling for different cloud providers
|
|
|
|
// TODO: GroupID of nodes is empty, since they currently do not scale.
|
|
|
|
nodes = cmdc.ScalingGroup{Instances: nodeInstances, GroupID: ""}
|
|
|
|
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func getGCPInstances(stat state.ConstellationState, config *configc.Config) (coordinators, nodes cmdc.ScalingGroup, err error) {
|
2022-04-25 11:21:32 -04:00
|
|
|
coordinatorMap := stat.GCPCoordinators
|
|
|
|
if len(coordinatorMap) == 0 {
|
|
|
|
return cmdc.ScalingGroup{}, cmdc.ScalingGroup{}, errors.New("no coordinators available, can't create Constellation without any instance")
|
|
|
|
}
|
|
|
|
var coordinatorInstances cmdc.Instances
|
|
|
|
for _, node := range coordinatorMap {
|
|
|
|
coordinatorInstances = append(coordinatorInstances, cmdc.Instance(node))
|
2022-03-22 11:03:15 -04:00
|
|
|
}
|
|
|
|
// GroupID of coordinators is empty, since they currently do not scale.
|
2022-04-25 11:21:32 -04:00
|
|
|
coordinators = cmdc.ScalingGroup{
|
|
|
|
Instances: coordinatorInstances,
|
|
|
|
GroupID: "",
|
|
|
|
}
|
2022-03-22 11:03:15 -04:00
|
|
|
|
|
|
|
nodeMap := stat.GCPNodes
|
|
|
|
if len(nodeMap) == 0 {
|
|
|
|
return cmdc.ScalingGroup{}, cmdc.ScalingGroup{}, errors.New("no nodes available, can't create Constellation with one instance")
|
|
|
|
}
|
|
|
|
|
|
|
|
var nodeInstances cmdc.Instances
|
|
|
|
for _, node := range nodeMap {
|
|
|
|
nodeInstances = append(nodeInstances, cmdc.Instance(node))
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: make min / max configurable and abstract autoscaling for different cloud providers
|
|
|
|
nodes = cmdc.ScalingGroup{
|
|
|
|
Instances: nodeInstances,
|
2022-05-16 12:54:25 -04:00
|
|
|
GroupID: gcp.AutoscalingNodeGroup(stat.GCPProject, stat.GCPZone, stat.GCPNodeInstanceGroup, config.AutoscalingNodeGroupsMin, config.AutoscalingNodeGroupsMax),
|
2022-03-22 11:03:15 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-03-25 07:50:07 -04:00
|
|
|
func getAzureInstances(stat state.ConstellationState, _ *configc.Config) (coordinators, nodes cmdc.ScalingGroup, err error) {
|
2022-04-25 11:21:32 -04:00
|
|
|
coordinatorMap := stat.AzureCoordinators
|
|
|
|
if len(coordinatorMap) == 0 {
|
|
|
|
return cmdc.ScalingGroup{}, cmdc.ScalingGroup{}, errors.New("no coordinators available, can't create Constellation without any instance")
|
|
|
|
}
|
|
|
|
var coordinatorInstances cmdc.Instances
|
|
|
|
for _, node := range coordinatorMap {
|
|
|
|
coordinatorInstances = append(coordinatorInstances, cmdc.Instance(node))
|
2022-03-22 11:03:15 -04:00
|
|
|
}
|
|
|
|
// GroupID of coordinators is empty, since they currently do not scale.
|
2022-04-25 11:21:32 -04:00
|
|
|
coordinators = cmdc.ScalingGroup{
|
|
|
|
Instances: coordinatorInstances,
|
|
|
|
GroupID: "",
|
|
|
|
}
|
2022-03-22 11:03:15 -04:00
|
|
|
nodeMap := stat.AzureNodes
|
|
|
|
if len(nodeMap) == 0 {
|
|
|
|
return cmdc.ScalingGroup{}, cmdc.ScalingGroup{}, errors.New("no nodes available, can't create Constellation with one instance")
|
|
|
|
}
|
|
|
|
|
|
|
|
var nodeInstances cmdc.Instances
|
|
|
|
for _, node := range nodeMap {
|
|
|
|
nodeInstances = append(nodeInstances, cmdc.Instance(node))
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: make min / max configurable and abstract autoscaling for different cloud providers
|
|
|
|
nodes = cmdc.ScalingGroup{
|
|
|
|
Instances: nodeInstances,
|
|
|
|
GroupID: "",
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
2022-05-24 03:44:00 -04:00
|
|
|
|
|
|
|
func getQEMUInstances(stat state.ConstellationState, _ *configc.Config) (coordinators, nodes cmdc.ScalingGroup, err error) {
|
|
|
|
coordinatorMap := stat.QEMUCoordinators
|
|
|
|
if len(coordinatorMap) == 0 {
|
|
|
|
return cmdc.ScalingGroup{}, cmdc.ScalingGroup{}, errors.New("no coordinators available, can't create Constellation without any instance")
|
|
|
|
}
|
|
|
|
var coordinatorInstances cmdc.Instances
|
|
|
|
for _, node := range coordinatorMap {
|
|
|
|
coordinatorInstances = append(coordinatorInstances, cmdc.Instance(node))
|
|
|
|
}
|
|
|
|
// GroupID of coordinators is empty, since they currently do not scale.
|
|
|
|
coordinators = cmdc.ScalingGroup{
|
|
|
|
Instances: coordinatorInstances,
|
|
|
|
GroupID: "",
|
|
|
|
}
|
|
|
|
nodeMap := stat.QEMUNodes
|
|
|
|
if len(nodeMap) == 0 {
|
|
|
|
return cmdc.ScalingGroup{}, cmdc.ScalingGroup{}, errors.New("no nodes available, can't create Constellation with one instance")
|
|
|
|
}
|
|
|
|
var nodeInstances cmdc.Instances
|
|
|
|
for _, node := range nodeMap {
|
|
|
|
nodeInstances = append(nodeInstances, cmdc.Instance(node))
|
|
|
|
}
|
|
|
|
nodes = cmdc.ScalingGroup{
|
|
|
|
Instances: nodeInstances,
|
|
|
|
GroupID: "",
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|