Skip to content

Commit

Permalink
fix(importX509): handle length encodings better
Browse files Browse the repository at this point in the history
closes #459
  • Loading branch information
panva committed Sep 27, 2022
1 parent 1c303fa commit 47d0d77
Show file tree
Hide file tree
Showing 2 changed files with 51 additions and 12 deletions.
31 changes: 19 additions & 12 deletions src/key/import.ts
Original file line number Diff line number Diff line change
Expand Up @@ -41,20 +41,13 @@ function parseElement(bytes: Uint8Array) {
if (bytes[position] < 0x80) {
length = bytes[position]
position++
} else {
let numberOfDigits = bytes[position] & 0x7f
position++
length = 0
for (let i = 0; i < numberOfDigits; i++) {
length = length * 256 + bytes[position]
position++
}
}

if (length === 0x80) {
} else if (length === 0x80) {
length = 0

while (bytes[position + length] !== 0 || bytes[position + length + 1] !== 0) {
if (length > bytes.byteLength) {
throw new TypeError('invalid indefinite form length')
}
length++
}

Expand All @@ -64,6 +57,14 @@ function parseElement(bytes: Uint8Array) {
contents: bytes.subarray(position, position + length),
raw: bytes.subarray(0, byteLength),
}
} else {
let numberOfDigits = bytes[position] & 0x7f
position++
length = 0
for (let i = 0; i < numberOfDigits; i++) {
length = length * 256 + bytes[position]
position++
}
}

const byteLength = position + length
Expand Down Expand Up @@ -158,7 +159,13 @@ export async function importX509(
if (typeof x509 !== 'string' || x509.indexOf('-----BEGIN CERTIFICATE-----') !== 0) {
throw new TypeError('"x509" must be X.509 formatted string')
}
const spki = getSPKI(x509)
let spki: string
try {
spki = getSPKI(x509)
} catch (cause) {
// @ts-ignore
throw new TypeError('failed to parse the X.509 certificate', { cause })
}
return importPublic(spki, alg, options)
}

Expand Down
32 changes: 32 additions & 0 deletions test/jwk/issue-459.test.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
import test from 'ava'
import { keyRoot } from '../dist.mjs'

const { importX509 } = await import(keyRoot)

const cert = `-----BEGIN CERTIFICATE-----
MIID5jCCAs6gAwIBAgIBAjANBgkqhkiG9w0BAQsFADB7MQswCQYDVQQGEwJVUzEL
MAkGA1UECBMCVE4xEDAOBgNVBAoTB01TSUdOSUExDDAKBgNVBAsTA1JORDEXMBUG
A1UEAxMOTVNJR05JQSBSTkQgQ0ExJjAkBgkqhkiG9w0BCQEWF3BhdmxvLmx5c292
QG1zaWduaWEuY29tMB4XDTE5MTExMzA4MjAwMFoXDTI4MTExMzA4MjAwMFowgYAx
CzAJBgNVBAYTAlVTMQswCQYDVQQIEwJUTjEQMA4GA1UEChMHTVNJR05JQTEUMBIG
A1UECxMLTVNJR05JQSBSTkQxFDASBgNVBAMTC01TSUdOSUEgUk5EMSYwJAYJKoZI
hvcNAQkBFhdwYXZsby5seXNvdkBtc2lnbmlhLmNvbTCCASIwDQYJKoZIhvcNAQEB
BQADggEPADCCAQoCggEBAKRoo30zttpiFlBKnOAmlOcT07xPms7Z6/ZdN9KnE/Po
NQx7g6+Ap6b+trA2WDG80jEtwAy5XJcm81rBvJJvjwWQhiPjhXHvEibl+5zTYEXQ
tvl3qKNdikXuXPBLI/rwmZTNZd2aa5biVoLEY+cQVLOjdAZS9ZIkeuLYeLEZfNky
7rLa4XyRO4W4XEUWgafOp+ZSXATOz48XCb+fmaek4d8epsVJ/X3Qww9I9mqg8QA7
/EH9ASOYvbMzOjSuDjYBCRq4SJw/YBJDnBcBJSESzLJDDCJQyP4BOD2+P5UZ/OWS
NyzEDCLfLsiCVjdt0mNXrn/tGpdLoy1rVfC2SOAoZEUCAwEAAaNvMG0wDAYDVR0T
AQH/BAIwADAdBgNVHQ4EFgQUU/luo/bbBOlrQ7wrC3+ggkITcSYwCwYDVR0PBAQD
AgSwMBEGCWCGSAGG+EIBAQQEAwIFoDAeBglghkgBhvhCAQ0EERYPeGNhIGNlcnRp
ZmljYXRlMA0GCSqGSIb3DQEBCwUAA4IBAQAXroFZ9FeP10gtQguptDo6U0SIAB9n
qjN1IktyqatfUuVtThuxXAb3QQ7kYmGCZEaOIKoFdVc8i9aR5ZrYC1VIN4+cGLv7
P36Zl2q4i2G/X0QzniPPvsPyOUXeTVs3k6Sxe07uWdxsglq9LcVW++PvGYzotZP+
ZtmTzYAQtgadhPNo7+QmTO1FDju9p9hTFK7WhmXAO48bF9jrFiTkbwmo6PdlQiqi
PQYlbfO0XV727QUZ1YyG8rR/3VVRsBOmwZBKCj0dkh9eiRcNpJloqe1uZ83EBG/W
Cic5wE9P+Ol/pFNJFpfjXMsmT8lkCK954aYf2xoH1bHkONYAEEk0iQu/
-----END CERTIFICATE-----`

test('https://github.com/panva/jose/issues/459', (t) => {
return t.notThrowsAsync(() => importX509(cert, 'RS256'))
})

0 comments on commit 47d0d77

Please sign in to comment.