From 1c38e252a6d943b27c8c88374d98db889b198d35 Mon Sep 17 00:00:00 2001 From: Herman Slatman Date: Tue, 4 Apr 2023 12:20:31 +0200 Subject: [PATCH] Cast `alg` to a valid `COSEAlgorithmIdentifier` --- acme/challenge.go | 12 +++++++++++- acme/challenge_tpmsimulator_test.go | 2 +- 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/acme/challenge.go b/acme/challenge.go index 6657962e..9b44d020 100644 --- a/acme/challenge.go +++ b/acme/challenge.go @@ -511,6 +511,15 @@ type tpmAttestationData struct { Fingerprint string } +// coseAlgorithmIdentifier models a COSEAlgorithmIdentifier. +// Also see https://www.w3.org/TR/webauthn-2/#sctn-alg-identifier. +type coseAlgorithmIdentifier int32 + +const ( + coseAlgES256 coseAlgorithmIdentifier = -7 + coseAlgRS256 coseAlgorithmIdentifier = -257 +) + func doTPMAttestationFormat(ctx context.Context, prov Provisioner, ch *Challenge, jwk *jose.JSONWebKey, att *attestationObject) (*tpmAttestationData, error) { ver, ok := att.AttStatement["ver"].(string) if !ok { @@ -622,7 +631,8 @@ func doTPMAttestationFormat(ctx context.Context, prov Provisioner, ch *Challenge } // only RS256 and ES256 are allowed - if alg != -257 && alg != -1 { + coseAlg := coseAlgorithmIdentifier(alg) + if coseAlg != coseAlgRS256 && coseAlg != coseAlgES256 { return nil, NewError(ErrorBadAttestationStatementType, "invalid alg %d in attestation statement", alg) } diff --git a/acme/challenge_tpmsimulator_test.go b/acme/challenge_tpmsimulator_test.go index ae6eb210..ba09427b 100644 --- a/acme/challenge_tpmsimulator_test.go +++ b/acme/challenge_tpmsimulator_test.go @@ -515,7 +515,7 @@ func Test_doTPMAttestationFormat(t *testing.T) { AttStatement: map[string]interface{}{ "ver": "2.0", "x5c": []interface{}{akCert.Raw, aca.Intermediate.Raw}, - "alg": int64(-257), // + "alg": int64(-257), // RS256 "sig": params.CreateSignature, "certInfo": params.CreateAttestation, "pubArea": params.Public,