gecko-dev/security/certverifier/ExtendedValidation.h
2021-04-16 22:32:35 +00:00

47 lines
1.3 KiB
C++

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef ExtendedValidation_h
#define ExtendedValidation_h
#include "ScopedNSSTypes.h"
#include "certt.h"
namespace mozilla {
namespace pkix {
struct CertPolicyId;
} // namespace pkix
} // namespace mozilla
namespace mozilla {
namespace psm {
nsresult LoadExtendedValidationInfo();
/**
* Finds the first policy OID in the given cert that is known to be an EV policy
* OID.
*
* @param cert
* The cert to find the first EV policy of.
* @param policy
* The found policy.
* @param policyOidTag
* The OID tag of the found policy.
* @return true if a suitable policy was found, false otherwise.
*/
bool GetFirstEVPolicy(const nsTArray<uint8_t>& cert,
/*out*/ mozilla::pkix::CertPolicyId& policy);
// CertIsAuthoritativeForEVPolicy does NOT evaluate whether the cert is trusted
// or distrusted.
bool CertIsAuthoritativeForEVPolicy(const nsTArray<uint8_t>& cert,
const mozilla::pkix::CertPolicyId& policy);
} // namespace psm
} // namespace mozilla
#endif // ExtendedValidation_h