001/**
002 * Licensed to the Apache Software Foundation (ASF) under one or more
003 * contributor license agreements.  See the NOTICE file distributed with
004 * this work for additional information regarding copyright ownership.
005 * The ASF licenses this file to You under the Apache License, Version 2.0
006 * (the "License"); you may not use this file except in compliance with
007 * the License.  You may obtain a copy of the License at
008 *
009 *      http://www.apache.org/licenses/LICENSE-2.0
010 *
011 * Unless required by applicable law or agreed to in writing, software
012 * distributed under the License is distributed on an "AS IS" BASIS,
013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014 * See the License for the specific language governing permissions and
015 * limitations under the License.
016 */
017package org.apache.activemq.transport.nio;
018
019import java.io.IOException;
020import java.net.Socket;
021import java.net.URI;
022import java.net.URISyntaxException;
023
024import javax.net.ServerSocketFactory;
025import javax.net.ssl.SSLContext;
026
027import org.apache.activemq.transport.Transport;
028import org.apache.activemq.transport.tcp.TcpTransportFactory;
029import org.apache.activemq.transport.tcp.TcpTransportServer;
030import org.apache.activemq.wireformat.WireFormat;
031
032public class NIOSSLTransportServer extends TcpTransportServer {
033
034    private SSLContext context;
035
036    public NIOSSLTransportServer(SSLContext context, TcpTransportFactory transportFactory, URI location, ServerSocketFactory serverSocketFactory) throws IOException, URISyntaxException {
037        super(transportFactory, location, serverSocketFactory);
038
039        this.context = context;
040    }
041
042    private boolean needClientAuth;
043    private boolean wantClientAuth;
044
045    @Override
046    protected Transport createTransport(Socket socket, WireFormat format) throws IOException {
047        NIOSSLTransport transport = new NIOSSLTransport(format, socket);
048        if (context != null) {
049            transport.setSslContext(context);
050        }
051
052        transport.setNeedClientAuth(needClientAuth);
053        transport.setWantClientAuth(wantClientAuth);
054
055        return transport;
056    }
057
058    @Override
059    public boolean isSslServer() {
060        return true;
061    }
062
063    public boolean isNeedClientAuth() {
064        return this.needClientAuth;
065    }
066
067    public void setNeedClientAuth(boolean value) {
068        this.needClientAuth = value;
069    }
070
071    public boolean isWantClientAuth() {
072        return this.wantClientAuth;
073    }
074
075    public void setWantClientAuth(boolean value) {
076        this.wantClientAuth = value;
077    }
078}