/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * You can obtain a copy of the license at * trunk/opends/resource/legal-notices/OpenDS.LICENSE * or https://OpenDS.dev.java.net/OpenDS.LICENSE. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at * trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable, * add the following below this CDDL HEADER, with the fields enclosed * by brackets "[]" replaced with your own identifying information: * Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END * * * Copyright 2010 Sun Microsystems, Inc. */ package org.opends.sdk.requests; import javax.net.ssl.SSLContext; import org.opends.sdk.*; import org.opends.sdk.controls.Control; import org.opends.sdk.responses.*; import com.sun.opends.sdk.util.Validator; import java.util.*; /** * Start TLS extended request implementation. */ final class StartTLSExtendedRequestImpl extends AbstractExtendedRequest implements StartTLSExtendedRequest { static final class RequestDecoder implements ExtendedRequestDecoder { public StartTLSExtendedRequest decodeExtendedRequest( final ExtendedRequest request, final DecodeOptions options) throws DecodeException { // TODO: Check the OID and that the value is not present. final StartTLSExtendedRequest newRequest = new StartTLSExtendedRequestImpl(); for (final Control control : request.getControls()) { newRequest.addControl(control); } return newRequest; } } private static final class ResultDecoder extends AbstractExtendedResultDecoder { public GenericExtendedResult newExtendedErrorResult( final ResultCode resultCode, final String matchedDN, final String diagnosticMessage) { return Responses.newGenericExtendedResult(resultCode).setMatchedDN( matchedDN).setDiagnosticMessage(diagnosticMessage); } public ExtendedResult decodeExtendedResult(final ExtendedResult result, final DecodeOptions options) throws DecodeException { // TODO: Should we check oid is NOT null and matches but // value is null? return result; } } private SSLContext sslContext; /** * The list of cipher suite */ private List enabledCipherSuites = new LinkedList(); /** * the list of protocols */ private List enabledProtocols = new LinkedList(); // No need to expose this. private static final ExtendedResultDecoder RESULT_DECODER = new ResultDecoder(); StartTLSExtendedRequestImpl(final SSLContext sslContext) { Validator.ensureNotNull(sslContext); this.sslContext = sslContext; } /** * Creates a new startTLS extended request that is an exact copy of the * provided request. * * @param startTLSExtendedRequest * The startTLS extended request to be copied. * @throws NullPointerException * If {@code startTLSExtendedRequest} was {@code null} . */ StartTLSExtendedRequestImpl( final StartTLSExtendedRequest startTLSExtendedRequest) throws NullPointerException { super(startTLSExtendedRequest); this.sslContext = startTLSExtendedRequest.getSSLContext(); this.enabledCipherSuites.addAll( startTLSExtendedRequest.getEnabledCipherSuites()); this.enabledProtocols.addAll(startTLSExtendedRequest.getEnabledProtocols()); } // Prevent instantiation. private StartTLSExtendedRequestImpl() { // Nothing to do. } /** * {@inheritDoc} */ @Override public String getOID() { return OID; } /** * {@inheritDoc} */ @Override public ExtendedResultDecoder getResultDecoder() { return RESULT_DECODER; } /** * {@inheritDoc} */ public SSLContext getSSLContext() { return sslContext; } /** * {@inheritDoc}} */ public StartTLSExtendedRequest addEnabledProtocol(String... protocols) { for (final String protocol : protocols) { this.enabledProtocols.add(Validator.ensureNotNull(protocol)); } return this; } /** * {@inheritDoc}} */ public StartTLSExtendedRequest addEnabledCipherSuite(String... suites) { for (final String suite : suites) { this.enabledCipherSuites.add(Validator.ensureNotNull(suite)); } return this; } /** * {@inheritDoc}} */ public List getEnabledProtocols() { return this.enabledProtocols; } /** * {@inheritDoc}} */ public List getEnabledCipherSuites() { return this.enabledCipherSuites; } /** * {@inheritDoc} */ @Override public ByteString getValue() { return null; } /** * {@inheritDoc} */ @Override public boolean hasValue() { return false; } /** * {@inheritDoc} */ public StartTLSExtendedRequest setSSLContext(final SSLContext sslContext) { Validator.ensureNotNull(sslContext); this.sslContext = sslContext; return this; } /** * {@inheritDoc} */ @Override public String toString() { final StringBuilder builder = new StringBuilder(); builder.append("StartTLSExtendedRequest(requestName="); builder.append(getOID()); builder.append(", controls="); builder.append(getControls()); builder.append(")"); return builder.toString(); } }