]> git.saurik.com Git - apple/security.git/blob - OSX/sec/Security/SecTrustInternal.h
Security-59754.41.1.tar.gz
[apple/security.git] / OSX / sec / Security / SecTrustInternal.h
1 /*
2 * Copyright (c) 2015-2020 Apple Inc. All Rights Reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
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
11 * file.
12 *
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.
20 *
21 * @APPLE_LICENSE_HEADER_END@
22 */
23
24 /*!
25 @header SecTrustInternal
26 This header provides the interface to internal functions used by SecTrust.
27 */
28
29 #ifndef _SECURITY_SECTRUSTINTERNAL_H_
30 #define _SECURITY_SECTRUSTINTERNAL_H_
31
32 #include <Security/SecTrust.h>
33
34 __BEGIN_DECLS
35
36 /* args_in keys. */
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"
48
49 /* args_out keys. */
50 #define kSecTrustDetailsKey "details"
51 #define kSecTrustChainKey "chain"
52 #define kSecTrustResultKey "result"
53 #define kSecTrustInfoKey "info"
54
55 extern const CFStringRef kSecCertificateDetailSHA1Digest;
56
57 #if TARGET_OS_OSX
58 SecKeyRef SecTrustCopyPublicKey_ios(SecTrustRef trust);
59 CFArrayRef SecTrustCopyProperties_ios(SecTrustRef trust);
60 #endif
61
62 #define kSecTrustEventNameKey "eventName"
63 #define kSecTrustEventAttributesKey "eventAttributes"
64 #define kSecTrustEventApplicationID "appID"
65
66 typedef enum {
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;
80
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
93
94 __END_DECLS
95
96 #endif /* !_SECURITY_SECTRUSTINTERNAL_H_ */