]> git.saurik.com Git - apple/security.git/blob - OSX/sec/Security/SecTrustInternal.h
Security-59306.61.1.tar.gz
[apple/security.git] / OSX / sec / Security / SecTrustInternal.h
1 /*
2 * Copyright (c) 2015-2016 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
48 /* args_out keys. */
49 #define kSecTrustDetailsKey "details"
50 #define kSecTrustChainKey "chain"
51 #define kSecTrustResultKey "result"
52 #define kSecTrustInfoKey "info"
53
54 extern const CFStringRef kSecCertificateDetailSHA1Digest;
55
56 #if TARGET_OS_OSX
57 SecKeyRef SecTrustCopyPublicKey_ios(SecTrustRef trust);
58 CFArrayRef SecTrustCopyProperties_ios(SecTrustRef trust);
59 #endif
60
61 #define kSecTrustEventNameKey "eventName"
62 #define kSecTrustEventAttributesKey "eventAttributes"
63 #define kSecTrustEventApplicationID "appID"
64
65 typedef enum {
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;
79
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
92
93 __END_DECLS
94
95 #endif /* !_SECURITY_SECTRUSTINTERNAL_H_ */