* build: correct toolchain order * build: gazelle-update-repos * build: use pregenerated proto for dependencies * update bazeldnf * deps: tpm simulator * Update Google trillian module * cli: add stamping as alternative build info source * bazel: add go_test wrappers, mark special tests and select testing deps * deps: add libvirt deps * deps: go-libvirt patches * deps: cloudflare circl patches * bazel: add go_test wrappers, mark special tests and select testing deps * bazel: keep gazelle overrides * bazel: cleanup bazelrc * bazel: switch CMakeLists.txt to use bazel * bazel: fix injection of version information via stamping * bazel: commit all build files * dev-docs: document bazel usage * deps: upgrade zig-cc for go 1.20 * bazel: update Perl for macOS arm64 & Linux arm64 support * bazel: use static perl toolchain for OpenSSL * bazel: use static protobuf (protoc) toolchain * deps: add git and go to nix deps Co-authored-by: Paul Meyer <49727155+katexochen@users.noreply.github.com>
Attested TLS (aTLS)
In a confidential computing (CC) environment, attested TLS (aTLS) can be used to establish secure connections between two parties utilizing the remote attestation features of the CC components.
aTLS modifies the TLS handshake by embedding an attestation statement into the TLS certificate. Instead of relying on a Certificate Authority, aTLS uses this attestation statement to establish trust in the certificate.
The protocol can be used by clients to verify a server certificate, by a server to verify a client certificate, or for mutual verification (mutual aTLS).
Client side verification
-
The client sends a ClientHello message, setting ServerName to a random nonce.
-
The server generates an attestation statement using the clients nonce and its CC capabilities.
- The attestation is embedded in the server certificate using x509 certificate extensions with an object identifier (OID) to identify the CC attestation type. See OID for implementation details.
-
The client verifies the attestation statement.
-
If successful the client can trust the server to be running the expected configuration, and finish the TLS handshake.
sequenceDiagram
participant Client
participant Server
Client->>Server: ClientHello(nonce)
Server->>Client: ServerCertificate(AttestationStatement), ServerHelloDone
Note over Client: Verify Attestation
Client->>Server: ClientKeyExchange
Client->>Server: ChangeCipherSpec, Finished
Server->>Client: #
Server side verification
-
The client sends a ClientHello message
-
The server sends back a certificate and a random nonce. The nonce is encoded as the Distinguished Name of an acceptable CA.
-
The client does not verify the servers certificate, but uses the nonce to generate an attestation based on its CC capabilities.
- The attestation is embedded in the client certificate using x509 certificate extensions with an OID to identify the CC attestation type.
-
The server verifies the client's attestation statement.
-
If successful the server can trust the client to be running the expected configuration, and finish the TLS handshake.
sequenceDiagram
participant Client
participant Server
Client->>Server: ClientHello
Server->>Client: ServerCertificate, AcceptableCAs(nonce), ServerHelloDone
Client->>Server: ClientKeyExchange, ClientCertificate(AttestationStatement)
Client->>Server: ChangeCipherSpec, Finished
Note over Server: Verify Attestation
Server->>Client: ChangeCipherSpec, Finished
Mutual aTLS
-
The client sends a ClientHello message, setting ServerName to a random nonce.
-
The server generates an attestation statement using the clients nonce and its CC capabilities.
- The attestation is embedded in the server certificate using x509 certificate extensions with an OID to identify the attestation type.
- A nonce is encoded as the Distinguished Name of an acceptable CA.
-
The client verifies the attestation statement.
-
The client uses the nonce to generate an attestation based on its CC capabilities.
- The attestation is embedded in the client certificate using x509 certificate extensions with an OID to identify the CC attestation type.
-
The server verifies the client's attestation statement.
-
If all verifications were successful, mutual trust in each others configuration is established, and the TLS handshake can be finished.
sequenceDiagram
participant Client
participant Server
Client->>Server: ClientHello(nonce)
Server->>Client: ServerCertificate(AttestationStatement), AcceptableCAs(nonce), ServerHelloDone
Note over Client: Verify Attestation
Client->>Server: ClientKeyExchange, ClientCertificate(AttestationStatement)
Client->>Server: ChangeCipherSpec, Finished
Note over Server: Verify Attestation
Server->>Client: ChangeCipherSpec, Finished