| // Copyright 2020 The Go Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style |
| // license that can be found in the LICENSE file. |
| // ecdsa.VerifyASN1 was added in Go 1.15. |
| "golang.org/x/crypto/cryptobyte" |
| "golang.org/x/crypto/cryptobyte/asn1" |
| func verifyASN1(pub *ecdsa.PublicKey, hash, sig []byte) bool { |
| r, s = &big.Int{}, &big.Int{} |
| input := cryptobyte.String(sig) |
| if !input.ReadASN1(&inner, asn1.SEQUENCE) || |
| !inner.ReadASN1Integer(r) || |
| !inner.ReadASN1Integer(s) || |
| return ecdsa.Verify(pub, hash, r, s) |