2022-03-22 16:03:15 +01:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
|
|
|
"io"
|
|
|
|
|
2022-06-07 11:08:44 +02:00
|
|
|
"github.com/edgelesssys/constellation/cli/internal/proto"
|
2022-05-16 17:32:00 +02:00
|
|
|
"github.com/edgelesssys/constellation/coordinator/pubapi/pubproto"
|
2022-04-20 15:32:54 +02:00
|
|
|
"github.com/edgelesssys/constellation/coordinator/state"
|
2022-06-01 15:08:42 +02:00
|
|
|
"github.com/edgelesssys/constellation/internal/atls"
|
2022-03-22 16:03:15 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
type stubProtoClient struct {
|
|
|
|
conn bool
|
|
|
|
respClient proto.ActivationResponseClient
|
|
|
|
connectErr error
|
|
|
|
closeErr error
|
2022-04-20 15:32:54 +02:00
|
|
|
getStateErr error
|
2022-03-22 16:03:15 +01:00
|
|
|
activateErr error
|
|
|
|
|
2022-04-20 15:32:54 +02:00
|
|
|
getStateState state.State
|
2022-03-22 16:03:15 +01:00
|
|
|
activateUserPublicKey []byte
|
|
|
|
activateMasterSecret []byte
|
2022-04-25 17:21:58 +02:00
|
|
|
activateNodeIPs []string
|
|
|
|
activateCoordinatorIPs []string
|
2022-03-22 16:03:15 +01:00
|
|
|
activateAutoscalingNodeGroups []string
|
|
|
|
cloudServiceAccountURI string
|
2022-05-16 17:32:00 +02:00
|
|
|
sshUserKeys []*pubproto.SSHUserKey
|
2022-03-22 16:03:15 +01:00
|
|
|
}
|
|
|
|
|
2022-05-06 13:56:02 +02:00
|
|
|
func (c *stubProtoClient) Connect(_ string, _ []atls.Validator) error {
|
2022-03-22 16:03:15 +01:00
|
|
|
c.conn = true
|
|
|
|
return c.connectErr
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *stubProtoClient) Close() error {
|
|
|
|
c.conn = false
|
|
|
|
return c.closeErr
|
|
|
|
}
|
|
|
|
|
2022-04-20 15:32:54 +02:00
|
|
|
func (c *stubProtoClient) GetState(_ context.Context) (state.State, error) {
|
|
|
|
return c.getStateState, c.getStateErr
|
|
|
|
}
|
|
|
|
|
2022-05-16 17:32:00 +02:00
|
|
|
func (c *stubProtoClient) Activate(ctx context.Context, userPublicKey, masterSecret []byte, nodeIPs, coordinatorIPs []string, autoscalingNodeGroups []string, cloudServiceAccountURI string, sshUserKeys []*pubproto.SSHUserKey) (proto.ActivationResponseClient, error) {
|
2022-03-22 16:03:15 +01:00
|
|
|
c.activateUserPublicKey = userPublicKey
|
|
|
|
c.activateMasterSecret = masterSecret
|
2022-04-25 17:21:58 +02:00
|
|
|
c.activateNodeIPs = nodeIPs
|
|
|
|
c.activateCoordinatorIPs = coordinatorIPs
|
2022-03-22 16:03:15 +01:00
|
|
|
c.activateAutoscalingNodeGroups = autoscalingNodeGroups
|
|
|
|
c.cloudServiceAccountURI = cloudServiceAccountURI
|
2022-05-16 17:32:00 +02:00
|
|
|
c.sshUserKeys = sshUserKeys
|
2022-03-22 16:03:15 +01:00
|
|
|
|
|
|
|
return c.respClient, c.activateErr
|
|
|
|
}
|
|
|
|
|
2022-04-25 17:21:58 +02:00
|
|
|
func (c *stubProtoClient) ActivateAdditionalCoordinators(ctx context.Context, ips []string) error {
|
|
|
|
return c.activateErr
|
|
|
|
}
|
|
|
|
|
2022-03-22 16:03:15 +01:00
|
|
|
type stubActivationRespClient struct {
|
|
|
|
nextLogErr *error
|
|
|
|
getKubeconfigErr error
|
|
|
|
getCoordinatorVpnKeyErr error
|
|
|
|
getClientVpnIpErr error
|
|
|
|
getOwnerIDErr error
|
|
|
|
getClusterIDErr error
|
|
|
|
writeLogStreamErr error
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *stubActivationRespClient) NextLog() (string, error) {
|
|
|
|
if s.nextLogErr == nil {
|
|
|
|
return "", io.EOF
|
|
|
|
}
|
|
|
|
return "", *s.nextLogErr
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *stubActivationRespClient) WriteLogStream(io.Writer) error {
|
|
|
|
return s.writeLogStreamErr
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *stubActivationRespClient) GetKubeconfig() (string, error) {
|
|
|
|
return "", s.getKubeconfigErr
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *stubActivationRespClient) GetCoordinatorVpnKey() (string, error) {
|
|
|
|
return "", s.getCoordinatorVpnKeyErr
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *stubActivationRespClient) GetClientVpnIp() (string, error) {
|
|
|
|
return "", s.getClientVpnIpErr
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *stubActivationRespClient) GetOwnerID() (string, error) {
|
|
|
|
return "", s.getOwnerIDErr
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *stubActivationRespClient) GetClusterID() (string, error) {
|
|
|
|
return "", s.getClusterIDErr
|
|
|
|
}
|
|
|
|
|
|
|
|
type fakeProtoClient struct {
|
|
|
|
conn bool
|
|
|
|
respClient proto.ActivationResponseClient
|
|
|
|
}
|
|
|
|
|
2022-05-06 13:56:02 +02:00
|
|
|
func (c *fakeProtoClient) Connect(endpoint string, validators []atls.Validator) error {
|
|
|
|
if endpoint == "" {
|
|
|
|
return errors.New("endpoint is empty")
|
2022-04-19 17:02:02 +02:00
|
|
|
}
|
|
|
|
if len(validators) == 0 {
|
|
|
|
return errors.New("validators is empty")
|
|
|
|
}
|
2022-03-22 16:03:15 +01:00
|
|
|
c.conn = true
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *fakeProtoClient) Close() error {
|
|
|
|
c.conn = false
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-04-20 15:32:54 +02:00
|
|
|
func (c *fakeProtoClient) GetState(_ context.Context) (state.State, error) {
|
|
|
|
if !c.conn {
|
|
|
|
return state.Uninitialized, errors.New("client is not connected")
|
|
|
|
}
|
|
|
|
return state.IsNode, nil
|
|
|
|
}
|
|
|
|
|
2022-05-16 17:32:00 +02:00
|
|
|
func (c *fakeProtoClient) Activate(ctx context.Context, userPublicKey, masterSecret []byte, nodeIPs, coordinatorIPs, autoscalingNodeGroups []string, cloudServiceAccountURI string, sshUserKeys []*pubproto.SSHUserKey) (proto.ActivationResponseClient, error) {
|
2022-03-22 16:03:15 +01:00
|
|
|
if !c.conn {
|
|
|
|
return nil, errors.New("client is not connected")
|
|
|
|
}
|
|
|
|
return c.respClient, nil
|
|
|
|
}
|
|
|
|
|
2022-04-25 17:21:58 +02:00
|
|
|
func (c *fakeProtoClient) ActivateAdditionalCoordinators(ctx context.Context, ips []string) error {
|
|
|
|
if !c.conn {
|
|
|
|
return errors.New("client is not connected")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-03-22 16:03:15 +01:00
|
|
|
type fakeActivationRespClient struct {
|
|
|
|
responses []fakeActivationRespMessage
|
|
|
|
kubeconfig string
|
|
|
|
coordinatorVpnKey string
|
|
|
|
clientVpnIp string
|
|
|
|
ownerID string
|
|
|
|
clusterID string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *fakeActivationRespClient) NextLog() (string, error) {
|
|
|
|
for len(c.responses) > 0 {
|
|
|
|
resp := c.responses[0]
|
|
|
|
c.responses = c.responses[1:]
|
|
|
|
if len(resp.log) > 0 {
|
|
|
|
return resp.log, nil
|
|
|
|
}
|
|
|
|
c.kubeconfig = resp.kubeconfig
|
|
|
|
c.coordinatorVpnKey = resp.coordinatorVpnKey
|
|
|
|
c.clientVpnIp = resp.clientVpnIp
|
|
|
|
c.ownerID = resp.ownerID
|
|
|
|
c.clusterID = resp.clusterID
|
|
|
|
}
|
|
|
|
return "", io.EOF
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *fakeActivationRespClient) WriteLogStream(w io.Writer) error {
|
|
|
|
log, err := c.NextLog()
|
|
|
|
for err == nil {
|
|
|
|
fmt.Fprint(w, log)
|
|
|
|
log, err = c.NextLog()
|
|
|
|
}
|
|
|
|
if !errors.Is(err, io.EOF) {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *fakeActivationRespClient) GetKubeconfig() (string, error) {
|
|
|
|
if c.kubeconfig == "" {
|
|
|
|
return "", errors.New("kubeconfig is empty")
|
|
|
|
}
|
|
|
|
return c.kubeconfig, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *fakeActivationRespClient) GetCoordinatorVpnKey() (string, error) {
|
|
|
|
if c.coordinatorVpnKey == "" {
|
2022-04-27 14:21:36 +02:00
|
|
|
return "", errors.New("control-plane public VPN key is empty")
|
2022-03-22 16:03:15 +01:00
|
|
|
}
|
|
|
|
return c.coordinatorVpnKey, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *fakeActivationRespClient) GetClientVpnIp() (string, error) {
|
|
|
|
if c.clientVpnIp == "" {
|
|
|
|
return "", errors.New("client VPN IP is empty")
|
|
|
|
}
|
|
|
|
return c.clientVpnIp, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *fakeActivationRespClient) GetOwnerID() (string, error) {
|
|
|
|
if c.ownerID == "" {
|
|
|
|
return "", errors.New("init secret is empty")
|
|
|
|
}
|
|
|
|
return c.ownerID, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *fakeActivationRespClient) GetClusterID() (string, error) {
|
|
|
|
if c.clusterID == "" {
|
|
|
|
return "", errors.New("cluster identifier is empty")
|
|
|
|
}
|
|
|
|
return c.clusterID, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type fakeActivationRespMessage struct {
|
|
|
|
log string
|
|
|
|
kubeconfig string
|
|
|
|
coordinatorVpnKey string
|
|
|
|
clientVpnIp string
|
|
|
|
ownerID string
|
|
|
|
clusterID string
|
|
|
|
}
|