2022-03-22 16:03:15 +01:00
|
|
|
package pubapi
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
|
|
|
"github.com/edgelesssys/constellation/coordinator/peer"
|
2022-06-13 16:23:19 +02:00
|
|
|
"github.com/edgelesssys/constellation/coordinator/pubapi/pubproto"
|
2022-04-13 09:18:32 +02:00
|
|
|
"github.com/edgelesssys/constellation/coordinator/role"
|
2022-03-22 16:03:15 +01:00
|
|
|
"github.com/edgelesssys/constellation/coordinator/state"
|
2022-06-15 16:00:48 +02:00
|
|
|
attestationtypes "github.com/edgelesssys/constellation/internal/attestation/types"
|
2022-05-16 17:32:00 +02:00
|
|
|
"github.com/edgelesssys/constellation/internal/deploy/ssh"
|
2022-06-29 16:13:01 +02:00
|
|
|
kms "github.com/edgelesssys/constellation/kms/setup"
|
2022-03-22 16:03:15 +01:00
|
|
|
kubeadm "k8s.io/kubernetes/cmd/kubeadm/app/apis/kubeadm/v1beta3"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Core interface {
|
|
|
|
GetVPNPubKey() ([]byte, error)
|
|
|
|
SetVPNIP(string) error
|
2022-04-13 12:39:55 +02:00
|
|
|
GetVPNIP() (string, error)
|
2022-03-30 14:28:14 +02:00
|
|
|
InitializeStoreIPs() error
|
|
|
|
GetNextNodeIP() (string, error)
|
2022-04-13 12:39:55 +02:00
|
|
|
GetNextCoordinatorIP() (string, error)
|
2022-03-22 16:03:15 +01:00
|
|
|
SwitchToPersistentStore() error
|
|
|
|
GetIDs(masterSecret []byte) (ownerID []byte, clusterID []byte, err error)
|
2022-04-28 10:10:02 +02:00
|
|
|
PersistNodeState(role role.Role, vpnIP string, ownerID []byte, clusterID []byte) error
|
2022-03-22 16:03:15 +01:00
|
|
|
SetUpKMS(ctx context.Context, storageURI, kmsURI, kekID string, useExisting bool) error
|
2022-04-20 15:22:39 +02:00
|
|
|
GetKMSInfo() (kms.KMSInformation, error)
|
2022-04-12 14:24:36 +02:00
|
|
|
GetDataKey(ctx context.Context, keyID string, length int) ([]byte, error)
|
2022-04-20 11:38:56 +02:00
|
|
|
GetDiskUUID() (string, error)
|
|
|
|
UpdateDiskPassphrase(passphrase string) error
|
2022-03-22 16:03:15 +01:00
|
|
|
|
|
|
|
GetState() state.State
|
|
|
|
RequireState(...state.State) error
|
|
|
|
AdvanceState(newState state.State, ownerID, clusterID []byte) error
|
|
|
|
|
|
|
|
GetPeers(resourceVersion int) (int, []peer.Peer, error)
|
|
|
|
AddPeer(peer.Peer) error
|
2022-04-13 12:39:55 +02:00
|
|
|
AddPeerToStore(peer.Peer) error
|
|
|
|
AddPeerToVPN(peer.Peer) error
|
2022-03-22 16:03:15 +01:00
|
|
|
UpdatePeers([]peer.Peer) error
|
|
|
|
|
2022-05-16 17:32:00 +02:00
|
|
|
CreateSSHUsers([]ssh.UserKey) error
|
|
|
|
|
2022-06-15 16:00:48 +02:00
|
|
|
InitCluster(
|
|
|
|
ctx context.Context, autoscalingNodeGroups []string, cloudServiceAccountURI string, id attestationtypes.ID, masterSecret []byte, sshUserKeys []*pubproto.SSHUserKey,
|
|
|
|
) ([]byte, error)
|
2022-05-24 10:04:42 +02:00
|
|
|
JoinCluster(ctx context.Context, joinToken *kubeadm.BootstrapTokenDiscovery, certificateKey string, role role.Role) error
|
2022-03-22 16:03:15 +01:00
|
|
|
}
|