github.com/zmap/zcrypto@v0.0.0-20240512203510-0fef58d9a9db/verifier/builtins.go (about) 1 /* 2 * ZCrypto Copyright 2017 Regents of the University of Michigan 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); you may not 5 * use this file except in compliance with the License. You may obtain a copy 6 * of the License at http://www.apache.org/licenses/LICENSE-2.0 7 * 8 * Unless required by applicable law or agreed to in writing, software 9 * distributed under the License is distributed on an "AS IS" BASIS, 10 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or 11 * implied. See the License for the specific language governing 12 * permissions and limitations under the License. 13 */ 14 15 package verifier 16 17 // NewNSS returns a new verifier mimicking NSS. 18 func NewNSS(pki *Graph) (nss *Verifier) { 19 nss = NewVerifier(pki, &VerifyProcedureNSS{}) 20 return 21 } 22 23 // NewMicrosoft returns a new verifier mimicking Microsoft SChannel. 24 func NewMicrosoft(pki *Graph) (microsoft *Verifier) { 25 microsoft = NewVerifier(pki, &VerifyProcedureMicrosoft{}) 26 return 27 } 28 29 // NewApple returns a new verifier mimicking Apple SecureTransport. 30 func NewApple(pki *Graph) (apple *Verifier) { 31 apple = NewVerifier(pki, &VerifyProcedureApple{}) 32 return 33 } 34 35 // NewJava returns a new verifier mimicking javax.net.ssl. 36 func NewJava(pki *Graph) (java *Verifier) { 37 java = NewVerifier(pki, &VerifyProcedureJava{}) 38 return 39 } 40 41 // NewGoogleCTPrimary returns a new verifier mimicking the behavior of the 42 // primary Google CT logs (e.g. Pilot). 43 func NewGoogleCTPrimary(pki *Graph) (gct *Verifier) { 44 gct = NewVerifier(pki, &VerifyProcedureGoogleCTPrimary{}) 45 return 46 }