Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(53)

Side by Side Diff: chrome/renderer/resources/extensions/platform_keys/get_public_key.js

Issue 1001853003: chrome.platformKeys: Require a algorithm name to getKeyPair(). (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | chrome/test/data/extensions/api_test/platform_keys/basic.js » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 var internalAPI = require('platformKeys.internalAPI'); 5 var internalAPI = require('platformKeys.internalAPI');
6 6
7 var normalizeAlgorithm = 7 var normalizeAlgorithm =
8 requireNative('platform_keys_natives').NormalizeAlgorithm; 8 requireNative('platform_keys_natives').NormalizeAlgorithm;
9 9
10 function combineAlgorithms(algorithm, importParams) { 10 function normalizeImportParams(importParams) {
11 if (importParams.name === undefined) { 11 if (!importParams.name) {
12 importParams.name = algorithm.name; 12 throw new Error('Algorithm: name: Missing or not a string');
Andrew T Wilson (Slow) 2015/03/19 07:31:49 I guess some other code is checking if the supplie
pneubeck (no reviews) 2015/03/23 13:20:59 Done.
13 } 13 }
14 14
15 // Verify whether importParams.hash equals 15 // Check whether importParams.hash equals
16 // { name: 'none' } 16 // { name: 'none' }
17 // and temporarily replace it by a valid WebCrypto Hash for normalization.
18 var hashIsNone = false;
17 if (importParams.hash && 19 if (importParams.hash &&
18 importParams.hash.name.toLowerCase() === 'none') { 20 importParams.hash.name.toLowerCase() === 'none') {
Andrew T Wilson (Slow) 2015/03/19 07:31:49 Also, note that there's kind of an implicit contra
Andrew T Wilson (Slow) 2015/03/19 07:31:49 SO, if I pass in : importParams.hash = { name: 'n
pneubeck (no reviews) 2015/03/23 13:20:59 Done.
pneubeck (no reviews) 2015/03/23 13:20:59 yes. extraneous attributes shall be removed. I add
19 if (Object.keys(importParams.hash).length != 1 || 21 hashIsNone = true;
20 Object.keys(importParams).length != 2) { 22 // Will be reverted to 'none' after normalization.
21 // 'name' must be the only hash property in this case. 23 importParams.hash = { name: 'SHA-1' };
22 throw new Error('A required parameter was missing or out-of-range');
23 }
24 importParams.hash.name = 'none';
25 } else {
26 // Otherwise apply WebCrypto's algorithm normalization.
27 importParams = normalizeAlgorithm(importParams, 'ImportKey');
28 if (!importParams) {
29 // throw CreateSyntaxError();
30 throw new Error('A required parameter was missing or out-of-range');
31 }
32 } 24 }
33 25
26 // Apply WebCrypto's algorithm normalization.
27 importParams = normalizeAlgorithm(importParams, 'ImportKey');
28 if (!importParams) {
29 throw new Error('A required parameter was missing or out-of-range');
30 }
31 if (hashIsNone) {
32 importParams.hash = { name: 'none' };
33 }
34 return importParams;
35 }
36
37 function combineAlgorithms(algorithm, importParams) {
34 // internalAPI.getPublicKey returns publicExponent as ArrayBuffer, but it 38 // internalAPI.getPublicKey returns publicExponent as ArrayBuffer, but it
35 // should be a Uint8Array. 39 // should be a Uint8Array.
36 if (algorithm.publicExponent) { 40 if (algorithm.publicExponent) {
37 algorithm.publicExponent = new Uint8Array(algorithm.publicExponent); 41 algorithm.publicExponent = new Uint8Array(algorithm.publicExponent);
38 } 42 }
39 43
40 for (var key in importParams) { 44 algorithm.hash = importParams.hash;
41 algorithm[key] = importParams[key];
42 }
43
44 return algorithm; 45 return algorithm;
45 } 46 }
46 47
47 function getPublicKey(cert, importParams, callback) { 48 function getPublicKey(cert, importParams, callback) {
49 importParams = normalizeImportParams(importParams);
50 // TODO(pneubeck): pass importParams.name to the internal getPublicKey and
51 // verify on the C++ side that the requested algorithm is compatible with the
52 // given SubjectPublicKeyInfo of the certificate.
53 // https://crbug.com/466584
48 internalAPI.getPublicKey(cert, function(publicKey, algorithm) { 54 internalAPI.getPublicKey(cert, function(publicKey, algorithm) {
49 var combinedAlgorithm = combineAlgorithms(algorithm, importParams); 55 var combinedAlgorithm = combineAlgorithms(algorithm, importParams);
50 callback(publicKey, combinedAlgorithm); 56 callback(publicKey, combinedAlgorithm);
51 }); 57 });
52 } 58 }
53 59
54 exports.getPublicKey = getPublicKey; 60 exports.getPublicKey = getPublicKey;
OLDNEW
« no previous file with comments | « no previous file | chrome/test/data/extensions/api_test/platform_keys/basic.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698