1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Internal API for platform keys and certificate management.
[ platforms = ("chromeos"),
implemented_in = "chrome/browser/extensions/api/enterprise_platform_keys/enterprise_platform_keys_api.h" ]
namespace enterprise.platformKeysInternal {
dictionary Hash {
DOMString name;
};
// For more information about the RSA key generation parameters, please refer
// to: https://www.w3.org/TR/WebCryptoAPI/#RsaHashedKeyGenParams-dictionary
// For more information about the ECDSA key generation parameters, please
// refer to: https://www.w3.org/TR/WebCryptoAPI/#dfn-EcdsaParams
// Note: |hash| is not used by generateKey() but is added to completely
// mirror WebCrypto in using RsaHashedKeyAlgorithm to be able to wrap all
// parameters in one structure.
dictionary Algorithm {
// Provided for all algorithms.
DOMString name;
// Provided in case the algorithm is RSASSA-PKCS1-v1_5 or RSA-OAEP
// (the last type is supported on Chrome versions 135+).
long? modulusLength;
ArrayBuffer? publicExponent;
Hash? hash;
// Provided in case the algorithm is ECDSA.
DOMString? namedCurve;
};
// Invoked by <code>getTokens</code>.
// |tokenIds| The list of IDs of the available Tokens.
callback GetTokensCallback = void(DOMString[] tokenIds);
// Invoked by <code>generateKey</code>.
// |publicKey| The Subject Public Key Info (see X.509) of the generated key
// in DER encoding.
callback GenerateKeyCallback = void(ArrayBuffer publicKey);
interface Functions {
// Internal version of enterprise.platformKeys.getTokens. Returns a list of
// token IDs instead of token objects.
static void getTokens(GetTokensCallback callback);
// Internal version of SubtleCrypto.generateKey, currently supporting only
// RSASSA-PKCS1-v1_5, RSA-OAEP (on Chrome versions 135+), and ECDSA.
// |tokenId| The id of a Token returned by |getTokens|.
// |algorithm| The algorithm parameters as specified by WebCrypto.
// |softwareBacked| Whether the key operations should be executed in
// software.
// |callback| Called back with the Subject Public Key Info of the generated
// key.
static void generateKey(DOMString tokenId,
Algorithm algorithm,
boolean softwareBacked,
GenerateKeyCallback callback);
};
};
|