d3c75563bab05daa9ecdaba278dc5e5957d90c9c
[WebKit-https.git] / Source / WebCore / crypto / mac / CryptoAlgorithmAES_CBCMac.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 "CryptoAlgorithmAES_CBC.h"
28
29 #if ENABLE(SUBTLE_CRYPTO)
30
31 #include "CryptoAlgorithmAesCbcCfbParams.h"
32 #include "CryptoKeyAES.h"
33 #include <CommonCrypto/CommonCrypto.h>
34
35 namespace WebCore {
36
37 static ExceptionOr<Vector<uint8_t>> transformAES_CBC(CCOperation operation, const Vector<uint8_t>& iv, const Vector<uint8_t>& key, const Vector<uint8_t>& data)
38 {
39     CCCryptorRef cryptor;
40     CCCryptorStatus status = CCCryptorCreate(operation, kCCAlgorithmAES, kCCOptionPKCS7Padding, key.data(), key.size(), iv.data(), &cryptor);
41     if (status)
42         return Exception { OperationError };
43
44     Vector<uint8_t> result(CCCryptorGetOutputLength(cryptor, data.size(), true));
45
46     size_t bytesWritten;
47     status = CCCryptorUpdate(cryptor, data.data(), data.size(), result.data(), result.size(), &bytesWritten);
48     if (status)
49         return Exception { OperationError };
50
51     uint8_t* p = result.data() + bytesWritten;
52     status = CCCryptorFinal(cryptor, p, result.end() - p, &bytesWritten);
53     p += bytesWritten;
54     if (status)
55         return Exception { OperationError };
56
57     ASSERT(p <= result.end());
58     result.shrink(p - result.begin());
59
60     CCCryptorRelease(cryptor);
61
62     return WTFMove(result);
63 }
64
65 ExceptionOr<Vector<uint8_t>> CryptoAlgorithmAES_CBC::platformEncrypt(CryptoAlgorithmAesCbcCfbParams& parameters, const CryptoKeyAES& key, const Vector<uint8_t>& plainText)
66 {
67     ASSERT(parameters.ivVector().size() == kCCBlockSizeAES128);
68     return transformAES_CBC(kCCEncrypt, parameters.ivVector(), key.key(), plainText);
69 }
70
71 ExceptionOr<Vector<uint8_t>> CryptoAlgorithmAES_CBC::platformDecrypt(CryptoAlgorithmAesCbcCfbParams& parameters, const CryptoKeyAES& key, const Vector<uint8_t>& cipherText)
72 {
73     ASSERT(parameters.ivVector().size() == kCCBlockSizeAES128);
74     return transformAES_CBC(kCCDecrypt, parameters.ivVector(), key.key(), cipherText);
75 }
76
77 } // namespace WebCore
78
79 #endif // ENABLE(SUBTLE_CRYPTO)