mirror of
				https://github.com/siderolabs/talos.git
				synced 2025-10-26 22:11:38 +01:00 
			
		
		
		
	This implements the first round of changes, replacing the volume backend with the new implementation, while keeping most of the external interfaces intact. See #8367 Signed-off-by: Andrey Smirnov <andrey.smirnov@siderolabs.com>
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // This Source Code Form is subject to the terms of the Mozilla Public
 | |
| // License, v. 2.0. If a copy of the MPL was not distributed with this
 | |
| // file, You can obtain one at http://mozilla.org/MPL/2.0/.
 | |
| 
 | |
| // Package keys contains various encryption KeyHandler implementations.
 | |
| package keys
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"errors"
 | |
| 	"fmt"
 | |
| 
 | |
| 	"github.com/siderolabs/go-blockdevice/v2/encryption"
 | |
| 	"github.com/siderolabs/go-blockdevice/v2/encryption/token"
 | |
| 
 | |
| 	"github.com/siderolabs/talos/pkg/machinery/resources/block"
 | |
| )
 | |
| 
 | |
| var errNoSystemInfoGetter = errors.New("the UUID getter is not set")
 | |
| 
 | |
| // NewHandler key using provided config.
 | |
| func NewHandler(cfg block.EncryptionKey, options ...KeyOption) (Handler, error) {
 | |
| 	opts, err := NewDefaultOptions(options)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	key := KeyHandler{slot: cfg.Slot}
 | |
| 
 | |
| 	switch cfg.Type {
 | |
| 	case block.EncryptionKeyStatic:
 | |
| 		k := cfg.StaticPassphrase
 | |
| 		if k == nil {
 | |
| 			return nil, errors.New("static key must have key data defined")
 | |
| 		}
 | |
| 
 | |
| 		return NewStaticKeyHandler(key, k), nil
 | |
| 	case block.EncryptionKeyNodeID:
 | |
| 		if opts.GetSystemInformation == nil {
 | |
| 			return nil, fmt.Errorf("failed to create nodeUUID key handler at slot %d: %w", cfg.Slot, errNoSystemInfoGetter)
 | |
| 		}
 | |
| 
 | |
| 		return NewNodeIDKeyHandler(key, opts.VolumeID, opts.GetSystemInformation), nil
 | |
| 	case block.EncryptionKeyKMS:
 | |
| 		if opts.GetSystemInformation == nil {
 | |
| 			return nil, fmt.Errorf("failed to create KMS key handler at slot %d: %w", cfg.Slot, errNoSystemInfoGetter)
 | |
| 		}
 | |
| 
 | |
| 		return NewKMSKeyHandler(key, cfg.KMSEndpoint, opts.GetSystemInformation)
 | |
| 	case block.EncryptionKeyTPM:
 | |
| 		return NewTPMKeyHandler(key, cfg.TPMCheckSecurebootStatusOnEnroll)
 | |
| 	default:
 | |
| 		return nil, fmt.Errorf("unsupported key type: %s", cfg.Type)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // Handler manages key lifecycle.
 | |
| type Handler interface {
 | |
| 	NewKey(context.Context) (*encryption.Key, token.Token, error)
 | |
| 	GetKey(context.Context, token.Token) (*encryption.Key, error)
 | |
| 	Slot() int
 | |
| }
 | |
| 
 | |
| // KeyHandler is the base class for all key handlers.
 | |
| type KeyHandler struct {
 | |
| 	slot int
 | |
| }
 | |
| 
 | |
| // Slot implements Handler interface.
 | |
| func (k *KeyHandler) Slot() int {
 | |
| 	return k.slot
 | |
| }
 | |
| 
 | |
| // ErrTokenInvalid is returned by the keys handler if the supplied token is not valid.
 | |
| var ErrTokenInvalid = errors.New("invalid token")
 |