mirror of
https://github.com/edgelesssys/constellation.git
synced 2024-12-27 00:19:36 -05:00
e350ca0f57
* Implement Azure TDX attestation primitives * Add default measurements and claims for Azure TDX * Enable Constellation on Azure TDX --------- Signed-off-by: Daniel Weiße <dw@edgeless.systems>
44 lines
1.4 KiB
Go
44 lines
1.4 KiB
Go
/*
|
|
Copyright (c) Edgeless Systems GmbH
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
package cmd
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/edgelesssys/constellation/v2/cli/internal/cloudcmd"
|
|
"github.com/edgelesssys/constellation/v2/cli/internal/terraform"
|
|
"github.com/edgelesssys/constellation/v2/internal/attestation/variant"
|
|
"github.com/edgelesssys/constellation/v2/internal/cloud/cloudprovider"
|
|
"github.com/edgelesssys/constellation/v2/internal/cloud/gcpshared"
|
|
"github.com/edgelesssys/constellation/v2/internal/config"
|
|
"github.com/edgelesssys/constellation/v2/internal/constellation/state"
|
|
)
|
|
|
|
type cloudApplier interface {
|
|
Plan(ctx context.Context, conf *config.Config) (bool, error)
|
|
Apply(ctx context.Context, csp cloudprovider.Provider, variant variant.Variant, rollback cloudcmd.RollbackBehavior) (state.Infrastructure, error)
|
|
RestoreWorkspace() error
|
|
WorkingDirIsEmpty() (bool, error)
|
|
}
|
|
|
|
type cloudIAMCreator interface {
|
|
Create(
|
|
ctx context.Context,
|
|
provider cloudprovider.Provider,
|
|
opts *cloudcmd.IAMConfigOptions,
|
|
) (cloudcmd.IAMOutput, error)
|
|
}
|
|
|
|
type iamDestroyer interface {
|
|
DestroyIAMConfiguration(ctx context.Context, tfWorkspace string, logLevel terraform.LogLevel) error
|
|
GetTfStateServiceAccountKey(ctx context.Context, tfWorkspace string) (gcpshared.ServiceAccountKey, error)
|
|
}
|
|
|
|
type cloudTerminator interface {
|
|
Terminate(ctx context.Context, workspace string, logLevel terraform.LogLevel) error
|
|
}
|