Update SubtleCrypto::generateKey to match the latest spec
[WebKit-https.git] / Source / WebCore / crypto / algorithms / CryptoAlgorithmHMAC.cpp
1 /*
2  * Copyright (C) 2013 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 "CryptoAlgorithmHMAC.h"
28
29 #if ENABLE(SUBTLE_CRYPTO)
30
31 #include "CryptoAlgorithmHmacKeyGenParams.h"
32 #include "CryptoAlgorithmHmacKeyParamsDeprecated.h"
33 #include "CryptoAlgorithmHmacParamsDeprecated.h"
34 #include "CryptoKeyDataOctetSequence.h"
35 #include "CryptoKeyHMAC.h"
36 #include "ExceptionCode.h"
37
38 namespace WebCore {
39
40 const char* const CryptoAlgorithmHMAC::s_name = "HMAC";
41
42 CryptoAlgorithmHMAC::CryptoAlgorithmHMAC()
43 {
44 }
45
46 CryptoAlgorithmHMAC::~CryptoAlgorithmHMAC()
47 {
48 }
49
50 Ref<CryptoAlgorithm> CryptoAlgorithmHMAC::create()
51 {
52     return adoptRef(*new CryptoAlgorithmHMAC);
53 }
54
55 CryptoAlgorithmIdentifier CryptoAlgorithmHMAC::identifier() const
56 {
57     return s_identifier;
58 }
59
60 bool CryptoAlgorithmHMAC::keyAlgorithmMatches(const CryptoAlgorithmHmacParamsDeprecated& parameters, const CryptoKey& key) const
61 {
62     if (key.algorithmIdentifier() != s_identifier)
63         return false;
64
65     if (downcast<CryptoKeyHMAC>(key).hashAlgorithmIdentifier() != parameters.hash)
66         return false;
67
68     return true;
69 }
70
71 void CryptoAlgorithmHMAC::generateKey(const std::unique_ptr<CryptoAlgorithmParameters>&& parameters, bool extractable, CryptoKeyUsage usages, KeyOrKeyPairCallback&& callback, ExceptionCallback&& exceptionCallback, ScriptExecutionContext*)
72 {
73     const auto& hmacParameters = downcast<CryptoAlgorithmHmacKeyGenParams>(*parameters);
74
75     if (usages & (CryptoKeyUsageEncrypt | CryptoKeyUsageDecrypt | CryptoKeyUsageDeriveKey | CryptoKeyUsageDeriveBits | CryptoKeyUsageWrapKey | CryptoKeyUsageUnwrapKey)) {
76         exceptionCallback(SYNTAX_ERR);
77         return;
78     }
79
80     if (hmacParameters.length && !hmacParameters.length.value()) {
81         exceptionCallback(OperationError);
82         return;
83     }
84
85     auto result = CryptoKeyHMAC::generate(hmacParameters.length.valueOr(0), hmacParameters.hashIdentifier, extractable, usages);
86     if (!result) {
87         exceptionCallback(OperationError);
88         return;
89     }
90
91     callback(result.get(), nullptr);
92 }
93
94 void CryptoAlgorithmHMAC::sign(const CryptoAlgorithmParametersDeprecated& parameters, const CryptoKey& key, const CryptoOperationData& data, VectorCallback&& callback, VoidCallback&& failureCallback, ExceptionCode& ec)
95 {
96     const CryptoAlgorithmHmacParamsDeprecated& hmacParameters = downcast<CryptoAlgorithmHmacParamsDeprecated>(parameters);
97
98     if (!keyAlgorithmMatches(hmacParameters, key)) {
99         ec = NOT_SUPPORTED_ERR;
100         return;
101     }
102
103     platformSign(hmacParameters, downcast<CryptoKeyHMAC>(key), data, WTFMove(callback), WTFMove(failureCallback), ec);
104 }
105
106 void CryptoAlgorithmHMAC::verify(const CryptoAlgorithmParametersDeprecated& parameters, const CryptoKey& key, const CryptoOperationData& expectedSignature, const CryptoOperationData& data, BoolCallback&& callback, VoidCallback&& failureCallback, ExceptionCode& ec)
107 {
108     const CryptoAlgorithmHmacParamsDeprecated& hmacParameters = downcast<CryptoAlgorithmHmacParamsDeprecated>(parameters);
109
110     if (!keyAlgorithmMatches(hmacParameters, key)) {
111         ec = NOT_SUPPORTED_ERR;
112         return;
113     }
114
115     platformVerify(hmacParameters, downcast<CryptoKeyHMAC>(key), expectedSignature, data, WTFMove(callback), WTFMove(failureCallback), ec);
116 }
117
118 void CryptoAlgorithmHMAC::generateKey(const CryptoAlgorithmParametersDeprecated& parameters, bool extractable, CryptoKeyUsage usages, KeyOrKeyPairCallback&& callback, VoidCallback&& failureCallback, ExceptionCode&, ScriptExecutionContext*)
119 {
120     const CryptoAlgorithmHmacKeyParamsDeprecated& hmacParameters = downcast<CryptoAlgorithmHmacKeyParamsDeprecated>(parameters);
121
122     RefPtr<CryptoKeyHMAC> result = CryptoKeyHMAC::generate(hmacParameters.hasLength ? hmacParameters.length : 0, hmacParameters.hash, extractable, usages);
123     if (!result) {
124         failureCallback();
125         return;
126     }
127
128     callback(result.get(), nullptr);
129 }
130
131 void CryptoAlgorithmHMAC::importKey(const CryptoAlgorithmParametersDeprecated& parameters, const CryptoKeyData& keyData, bool extractable, CryptoKeyUsage usage, KeyCallback&& callback, VoidCallback&&, ExceptionCode& ec)
132 {
133     if (!is<CryptoKeyDataOctetSequence>(keyData)) {
134         ec = NOT_SUPPORTED_ERR;
135         return;
136     }
137     const CryptoKeyDataOctetSequence& keyDataOctetSequence = downcast<CryptoKeyDataOctetSequence>(keyData);
138
139     const CryptoAlgorithmHmacParamsDeprecated& hmacParameters = downcast<CryptoAlgorithmHmacParamsDeprecated>(parameters);
140
141     RefPtr<CryptoKeyHMAC> result = CryptoKeyHMAC::create(keyDataOctetSequence.octetSequence(), hmacParameters.hash, extractable, usage);
142     callback(*result);
143 }
144
145 }
146
147 #endif // ENABLE(SUBTLE_CRYPTO)