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  }