| // 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. |
| |
| package org.chromium.net; |
| |
| import org.chromium.net.IRemoteAndroidKeyStoreCallbacks; |
| |
| /** |
| * Interface for communication with an Android KeyStore in another process. |
| */ |
| interface IRemoteAndroidKeyStore { |
| // Remote calls for SSlClientCertificateRequest - these allow retrieving |
| // the alias of the certificate to be used, its encoded chain and a handle |
| // for identifying a private key in the remote process. |
| String getClientCertificateAlias(); |
| byte[] getEncodedCertificateChain(in String alias); |
| int getPrivateKeyHandle(in String alias); |
| |
| // Registers callbacks for service->client communication. |
| void setClientCallbacks(IRemoteAndroidKeyStoreCallbacks callbacks); |
| |
| // Remote calls for AndroidKeyStore - these functions are performing operations |
| // with a PrivateKey in the remote process using the handle provided by |
| // |getPrivateKeyHandle|. |
| byte[] getRSAKeyModulus(in int handle); |
| byte[] getPrivateKeyEncodedBytes(in int handle); |
| byte[] getDSAKeyParamQ(in int handle); |
| byte[] getECKeyOrder(in int handle); |
| byte[] rawSignDigestWithPrivateKey(in int handle, in byte[] message); |
| int getPrivateKeyType(in int handle); |
| void releaseKey(in int handle); |
| } |