1/* 2 * Copyright (C) 2013 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17package libcore.javax.net.ssl; 18 19import java.net.Socket; 20import java.security.Principal; 21import java.security.PrivateKey; 22import java.security.cert.X509Certificate; 23import javax.net.ssl.SSLEngine; 24import javax.net.ssl.X509ExtendedKeyManager; 25 26/** 27 * {@link X509ExtendedKeyManager} which delegates all calls to the provided 28 * {@code X509ExtendedKeyManager} instance. 29 */ 30public class ForwardingX509ExtendedKeyManager extends X509ExtendedKeyManager { 31 private final X509ExtendedKeyManager delegate; 32 33 public ForwardingX509ExtendedKeyManager(X509ExtendedKeyManager delegate) { 34 this.delegate = delegate; 35 } 36 37 @Override 38 public String chooseClientAlias(String[] keyType, Principal[] issuers, Socket socket) { 39 return delegate.chooseClientAlias(keyType, issuers, socket); 40 } 41 42 @Override 43 public String chooseServerAlias(String keyType, Principal[] issuers, Socket socket) { 44 return delegate.chooseServerAlias(keyType, issuers, socket); 45 } 46 47 @Override 48 public X509Certificate[] getCertificateChain(String alias) { 49 return delegate.getCertificateChain(alias); 50 } 51 52 @Override 53 public String[] getClientAliases(String keyType, Principal[] issuers) { 54 return delegate.getClientAliases(keyType, issuers); 55 } 56 57 @Override 58 public String[] getServerAliases(String keyType, Principal[] issuers) { 59 return delegate.getServerAliases(keyType, issuers); 60 } 61 62 @Override 63 public String chooseEngineClientAlias(String[] keyType, Principal[] issuers, SSLEngine engine) { 64 return delegate.chooseEngineClientAlias(keyType, issuers, engine); 65 } 66 67 @Override 68 public String chooseEngineServerAlias(String keyType, Principal[] issuers, SSLEngine engine) { 69 return delegate.chooseEngineServerAlias(keyType, issuers, engine); 70 } 71 72 @Override 73 public PrivateKey getPrivateKey(String alias) { 74 return delegate.getPrivateKey(alias); 75 } 76} 77