mirror of
https://github.com/edgelesssys/constellation.git
synced 2025-01-23 22:01:14 -05:00
db79784045
* Merge Owner and Cluster ID into single value * Remove aTLS from KMS, as it is no longer used for cluster external communication * Update verify command to use cluster-id instead of unique-id flag * Remove owner ID from init output Signed-off-by: Daniel Weiße <dw@edgeless.systems>
32 lines
906 B
Go
32 lines
906 B
Go
package nodestate
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/edgelesssys/constellation/bootstrapper/role"
|
|
"github.com/edgelesssys/constellation/internal/file"
|
|
)
|
|
|
|
const nodeStatePath = "/run/state/constellation/node_state.json"
|
|
|
|
// NodeState is the state of a constellation node that is required to recover from a reboot.
|
|
// Can be persisted to disk and reloaded later.
|
|
type NodeState struct {
|
|
Role role.Role
|
|
MeasurementSalt []byte
|
|
}
|
|
|
|
// FromFile reads a NodeState from disk.
|
|
func FromFile(fileHandler file.Handler) (*NodeState, error) {
|
|
nodeState := &NodeState{}
|
|
if err := fileHandler.ReadJSON(nodeStatePath, nodeState); err != nil {
|
|
return nil, fmt.Errorf("loading node state: %w", err)
|
|
}
|
|
return nodeState, nil
|
|
}
|
|
|
|
// ToFile writes a NodeState to disk.
|
|
func (nodeState *NodeState) ToFile(fileHandler file.Handler) error {
|
|
return fileHandler.WriteJSON(nodeStatePath, nodeState, file.OptMkdirAll)
|
|
}
|