key.js revision cedac228d2dd51db4b79ea1e72c7f249408ee061
1// Copyright 2014 The Chromium Authors. All rights reserved. 2// Use of this source code is governed by a BSD-style license that can be 3// found in the LICENSE file. 4 5var utils = require('utils'); 6 7/** 8 * Enum of possible key types (subset of WebCrypto.KeyType). 9 * @enum {string} 10 */ 11var KeyType = { 12 public: 'public', 13 private: 'private' 14}; 15 16/** 17 * Enum of possible key usages (subset of WebCrypto.KeyUsage). 18 * @enum {string} 19 */ 20var KeyUsage = { 21 sign: 'sign', 22 verify: 'verify' 23}; 24 25/** 26 * Implementation of WebCrypto.Key used in enterprise.platformKeys. 27 * @param {KeyType} type The type of the new key. 28 * @param {ArrayBuffer} publicKeySpki The Subject Public Key Info in DER 29 * encoding. 30 * @param {KeyAlgorithm} algorithm The algorithm identifier. 31 * @param {KeyUsage[]} usages The allowed key usages. 32 * @param {boolean} extractable Whether the key is extractable. 33 * @constructor 34 */ 35var KeyImpl = function(type, publicKeySpki, algorithm, usages, extractable) { 36 this.type = type; 37 this.spki = publicKeySpki; 38 this.algorithm = algorithm; 39 this.usages = usages; 40 this.extractable = extractable; 41}; 42 43var Key = 44 utils.expose('Key', 45 KeyImpl, 46 {readonly:['extractable', 'type', 'algorithm', 'usages']}); 47 48/** 49 * Returns |key|'s Subject Public Key Info. Throws an exception if |key| is not 50 * a valid Key object. 51 * @param {Key} key 52 * @return {ArrayBuffer} The Subject Public Key Info in DER encoding of |key|. 53 */ 54function getSpki(key) { 55 if (!privates(key)) 56 throw new Error('Invalid key object.'); 57 var keyImpl = privates(key).impl; 58 if (!keyImpl || !keyImpl.spki) 59 throw new Error('Invalid key object.'); 60 return keyImpl.spki; 61} 62 63exports.Key = Key; 64exports.KeyType = KeyType; 65exports.KeyUsage = KeyUsage; 66exports.getSpki = getSpki; 67