[WebAuthN] Enable LocalAuthenticator for macOS
[WebKit-https.git] / Source / WTF / wtf / spi / cocoa / SecuritySPI.h
1 /*
2  * Copyright (C) 2015-2016 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
14  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
15  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
17  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23  * THE POSSIBILITY OF SUCH DAMAGE.
24  */
25
26 #pragma once
27
28 #if USE(APPLE_INTERNAL_SDK)
29
30 #include <Security/SecAccessControlPriv.h>
31 #include <Security/SecCertificatePriv.h>
32 #include <Security/SecIdentityPriv.h>
33 #include <Security/SecItemPriv.h>
34 #include <Security/SecKeyPriv.h>
35 #include <Security/SecTask.h>
36 #include <Security/SecTrustPriv.h>
37
38 #if PLATFORM(MAC)
39 #include <Security/keyTemplates.h>
40 #endif
41
42 #else
43
44 #include <Security/SecBase.h>
45
46 typedef uint32_t SecSignatureHashAlgorithm;
47 enum {
48     kSecSignatureHashAlgorithmUnknown = 0,
49     kSecSignatureHashAlgorithmMD2 = 1,
50     kSecSignatureHashAlgorithmMD4 = 2,
51     kSecSignatureHashAlgorithmMD5 = 3,
52     kSecSignatureHashAlgorithmSHA1 = 4,
53     kSecSignatureHashAlgorithmSHA224 = 5,
54     kSecSignatureHashAlgorithmSHA256 = 6,
55     kSecSignatureHashAlgorithmSHA384 = 7,
56     kSecSignatureHashAlgorithmSHA512 = 8
57 };
58
59 WTF_EXTERN_C_BEGIN
60
61 #if PLATFORM(MAC)
62 OSStatus SecTrustedApplicationCreateFromPath(const char* path, SecTrustedApplicationRef*);
63 #endif
64
65 SecSignatureHashAlgorithm SecCertificateGetSignatureHashAlgorithm(SecCertificateRef);
66 extern const CFStringRef kSecAttrNoLegacy;
67
68 WTF_EXTERN_C_END
69
70 #endif // USE(APPLE_INTERNAL_SDK)
71
72 typedef struct __SecTask *SecTaskRef;
73 typedef struct __SecTrust *SecTrustRef;
74
75 WTF_EXTERN_C_BEGIN
76
77 SecTaskRef SecTaskCreateWithAuditToken(CFAllocatorRef, audit_token_t);
78 SecTaskRef SecTaskCreateFromSelf(CFAllocatorRef);
79 CFTypeRef SecTaskCopyValueForEntitlement(SecTaskRef, CFStringRef entitlement, CFErrorRef*);
80 SecIdentityRef SecIdentityCreate(CFAllocatorRef, SecCertificateRef, SecKeyRef);
81 OSStatus SecKeyFindWithPersistentRef(CFDataRef persistentRef, SecKeyRef* lookedUpData);
82 SecAccessControlRef SecAccessControlCreateFromData(CFAllocatorRef, CFDataRef, CFErrorRef*);
83 CFDataRef SecAccessControlCopyData(SecAccessControlRef);
84
85 #if PLATFORM(MAC)
86 #include <Security/SecAsn1Types.h>
87 CFStringRef SecTaskCopySigningIdentifier(SecTaskRef, CFErrorRef *);
88 extern const SecAsn1Template kSecAsn1AlgorithmIDTemplate[];
89 extern const SecAsn1Template kSecAsn1SubjectPublicKeyInfoTemplate[];
90 uint32_t SecTaskGetCodeSignStatus(SecTaskRef);
91 #endif
92
93 #if HAVE(SEC_TRUST_SERIALIZATION)
94 CF_RETURNS_RETAINED CFDataRef SecTrustSerialize(SecTrustRef, CFErrorRef *);
95 CF_RETURNS_RETAINED SecTrustRef SecTrustDeserialize(CFDataRef serializedTrust, CFErrorRef *);
96 #endif
97
98 CF_RETURNS_RETAINED CFDictionaryRef SecTrustCopyInfo(SecTrustRef);
99
100 extern const CFStringRef kSecTrustInfoExtendedValidationKey;
101 extern const CFStringRef kSecTrustInfoCompanyNameKey;
102 extern const CFStringRef kSecTrustInfoRevocationKey;
103
104 WTF_EXTERN_C_END