3c1a38c77a765569faa1a84bb2be054b11445daf
[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 "CryptoAlgorithmHmacKeyParams.h"
32 #include "CryptoAlgorithmHmacParams.h"
33 #include "CryptoKeyDataOctetSequence.h"
34 #include "CryptoKeyHMAC.h"
35 #include "ExceptionCode.h"
36 #include "JSDOMPromise.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 std::unique_ptr<CryptoAlgorithm> CryptoAlgorithmHMAC::create()
51 {
52     return std::unique_ptr<CryptoAlgorithm>(new CryptoAlgorithmHMAC);
53 }
54
55 CryptoAlgorithmIdentifier CryptoAlgorithmHMAC::identifier() const
56 {
57     return s_identifier;
58 }
59
60 void CryptoAlgorithmHMAC::generateKey(const CryptoAlgorithmParameters& parameters, bool extractable, CryptoKeyUsage usages, std::unique_ptr<PromiseWrapper> promise, ExceptionCode&)
61 {
62     const CryptoAlgorithmHmacKeyParams& hmacParameters = static_cast<const CryptoAlgorithmHmacKeyParams&>(parameters);
63
64     RefPtr<CryptoKeyHMAC> result = CryptoKeyHMAC::generate(hmacParameters.hasLength ? hmacParameters.length : 0, hmacParameters.hash, extractable, usages);
65     if (!result) {
66         promise->reject(nullptr);
67         return;
68     }
69
70     promise->fulfill(result.release());
71 }
72
73 void CryptoAlgorithmHMAC::importKey(const CryptoAlgorithmParameters& parameters, const CryptoKeyData& keyData, bool extractable, CryptoKeyUsage usage, std::unique_ptr<PromiseWrapper> promise, ExceptionCode& ec)
74 {
75     if (keyData.format() != CryptoKeyData::Format::OctetSequence) {
76         ec = NOT_SUPPORTED_ERR;
77         return;
78     }
79     const CryptoKeyDataOctetSequence& keyDataOctetSequence = toCryptoKeyDataOctetSequence(keyData);
80
81     const CryptoAlgorithmHmacParams& hmacParameters = static_cast<const CryptoAlgorithmHmacParams&>(parameters);
82
83     RefPtr<CryptoKeyHMAC> result = CryptoKeyHMAC::create(keyDataOctetSequence.octetSequence(), hmacParameters.hash, extractable, usage);
84     promise->fulfill(result.release());
85 }
86
87 }
88
89 #endif // ENABLE(SUBTLE_CRYPTO)