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

Unified Diff: chrome/renderer/resources/extensions/enterprise_platform_keys/key_pair.js

Issue 214863002: Extension API enterprise.platformKeys. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Asynchronous calls revisited. Created 6 years, 7 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 side-by-side diff with in-line comments
Download patch
Index: chrome/renderer/resources/extensions/enterprise_platform_keys/key_pair.js
diff --git a/chrome/renderer/resources/extensions/enterprise_platform_keys/key_pair.js b/chrome/renderer/resources/extensions/enterprise_platform_keys/key_pair.js
new file mode 100644
index 0000000000000000000000000000000000000000..581a2e870649a5729a3593d966ad3da05930f8d6
--- /dev/null
+++ b/chrome/renderer/resources/extensions/enterprise_platform_keys/key_pair.js
@@ -0,0 +1,35 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+var utils = require('utils');
+var intersect = require('enterprise.platformKeys.utils').intersect;
+var keyModule = require('enterprise.platformKeys.Key');
+var Key = keyModule.Key;
+var KeyType = keyModule.KeyType;
+var KeyUsage = keyModule.KeyUsage;
+
+/**
+ * Implementation of WebCrypto.KeyPair used in enterprise.platformKeys.
+ * @param {ArrayBuffer} publicKeySpki The Subject Public Key Info in DER
+ * encoding.
+ * @param {KeyAlgorithm} algorithm The algorithm identifier.
+ * @param {KeyUsage[]} usages The allowed key usages.
+ * @constructor
+ */
+var KeyPairImpl = function(publicKeySpki, algorithm, usages) {
+ this.publicKey = new Key(KeyType.public,
+ publicKeySpki,
+ algorithm,
+ intersect([KeyUsage.verify], usages),
+ true /* extractable */);
+ this.privateKey = new Key(KeyType.private,
+ publicKeySpki,
+ algorithm,
+ intersect([KeyUsage.sign], usages),
+ false /* not extractable */);
+};
+
+exports.KeyPair = utils.expose('KeyPair',
+ KeyPairImpl,
+ {readonly:['publicKey', 'privateKey']});

Powered by Google App Engine
This is Rietveld 408576698