1*03ce13f7SAndroid Build Coastguard Worker// Copyright 2020 The SwiftShader Authors. All Rights Reserved. 2*03ce13f7SAndroid Build Coastguard Worker// 3*03ce13f7SAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License"); 4*03ce13f7SAndroid Build Coastguard Worker// you may not use this file except in compliance with the License. 5*03ce13f7SAndroid Build Coastguard Worker// You may obtain a copy of the License at 6*03ce13f7SAndroid Build Coastguard Worker// 7*03ce13f7SAndroid Build Coastguard Worker// http://www.apache.org/licenses/LICENSE-2.0 8*03ce13f7SAndroid Build Coastguard Worker// 9*03ce13f7SAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software 10*03ce13f7SAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS, 11*03ce13f7SAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12*03ce13f7SAndroid Build Coastguard Worker// See the License for the specific language governing permissions and 13*03ce13f7SAndroid Build Coastguard Worker// limitations under the License. 14*03ce13f7SAndroid Build Coastguard Worker 15*03ce13f7SAndroid Build Coastguard Workerpackage util 16*03ce13f7SAndroid Build Coastguard Worker 17*03ce13f7SAndroid Build Coastguard Workerimport ( 18*03ce13f7SAndroid Build Coastguard Worker "fmt" 19*03ce13f7SAndroid Build Coastguard Worker "io" 20*03ce13f7SAndroid Build Coastguard Worker 21*03ce13f7SAndroid Build Coastguard Worker "golang.org/x/crypto/openpgp" 22*03ce13f7SAndroid Build Coastguard Worker) 23*03ce13f7SAndroid Build Coastguard Worker 24*03ce13f7SAndroid Build Coastguard Worker// CheckPGP verifies that data has the PGP signature sig and was signed with the 25*03ce13f7SAndroid Build Coastguard Worker// PGP key key. 26*03ce13f7SAndroid Build Coastguard Workerfunc CheckPGP(data, sig, key io.Reader) error { 27*03ce13f7SAndroid Build Coastguard Worker keyring, err := openpgp.ReadArmoredKeyRing(key) 28*03ce13f7SAndroid Build Coastguard Worker if err != nil { 29*03ce13f7SAndroid Build Coastguard Worker return fmt.Errorf("Failed to read pgp key: %v", err) 30*03ce13f7SAndroid Build Coastguard Worker } 31*03ce13f7SAndroid Build Coastguard Worker 32*03ce13f7SAndroid Build Coastguard Worker if _, err := openpgp.CheckDetachedSignature(keyring, data, sig); err != nil { 33*03ce13f7SAndroid Build Coastguard Worker return fmt.Errorf("Failed to verify pgp: %v", err) 34*03ce13f7SAndroid Build Coastguard Worker } 35*03ce13f7SAndroid Build Coastguard Worker 36*03ce13f7SAndroid Build Coastguard Worker return nil 37*03ce13f7SAndroid Build Coastguard Worker} 38