2 * Copyright (c) 2015-2016 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"
49 #define kSecTrustDetailsKey "details"
50 #define kSecTrustChainKey "chain"
51 #define kSecTrustResultKey "result"
52 #define kSecTrustInfoKey "info"
54 extern const CFStringRef kSecCertificateDetailSHA1Digest
;
57 SecKeyRef
SecTrustCopyPublicKey_ios(SecTrustRef trust
);
58 CFArrayRef
SecTrustCopyProperties_ios(SecTrustRef trust
);
61 #define kSecTrustEventNameKey "eventName"
62 #define kSecTrustEventAttributesKey "eventAttributes"
63 #define kSecTrustEventApplicationID "appID"
66 kSecTrustErrorSubTypeBlocked
,
67 kSecTrustErrorSubTypeRevoked
,
68 kSecTrustErrorSubTypeKeySize
,
69 kSecTrustErrorSubTypeWeakHash
,
70 kSecTrustErrorSubTypeDenied
,
71 kSecTrustErrorSubTypeCompliance
,
72 kSecTrustErrorSubTypePinning
,
73 kSecTrustErrorSubTypeTrust
,
74 kSecTrustErrorSubTypeUsage
,
75 kSecTrustErrorSubTypeName
,
76 kSecTrustErrorSubTypeExpired
,
77 kSecTrustErrorSubTypeInvalid
,
78 } SecTrustErrorSubType
;
80 #define __PC_SUBTYPE_ kSecTrustErrorSubTypeInvalid
81 #define __PC_SUBTYPE_N kSecTrustErrorSubTypeName
82 #define __PC_SUBTYPE_E kSecTrustErrorSubTypeExpired
83 #define __PC_SUBTYPE_S kSecTrustErrorSubTypeKeySize
84 #define __PC_SUBTYPE_H kSecTrustErrorSubTypeWeakHash
85 #define __PC_SUBTYPE_U kSecTrustErrorSubTypeUsage
86 #define __PC_SUBTYPE_P kSecTrustErrorSubTypePinning
87 #define __PC_SUBTYPE_V kSecTrustErrorSubTypeRevoked
88 #define __PC_SUBTYPE_T kSecTrustErrorSubTypeTrust
89 #define __PC_SUBTYPE_C kSecTrustErrorSubTypeCompliance
90 #define __PC_SUBTYPE_D kSecTrustErrorSubTypeDenied
91 #define __PC_SUBTYPE_B kSecTrustErrorSubTypeBlocked
95 #endif /* !_SECURITY_SECTRUSTINTERNAL_H_ */