A stateless service that provides sealing key functionality for TDX (Trust Domain Extensions) workloads using an SGX (Software Guard Extensions) enclave as a key provider. You can read more about this tool in this blog post.
This service acts as a secure bridge between TDX workloads and SGX sealing keys, allowing TDX workloads to derive unique keys based on their measurements while ensuring they're running on the same platform using PPID verification.
- Stateless design for simplicity and security
- DCAP quote verification for platform validation (configurable)
- Measurement-based key derivation for TDX workloads
- PPID matching to ensure same-platform operation
- Public key encryption of derived keys
- Development mode for testing
- Detailed debug logging for troubleshooting
sequenceDiagram
participant TDX as TDX App
participant SGX as SGX Sealing Provider
participant PCCS as PCCS Server
Note over TDX: Generate keypair
Note over TDX: Include public key in<br/>quote's report data
TDX->>SGX: Send TDX quote
rect rgb(200, 200, 240)
Note over SGX: Development Mode (Optional)
SGX-->>PCCS: Skip quote verification
end
rect rgb(240, 240, 240)
Note over SGX: Production Mode
SGX->>PCCS: Get collateral
PCCS-->>SGX: Return collateral
Note over SGX: Verify TDX quote
end
Note over SGX: Get initial SGX quote
Note over SGX: Early PPID verification
alt PPID Mismatch
SGX-->>TDX: Return error
end
Note over SGX: Extract measurements<br/>from TDX quote
Note over SGX: Get SGX sealing key
Note over SGX: Derive unique key using<br/>measurements
Note over SGX: Extract public key from<br/>quote's report data
Note over SGX: Encrypt derived key<br/>with sealed box
Note over SGX: Calculate hash of<br/>encrypted key
Note over SGX: Get final quote with<br/>hash in report data
SGX->>TDX: Return encrypted key and<br/>provider quote with hash
Note over TDX: Verify provider quote
Note over TDX: Calculate hash of<br/>encrypted key
Note over TDX: Compare with hash in<br/>provider quote
alt Hash Mismatch
TDX-->>TDX: Abort - tampered data
end
Note over TDX: Decrypt key using<br/>private key
- Intel CPU with SGX and TDX support
- Gramine installed (version 1.5 or higher)
- Rust toolchain (tested with rustc 1.82.0)
- DCAP driver and related software stack
- Linux environment (Ubuntu 22.04 LTS)
- Clone the repository:
git clone https://github.com/MoeMahhouk/gramine-sealing-key-provider.git
cd gramine-sealing-key-provider
- Build the project:
# Production build
make SGX=1
# Development build (skips quote verification)
make SGX=1 DEV_MODE=1
# Build with debug logging
make SGX=1 DEBUG=1 DEV_MODE=1
# Copy your TDX quote
cp /path/to/your/tdx_quote /quotes/
# Run the provider in development mode
make SGX=1 DEV_MODE=1 run-provider
# With debug logging
make SGX=1 DEBUG=1 DEV_MODE=1 run-provider
# Run the provider with full security features
make SGX=1 run-provider
# Run the test client python that wraps your quote and sends it to the SGX sealing provider through TCP
python test_client.py
The service outputs the encrypted derived key in hexadecimal format to stdout. In debug mode, it also provides detailed logging about:
- Quote parsing and verification
- PPID comparison
- Measurement extraction
- Key derivation steps
- Encryption process
-
TDX App Preparation:
- Generates a keypair
- Includes public key in quote's report data
- Generates TDX quote
-
Service Operation:
- Receives TDX quote as input
- Verifies quote with DCAP (in production mode)
- Retrieves its own SGX quote and sealing key
- Compares PPIDs from both quotes
- Extracts measurements from TDX quote
- Derives unique key using measurements and SGX sealing key
- Encrypts derived key with public key from quote
- Returns encrypted key
-
TDX App Completion:
- Receives encrypted key
- Decrypts using private key
- Service operates within an SGX enclave
- PPID matching ensures same-platform operation
- Quote verification in production mode
- Public key encryption of derived keys
- Development mode clearly marked with warnings
- Measurement-based key derivation provides unique keys per TDX workload
- Implement Attested TLS (aTLS) connection to the service for secure communication
- Use public key from TDX quote's user report data to encrypt response
- Remove insecure command-line arguments and quotes folder access
- Add quote freshness verification
- Implement rate limiting to prevent abuse
- Support for multiple key derivation algorithms
- Add key rotation capabilities
- Support for key hierarchies
- Add configuration for custom measurement selection
- Implement key usage policies
- Create a proper client SDK
- Add health monitoring endpoints
- Implement proper error handling with detailed error codes
- Add metrics collection
- Create a configuration system for deployment flexibility
- Basic file-based I/O system
- Limited error handling
- No encryption of responses
- Command-line based interface
-
Network Protocol
- Implement a proper RPC or REST API
- Use aTLS for secure communication
- Add authentication mechanisms
-
Key Management
- Support for key hierarchies
- Key rotation policies
- Backup mechanisms
-
Security
- Quote freshness validation
- Response encryption
- Access control mechanisms
-
Monitoring
- Health checks
- Performance metrics
- Audit logging
Contributions are welcome! Please feel free to submit pull requests or open issues for discussion.
This project is licensed under MIT license - see the LICENSE file for details.