constellation/internal/cloud/metadata/metadata.go

67 lines
1.9 KiB
Go
Raw Normal View History

/*
Copyright (c) Edgeless Systems GmbH
SPDX-License-Identifier: AGPL-3.0-only
*/
2022-06-21 15:59:12 +00:00
package metadata
import (
"context"
"fmt"
"net"
"strconv"
2022-09-21 11:47:57 +00:00
"github.com/edgelesssys/constellation/v2/internal/constants"
"github.com/edgelesssys/constellation/v2/internal/role"
2022-06-21 15:59:12 +00:00
)
// InstanceMetadata describes metadata of a peer.
2022-06-21 15:59:12 +00:00
type InstanceMetadata struct {
Name string
ProviderID string
Role role.Role
// VPCIP is the primary IP address of the instance in the VPC.
VPCIP string
// PublicIP is the primary public IP of the instance, if available, empty string otherwise.
2022-10-25 22:27:40 +00:00
PublicIP string
2022-06-21 15:59:12 +00:00
// SSHKeys maps usernames to ssh public keys.
SSHKeys map[string][]string
2022-10-25 22:27:40 +00:00
// SecondaryIPRange is the VPC wide CIDR from which subnets are attached to VMs as AliasIPRanges.
// May be empty on certain CSPs.
SecondaryIPRange string
// AliasIPRanges is a list of IP ranges that are attached.
// May be empty on certain CSPs.
2022-10-25 22:27:40 +00:00
AliasIPRanges []string
2022-06-21 15:59:12 +00:00
}
2022-06-28 14:08:05 +00:00
type InstanceSelfer interface {
// Self retrieves the current instance.
Self(ctx context.Context) (InstanceMetadata, error)
}
type InstanceLister interface {
// List retrieves all instances belonging to the current constellation.
List(ctx context.Context) ([]InstanceMetadata, error)
}
// JoinServiceEndpoints returns the list of endpoints for the join service, which are running on the control plane nodes.
func JoinServiceEndpoints(ctx context.Context, lister InstanceLister) ([]string, error) {
2022-06-29 14:17:23 +00:00
instances, err := lister.List(ctx)
if err != nil {
return nil, fmt.Errorf("retrieving instances list from cloud provider: %w", err)
}
joinEndpoints := []string{}
2022-06-29 14:17:23 +00:00
for _, instance := range instances {
if instance.Role == role.ControlPlane {
if instance.VPCIP != "" {
joinEndpoints = append(joinEndpoints, net.JoinHostPort(instance.VPCIP, strconv.Itoa(constants.JoinServiceNodePort)))
2022-06-29 14:17:23 +00:00
}
}
}
return joinEndpoints, nil
2022-06-29 14:17:23 +00:00
}