mirror of
https://github.com/edgelesssys/constellation.git
synced 2024-12-11 17:04:22 -05:00
77 lines
2.2 KiB
Go
77 lines
2.2 KiB
Go
|
/*
|
||
|
Copyright (c) Edgeless Systems GmbH
|
||
|
|
||
|
SPDX-License-Identifier: AGPL-3.0-only
|
||
|
*/
|
||
|
|
||
|
package config
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
|
||
|
"github.com/edgelesssys/constellation/v2/internal/attestation/measurements"
|
||
|
"github.com/edgelesssys/constellation/v2/internal/variant"
|
||
|
)
|
||
|
|
||
|
// QEMUVTPM is the configuration for QEMU vTPM attestation.
|
||
|
type QEMUVTPM struct {
|
||
|
// description: |
|
||
|
// Expected TPM measurements.
|
||
|
Measurements measurements.M `json:"measurements" yaml:"measurements" validate:"required,no_placeholders"`
|
||
|
}
|
||
|
|
||
|
// GetVariant returns qemu-vtpm as the variant.
|
||
|
func (QEMUVTPM) GetVariant() variant.Variant {
|
||
|
return variant.QEMUVTPM{}
|
||
|
}
|
||
|
|
||
|
// GetMeasurements returns the measurements used for attestation.
|
||
|
func (c QEMUVTPM) GetMeasurements() measurements.M {
|
||
|
return c.Measurements
|
||
|
}
|
||
|
|
||
|
// SetMeasurements updates a config's measurements using the given measurements.
|
||
|
func (c *QEMUVTPM) SetMeasurements(m measurements.M) {
|
||
|
c.Measurements = m
|
||
|
}
|
||
|
|
||
|
// EqualTo returns true if the config is equal to the given config.
|
||
|
func (c QEMUVTPM) EqualTo(other AttestationCfg) (bool, error) {
|
||
|
otherCfg, ok := other.(*QEMUVTPM)
|
||
|
if !ok {
|
||
|
return false, fmt.Errorf("cannot compare %T with %T", c, other)
|
||
|
}
|
||
|
return c.Measurements.EqualTo(otherCfg.Measurements), nil
|
||
|
}
|
||
|
|
||
|
// QEMUTDX is the configuration for QEMU TDX attestation.
|
||
|
type QEMUTDX struct {
|
||
|
// description: |
|
||
|
// Expected TDX measurements.
|
||
|
Measurements measurements.M `json:"measurements" yaml:"measurements" validate:"required,no_placeholders"`
|
||
|
}
|
||
|
|
||
|
// GetVariant returns qemu-tdx as the variant.
|
||
|
func (QEMUTDX) GetVariant() variant.Variant {
|
||
|
return variant.QEMUTDX{}
|
||
|
}
|
||
|
|
||
|
// GetMeasurements returns the measurements used for attestation.
|
||
|
func (c QEMUTDX) GetMeasurements() measurements.M {
|
||
|
return c.Measurements
|
||
|
}
|
||
|
|
||
|
// SetMeasurements updates a config's measurements using the given measurements.
|
||
|
func (c *QEMUTDX) SetMeasurements(m measurements.M) {
|
||
|
c.Measurements = m
|
||
|
}
|
||
|
|
||
|
// EqualTo returns true if the config is equal to the given config.
|
||
|
func (c QEMUTDX) EqualTo(other AttestationCfg) (bool, error) {
|
||
|
otherCfg, ok := other.(*QEMUTDX)
|
||
|
if !ok {
|
||
|
return false, fmt.Errorf("cannot compare %T with %T", c, other)
|
||
|
}
|
||
|
return c.Measurements.EqualTo(otherCfg.Measurements), nil
|
||
|
}
|