| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2013 Google Inc. All rights reserved. | 2 * Copyright (C) 2013 Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 23 matching lines...) Expand all Loading... |
| 34 #include "V8Key.h" // Must precede ScriptPromiseResolver.h | 34 #include "V8Key.h" // Must precede ScriptPromiseResolver.h |
| 35 #include "bindings/v8/ExceptionState.h" | 35 #include "bindings/v8/ExceptionState.h" |
| 36 #include "bindings/v8/custom/V8ArrayBufferCustom.h" // Must precede ScriptPromis
eResolver.h | 36 #include "bindings/v8/custom/V8ArrayBufferCustom.h" // Must precede ScriptPromis
eResolver.h |
| 37 #include "bindings/v8/ScriptPromiseResolver.h" | 37 #include "bindings/v8/ScriptPromiseResolver.h" |
| 38 #include "core/dom/ExceptionCode.h" | 38 #include "core/dom/ExceptionCode.h" |
| 39 #include "modules/crypto/Key.h" | 39 #include "modules/crypto/Key.h" |
| 40 #include "modules/crypto/NormalizeAlgorithm.h" | 40 #include "modules/crypto/NormalizeAlgorithm.h" |
| 41 #include "public/platform/Platform.h" | 41 #include "public/platform/Platform.h" |
| 42 #include "public/platform/WebArrayBuffer.h" | 42 #include "public/platform/WebArrayBuffer.h" |
| 43 #include "public/platform/WebCrypto.h" | 43 #include "public/platform/WebCrypto.h" |
| 44 #include "public/platform/WebCryptoAlgorithmParams.h" | 44 #include "public/platform/WebCryptoAlgorithm.h" |
| 45 #include "wtf/ArrayBufferView.h" | 45 #include "wtf/ArrayBufferView.h" |
| 46 | 46 |
| 47 namespace WebCore { | 47 namespace WebCore { |
| 48 | 48 |
| 49 // FIXME: asynchronous completion of CryptoResult. Need to re-enter the | 49 // FIXME: asynchronous completion of CryptoResult. Need to re-enter the |
| 50 // v8::Context before trying to fulfill the promise, and enable test. | 50 // v8::Context before trying to fulfill the promise, and enable test. |
| 51 | 51 |
| 52 namespace { | 52 namespace { |
| 53 | 53 |
| 54 class CryptoResult : public WebKit::WebCryptoResultPrivate, public ThreadSafeRef
Counted<CryptoResult> { | 54 class CryptoResult : public WebKit::WebCryptoResultPrivate, public ThreadSafeRef
Counted<CryptoResult> { |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 110 void finish() | 110 void finish() |
| 111 { | 111 { |
| 112 ASSERT(!m_finished); | 112 ASSERT(!m_finished); |
| 113 m_finished = true; | 113 m_finished = true; |
| 114 } | 114 } |
| 115 | 115 |
| 116 RefPtr<ScriptPromiseResolver> m_promiseResolver; | 116 RefPtr<ScriptPromiseResolver> m_promiseResolver; |
| 117 bool m_finished; | 117 bool m_finished; |
| 118 }; | 118 }; |
| 119 | 119 |
| 120 WebKit::WebCryptoKeyUsageMask toKeyUsage(AlgorithmOperation operation) | |
| 121 { | |
| 122 switch (operation) { | |
| 123 case Encrypt: | |
| 124 return WebKit::WebCryptoKeyUsageEncrypt; | |
| 125 case Decrypt: | |
| 126 return WebKit::WebCryptoKeyUsageDecrypt; | |
| 127 case Sign: | |
| 128 return WebKit::WebCryptoKeyUsageSign; | |
| 129 case Verify: | |
| 130 return WebKit::WebCryptoKeyUsageVerify; | |
| 131 case DeriveKey: | |
| 132 return WebKit::WebCryptoKeyUsageDeriveKey; | |
| 133 case WrapKey: | |
| 134 return WebKit::WebCryptoKeyUsageWrapKey; | |
| 135 case UnwrapKey: | |
| 136 return WebKit::WebCryptoKeyUsageUnwrapKey; | |
| 137 case Digest: | |
| 138 case GenerateKey: | |
| 139 case ImportKey: | |
| 140 case NumberOfAlgorithmOperations: | |
| 141 break; | |
| 142 } | |
| 143 | |
| 144 ASSERT_NOT_REACHED(); | |
| 145 return 0; | |
| 146 } | |
| 147 | |
| 148 bool keyCanBeUsedForAlgorithm(const WebKit::WebCryptoKey& key, const WebKit::Web
CryptoAlgorithm& algorithm, AlgorithmOperation op) | |
| 149 { | |
| 150 if (!(key.usages() & toKeyUsage(op))) | |
| 151 return false; | |
| 152 | |
| 153 if (key.algorithm().id() != algorithm.id()) | |
| 154 return false; | |
| 155 | |
| 156 if (key.algorithm().paramsType() == WebKit::WebCryptoAlgorithmParamsTypeNone
) | |
| 157 return true; | |
| 158 | |
| 159 // Verify that the algorithm-specific parameters for the key conform to the | |
| 160 // algorithm. | |
| 161 | |
| 162 if (key.algorithm().paramsType() == WebKit::WebCryptoAlgorithmParamsTypeHmac
Params) { | |
| 163 return key.algorithm().hmacParams()->hash().id() == algorithm.hmacParams
()->hash().id(); | |
| 164 } | |
| 165 | |
| 166 ASSERT_NOT_REACHED(); | |
| 167 return false; | |
| 168 } | |
| 169 | |
| 170 ScriptObject startCryptoOperation(const Dictionary& rawAlgorithm, Key* key, Algo
rithmOperation operationType, ArrayBufferView* signature, ArrayBufferView* dataB
uffer, ExceptionState& es) | 120 ScriptObject startCryptoOperation(const Dictionary& rawAlgorithm, Key* key, Algo
rithmOperation operationType, ArrayBufferView* signature, ArrayBufferView* dataB
uffer, ExceptionState& es) |
| 171 { | 121 { |
| 172 WebKit::WebCrypto* platformCrypto = WebKit::Platform::current()->crypto(); | 122 WebKit::WebCrypto* platformCrypto = WebKit::Platform::current()->crypto(); |
| 173 if (!platformCrypto) { | 123 if (!platformCrypto) { |
| 174 es.throwDOMException(NotSupportedError); | 124 es.throwDOMException(NotSupportedError); |
| 175 return ScriptObject(); | 125 return ScriptObject(); |
| 176 } | 126 } |
| 177 | 127 |
| 178 WebKit::WebCryptoAlgorithm algorithm; | 128 WebKit::WebCryptoAlgorithm algorithm; |
| 179 if (!normalizeAlgorithm(rawAlgorithm, operationType, algorithm, es)) | 129 if (!normalizeAlgorithm(rawAlgorithm, operationType, algorithm, es)) |
| 180 return ScriptObject(); | 130 return ScriptObject(); |
| 181 | 131 |
| 182 // All operations other than Digest require a valid Key. | 132 // All operations other than Digest require a valid Key. |
| 183 if (operationType != Digest) { | 133 if (operationType != Digest) { |
| 184 if (!key) { | 134 if (!key) { |
| 185 es.throwTypeError(); | 135 es.throwTypeError(); |
| 186 return ScriptObject(); | 136 return ScriptObject(); |
| 187 } | 137 } |
| 188 | 138 |
| 189 if (!keyCanBeUsedForAlgorithm(key->key(), algorithm, operationType)) { | 139 if (!key->canBeUsedForAlgorithm(algorithm, operationType, es)) |
| 190 es.throwDOMException(NotSupportedError); | |
| 191 return ScriptObject(); | 140 return ScriptObject(); |
| 192 } | |
| 193 } | 141 } |
| 194 | 142 |
| 195 // Only Verify takes a signature. | 143 // Only Verify takes a signature. |
| 196 if (operationType == Verify && !signature) { | 144 if (operationType == Verify && !signature) { |
| 197 es.throwTypeError(); | 145 es.throwTypeError(); |
| 198 return ScriptObject(); | 146 return ScriptObject(); |
| 199 } | 147 } |
| 200 | 148 |
| 201 if (!dataBuffer) { | 149 if (!dataBuffer) { |
| 202 es.throwTypeError(); | 150 es.throwTypeError(); |
| (...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 317 return ScriptObject(); | 265 return ScriptObject(); |
| 318 | 266 |
| 319 const unsigned char* keyDataBytes = static_cast<unsigned char*>(keyData->bas
eAddress()); | 267 const unsigned char* keyDataBytes = static_cast<unsigned char*>(keyData->bas
eAddress()); |
| 320 | 268 |
| 321 RefPtr<CryptoResult> result = CryptoResult::create(); | 269 RefPtr<CryptoResult> result = CryptoResult::create(); |
| 322 platformCrypto->importKey(format, keyDataBytes, keyData->byteLength(), algor
ithm, extractable, keyUsages, result->result()); | 270 platformCrypto->importKey(format, keyDataBytes, keyData->byteLength(), algor
ithm, extractable, keyUsages, result->result()); |
| 323 return result->promise(); | 271 return result->promise(); |
| 324 } | 272 } |
| 325 | 273 |
| 326 } // namespace WebCore | 274 } // namespace WebCore |
| OLD | NEW |