[WebAuthN] Implement authenticatorMakeCredential
[WebKit-https.git] / Source / WebCore / Modules / webauthn / cocoa / LocalAuthenticator.h
1 /*
2  * Copyright (C) 2018 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 ENABLE(WEB_AUTHN)
29
30 #include <wtf/Forward.h>
31 #include <wtf/Noncopyable.h>
32 #include <wtf/WeakPtr.h>
33
34 namespace WebCore {
35
36 struct ExceptionData;
37 struct PublicKeyCredentialCreationOptions;
38
39 using CreationCallback = Function<void(const Vector<uint8_t>&, const Vector<uint8_t>&)>;
40 using ExceptionCallback = Function<void(const WebCore::ExceptionData&)>;
41
42 typedef void (^CompletionBlock)(SecKeyRef _Nullable referenceKey, NSArray * _Nullable certificates, NSError * _Nullable error);
43
44 // FIXME(182769): LocalAuthenticator should belongs to WebKit. However, we need unit tests.
45 class WEBCORE_EXPORT LocalAuthenticator {
46     WTF_MAKE_NONCOPYABLE(LocalAuthenticator);
47 public:
48     LocalAuthenticator() = default;
49     virtual ~LocalAuthenticator() = default;
50
51     void makeCredential(const Vector<uint8_t>& hash, const PublicKeyCredentialCreationOptions&, CreationCallback&&, ExceptionCallback&&);
52     bool isAvailable() const;
53
54 protected:
55     // Apple Attestation is moved into this virtual method such that it can be overrided by self attestation for testing.
56     virtual void issueClientCertificate(const String& rpId, const String& username, const Vector<uint8_t>& hash, CompletionBlock _Nonnull) const;
57
58     WeakPtrFactory<LocalAuthenticator> m_weakFactory;
59 };
60
61 } // namespace WebCore
62
63 #endif // ENABLE(WEB_AUTHN)