/* * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package com.sun.net.httpserver; import java.net.*; import java.io.*; import java.nio.*; import java.security.*; import java.nio.channels.*; import java.util.*; import java.util.concurrent.*; import javax.net.ssl.*; /** * This class is used to configure the https parameters for each incoming * https connection on a HttpsServer. Applications need to override * the {@link #configure(HttpsParameters)} method in order to change * the default configuration. *

* The following example shows how this may be done: *

*

* SSLContext sslContext = SSLContext.getInstance (....); * HttpsServer server = HttpsServer.create(); * * server.setHttpsConfigurator (new HttpsConfigurator(sslContext) { * public void configure (HttpsParameters params) { * * // get the remote address if needed * InetSocketAddress remote = params.getClientAddress(); * * SSLContext c = getSSLContext(); * * // get the default parameters * SSLParameters sslparams = c.getDefaultSSLParameters(); * if (remote.equals (...) ) { * // modify the default set for client x * } * * params.setSSLParameters(sslparams); * } * }); *
* @since 1.6 */ @jdk.Supported public class HttpsConfigurator { private SSLContext context; /** * Creates an Https configuration, with the given SSLContext. * @param context the SSLContext to use for this configurator * @throws NullPointerException if no SSLContext supplied */ public HttpsConfigurator (SSLContext context) { if (context == null) { throw new NullPointerException ("null SSLContext"); } this.context = context; } /** * Returns the SSLContext for this HttpsConfigurator. * @return the SSLContext */ public SSLContext getSSLContext() { return context; } //BEGIN_TIGER_EXCLUDE /** * Called by the HttpsServer to configure the parameters * for a https connection currently being established. * The implementation of configure() must call * {@link HttpsParameters#setSSLParameters(SSLParameters)} * in order to set the SSL parameters for the connection. *

* The default implementation of this method uses the * SSLParameters returned from

* getSSLContext().getDefaultSSLParameters() *

* configure() may be overridden in order to modify this behavior. * See, the example above. * @param params the HttpsParameters to be configured. * * @since 1.6 */ public void configure (HttpsParameters params) { params.setSSLParameters (getSSLContext().getDefaultSSLParameters()); } //END_TIGER_EXCLUDE }