5b0994d251a9433e6d957ef584e0b7553fc0017b
[WebKit-https.git] / Source / WebCore / crypto / algorithms / CryptoAlgorithmRSA_OAEP.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 "CryptoAlgorithmRSA_OAEP.h"
28
29 #if ENABLE(SUBTLE_CRYPTO)
30
31 #include "CryptoAlgorithmRsaKeyGenParams.h"
32 #include "CryptoAlgorithmRsaKeyParamsWithHash.h"
33 #include "CryptoAlgorithmRsaOaepParams.h"
34 #include "CryptoKeyDataRSAComponents.h"
35 #include "CryptoKeyRSA.h"
36 #include "ExceptionCode.h"
37
38 namespace WebCore {
39
40 const char* const CryptoAlgorithmRSA_OAEP::s_name = "RSA-OAEP";
41
42 CryptoAlgorithmRSA_OAEP::CryptoAlgorithmRSA_OAEP()
43 {
44 }
45
46 CryptoAlgorithmRSA_OAEP::~CryptoAlgorithmRSA_OAEP()
47 {
48 }
49
50 Ref<CryptoAlgorithm> CryptoAlgorithmRSA_OAEP::create()
51 {
52     return adoptRef(*new CryptoAlgorithmRSA_OAEP);
53 }
54
55 CryptoAlgorithmIdentifier CryptoAlgorithmRSA_OAEP::identifier() const
56 {
57     return s_identifier;
58 }
59
60 bool CryptoAlgorithmRSA_OAEP::keyAlgorithmMatches(const CryptoAlgorithmRsaOaepParams& algorithmParameters, const CryptoKey& key) const
61 {
62     if (key.algorithmIdentifier() != s_identifier)
63         return false;
64
65     CryptoAlgorithmIdentifier keyHash;
66     if (downcast<CryptoKeyRSA>(key).isRestrictedToHash(keyHash) && keyHash != algorithmParameters.hash)
67         return false;
68
69     return true;
70 }
71
72 void CryptoAlgorithmRSA_OAEP::encrypt(const CryptoAlgorithmParameters& parameters, const CryptoKey& key, const CryptoOperationData& data, VectorCallback&& callback, VoidCallback&& failureCallback, ExceptionCode& ec)
73 {
74     const CryptoAlgorithmRsaOaepParams& rsaOAEPParameters = downcast<CryptoAlgorithmRsaOaepParams>(parameters);
75
76     if (!keyAlgorithmMatches(rsaOAEPParameters, key)) {
77         ec = NOT_SUPPORTED_ERR;
78         return;
79     }
80
81     platformEncrypt(rsaOAEPParameters, downcast<CryptoKeyRSA>(key), data, WTFMove(callback), WTFMove(failureCallback), ec);
82 }
83
84 void CryptoAlgorithmRSA_OAEP::decrypt(const CryptoAlgorithmParameters& parameters, const CryptoKey& key, const CryptoOperationData& data, VectorCallback&& callback, VoidCallback&& failureCallback, ExceptionCode& ec)
85 {
86     const CryptoAlgorithmRsaOaepParams& rsaOAEPParameters = downcast<CryptoAlgorithmRsaOaepParams>(parameters);
87
88     if (!keyAlgorithmMatches(rsaOAEPParameters, key)) {
89         ec = NOT_SUPPORTED_ERR;
90         return;
91     }
92
93     platformDecrypt(rsaOAEPParameters, downcast<CryptoKeyRSA>(key), data, WTFMove(callback), WTFMove(failureCallback), ec);
94 }
95
96 void CryptoAlgorithmRSA_OAEP::generateKey(const CryptoAlgorithmParameters& parameters, bool extractable, CryptoKeyUsage usages, KeyOrKeyPairCallback&& callback, VoidCallback&& failureCallback, ExceptionCode&)
97 {
98     const CryptoAlgorithmRsaKeyGenParams& rsaParameters = downcast<CryptoAlgorithmRsaKeyGenParams>(parameters);
99
100     auto keyPairCallback = [callback](CryptoKeyPair& pair) {
101         callback(nullptr, &pair);
102     };
103
104     CryptoKeyRSA::generatePair(CryptoAlgorithmIdentifier::RSA_OAEP, rsaParameters.hash, rsaParameters.hasHash, rsaParameters.modulusLength, rsaParameters.publicExponent, extractable, usages, WTFMove(keyPairCallback), WTFMove(failureCallback));
105 }
106
107 void CryptoAlgorithmRSA_OAEP::importKey(const CryptoAlgorithmParameters& parameters, const CryptoKeyData& keyData, bool extractable, CryptoKeyUsage usage, KeyCallback&& callback, VoidCallback&& failureCallback, ExceptionCode&)
108 {
109     const CryptoAlgorithmRsaKeyParamsWithHash& rsaKeyParameters = downcast<CryptoAlgorithmRsaKeyParamsWithHash>(parameters);
110     const CryptoKeyDataRSAComponents& rsaComponents = downcast<CryptoKeyDataRSAComponents>(keyData);
111
112     RefPtr<CryptoKeyRSA> result = CryptoKeyRSA::create(CryptoAlgorithmIdentifier::RSA_OAEP, rsaKeyParameters.hash, rsaKeyParameters.hasHash, rsaComponents, extractable, usage);
113     if (!result) {
114         failureCallback();
115         return;
116     }
117
118     callback(*result);
119 }
120
121 }
122
123 #endif // ENABLE(SUBTLE_CRYPTO)