2 * Copyright (c) 2015-2020 Apple Inc. All Rights Reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
21 * @APPLE_LICENSE_HEADER_END@
25 @header SecTrustInternal
26 This header provides the interface to internal functions used by SecTrust.
29 #ifndef _SECURITY_SECTRUSTINTERNAL_H_
30 #define _SECURITY_SECTRUSTINTERNAL_H_
32 #include <Security/SecTrust.h>
37 #define kSecTrustCertificatesKey "certificates"
38 #define kSecTrustAnchorsKey "anchors"
39 #define kSecTrustAnchorsOnlyKey "anchorsOnly"
40 #define kSecTrustKeychainsAllowedKey "keychainsAllowed"
41 #define kSecTrustPoliciesKey "policies"
42 #define kSecTrustResponsesKey "responses"
43 #define kSecTrustSCTsKey "scts"
44 #define kSecTrustTrustedLogsKey "trustedLogs"
45 #define kSecTrustVerifyDateKey "verifyDate"
46 #define kSecTrustExceptionsKey "exceptions"
47 #define kSecTrustRevocationAdditionsKey "revocationCheck"
50 #define kSecTrustDetailsKey "details"
51 #define kSecTrustChainKey "chain"
52 #define kSecTrustResultKey "result"
53 #define kSecTrustInfoKey "info"
55 extern const CFStringRef kSecCertificateDetailSHA1Digest
;
58 SecKeyRef
SecTrustCopyPublicKey_ios(SecTrustRef trust
);
59 CFArrayRef
SecTrustCopyProperties_ios(SecTrustRef trust
);
62 #define kSecTrustEventNameKey "eventName"
63 #define kSecTrustEventAttributesKey "eventAttributes"
64 #define kSecTrustEventApplicationID "appID"
67 kSecTrustErrorSubTypeBlocked
,
68 kSecTrustErrorSubTypeRevoked
,
69 kSecTrustErrorSubTypeKeySize
,
70 kSecTrustErrorSubTypeWeakHash
,
71 kSecTrustErrorSubTypeDenied
,
72 kSecTrustErrorSubTypeCompliance
,
73 kSecTrustErrorSubTypePinning
,
74 kSecTrustErrorSubTypeTrust
,
75 kSecTrustErrorSubTypeUsage
,
76 kSecTrustErrorSubTypeName
,
77 kSecTrustErrorSubTypeExpired
,
78 kSecTrustErrorSubTypeInvalid
,
79 } SecTrustErrorSubType
;
81 #define __PC_SUBTYPE_ kSecTrustErrorSubTypeInvalid
82 #define __PC_SUBTYPE_N kSecTrustErrorSubTypeName
83 #define __PC_SUBTYPE_E kSecTrustErrorSubTypeExpired
84 #define __PC_SUBTYPE_S kSecTrustErrorSubTypeKeySize
85 #define __PC_SUBTYPE_H kSecTrustErrorSubTypeWeakHash
86 #define __PC_SUBTYPE_U kSecTrustErrorSubTypeUsage
87 #define __PC_SUBTYPE_P kSecTrustErrorSubTypePinning
88 #define __PC_SUBTYPE_V kSecTrustErrorSubTypeRevoked
89 #define __PC_SUBTYPE_T kSecTrustErrorSubTypeTrust
90 #define __PC_SUBTYPE_C kSecTrustErrorSubTypeCompliance
91 #define __PC_SUBTYPE_D kSecTrustErrorSubTypeDenied
92 #define __PC_SUBTYPE_B kSecTrustErrorSubTypeBlocked
96 #endif /* !_SECURITY_SECTRUSTINTERNAL_H_ */