mirror of
https://github.com/edgelesssys/constellation.git
synced 2025-01-04 04:10:59 -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>
46 lines
1.3 KiB
Go
46 lines
1.3 KiB
Go
package setup
|
|
|
|
import (
|
|
"io/fs"
|
|
"os"
|
|
"syscall"
|
|
)
|
|
|
|
// Mounter is an interface for mount and unmount operations.
|
|
type Mounter interface {
|
|
Mount(source string, target string, fstype string, flags uintptr, data string) error
|
|
Unmount(target string, flags int) error
|
|
MkdirAll(path string, perm fs.FileMode) error
|
|
}
|
|
|
|
// DeviceMapper is an interface for device mapping operations.
|
|
type DeviceMapper interface {
|
|
DiskUUID() string
|
|
FormatDisk(passphrase string) error
|
|
MapDisk(target string, passphrase string) error
|
|
}
|
|
|
|
// KeyWaiter is an interface to request and wait for disk decryption keys.
|
|
type KeyWaiter interface {
|
|
WaitForDecryptionKey(uuid, addr string) (diskKey, measurementSecret []byte, err error)
|
|
ResetKey()
|
|
}
|
|
|
|
// DiskMounter uses the syscall package to mount disks.
|
|
type DiskMounter struct{}
|
|
|
|
// Mount performs a mount syscall.
|
|
func (m DiskMounter) Mount(source string, target string, fstype string, flags uintptr, data string) error {
|
|
return syscall.Mount(source, target, fstype, flags, data)
|
|
}
|
|
|
|
// Unmount performs an unmount syscall.
|
|
func (m DiskMounter) Unmount(target string, flags int) error {
|
|
return syscall.Unmount(target, flags)
|
|
}
|
|
|
|
// MkdirAll uses os.MkdirAll to create the directory.
|
|
func (m DiskMounter) MkdirAll(path string, perm fs.FileMode) error {
|
|
return os.MkdirAll(path, perm)
|
|
}
|