1 | /* |
2 | * Copyright (C) 2010 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 | #include "config.h" |
27 | #include "AuthenticationChallengeProxy.h" |
28 | |
29 | #include "AuthenticationChallengeDisposition.h" |
30 | #include "AuthenticationDecisionListener.h" |
31 | #include "AuthenticationManager.h" |
32 | #include "AuthenticationManagerMessages.h" |
33 | #include "AuxiliaryProcessProxy.h" |
34 | #include "WebCertificateInfo.h" |
35 | #include "WebCoreArgumentCoders.h" |
36 | #include "WebCredential.h" |
37 | #include "WebProcessProxy.h" |
38 | #include "WebProtectionSpace.h" |
39 | |
40 | #if HAVE(SEC_KEY_PROXY) |
41 | #include "SecKeyProxyStore.h" |
42 | #endif |
43 | |
44 | namespace WebKit { |
45 | |
46 | AuthenticationChallengeProxy::AuthenticationChallengeProxy(WebCore::AuthenticationChallenge&& authenticationChallenge, uint64_t challengeID, Ref<IPC::Connection>&& connection, WeakPtr<SecKeyProxyStore>&& secKeyProxyStore) |
47 | : m_coreAuthenticationChallenge(WTFMove(authenticationChallenge)) |
48 | , m_listener(AuthenticationDecisionListener::create([challengeID, connection = WTFMove(connection), secKeyProxyStore = WTFMove(secKeyProxyStore)](AuthenticationChallengeDisposition disposition, const WebCore::Credential& credential) { |
49 | #if HAVE(SEC_KEY_PROXY) |
50 | if (secKeyProxyStore && secKeyProxyStore->initialize(credential)) { |
51 | sendClientCertificateCredentialOverXpc(connection, *secKeyProxyStore, challengeID, credential); |
52 | return; |
53 | } |
54 | #endif |
55 | connection->send(Messages::AuthenticationManager::CompleteAuthenticationChallenge(challengeID, disposition, credential), 0); |
56 | })) |
57 | { |
58 | } |
59 | |
60 | WebCredential* AuthenticationChallengeProxy::proposedCredential() const |
61 | { |
62 | if (!m_webCredential) |
63 | m_webCredential = WebCredential::create(m_coreAuthenticationChallenge.proposedCredential()); |
64 | |
65 | return m_webCredential.get(); |
66 | } |
67 | |
68 | WebProtectionSpace* AuthenticationChallengeProxy::protectionSpace() const |
69 | { |
70 | if (!m_webProtectionSpace) |
71 | m_webProtectionSpace = WebProtectionSpace::create(m_coreAuthenticationChallenge.protectionSpace()); |
72 | |
73 | return m_webProtectionSpace.get(); |
74 | } |
75 | |
76 | } // namespace WebKit |
77 | |