FileDocCategorySizeDatePackage
HandshakeCompletedEvent.javaAPI DocAndroid 1.5 API5029Wed May 06 22:41:06 BST 2009javax.net.ssl

HandshakeCompletedEvent.java

/*
 *  Licensed to the Apache Software Foundation (ASF) under one or more
 *  contributor license agreements.  See the NOTICE file distributed with
 *  this work for additional information regarding copyright ownership.
 *  The ASF licenses this file to You under the Apache License, Version 2.0
 *  (the "License"); you may not use this file except in compliance with
 *  the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */

package javax.net.ssl;

import java.io.Serializable;
import java.security.Principal;
import java.security.cert.Certificate;
import javax.security.cert.X509Certificate;
import java.util.EventObject;

/**
 * The event object encapsulating the information about a completed SSL
 * handshake on a SSL connection.
 * 
 * @since Android 1.0
 */
public class HandshakeCompletedEvent extends EventObject implements
        Serializable {

    /**
     * The 5.0 spec. doesn't declare this serialVersionUID field In order to be
     * compatible it is explicitly declared here
     */
    private static final long serialVersionUID = 7914963744257769778L;

    private transient SSLSession session;

    /**
     * Creates a new {@code HandshakeCompletedEvent} with the specified SSL
     * socket and SSL session.
     * 
     * @param sock
     *            the SSL socket.
     * @param s
     *            the SSL session.
     * @since Android 1.0
     */
    public HandshakeCompletedEvent(SSLSocket sock, SSLSession s) {
        super(sock);
        session = s;
    }

    /**
     * Returns the SSL session associated with this event.
     * 
     * @return the SSL session associated with this event.
     * @since Android 1.0
     */
    public SSLSession getSession() {
        return session;
    }

    /**
     * Returns the name of the cipher suite negotiated during this handshake.
     * 
     * @return the name of the cipher suite negotiated during this handshake.
     * @since Android 1.0
     */
    public String getCipherSuite() {
        return session.getCipherSuite();
    }

    /**
     * Returns the list of local certificates used during the handshake. These
     * certificates were sent to the peer.
     * 
     * @return Returns the list of certificates used during the handshake with
     *         the local identity certificate followed by CAs, or {@code null}
     *         if no certificates were used during the handshake.
     * @since Android 1.0
     */
    public Certificate[] getLocalCertificates() {
        return session.getLocalCertificates();
    }

    /**
     * Return the list of certificates identifying the peer during the
     * handshake.
     * 
     * @return the list of certificates identifying the peer with the peer's
     *         identity certificate followed by CAs.
     * @throws SSLPeerUnverifiedException
     *             if the identity of the peer has not been verified.
     * @since Android 1.0
     */
    public Certificate[] getPeerCertificates()
            throws SSLPeerUnverifiedException {
        return session.getPeerCertificates();
    }

    /**
     * Returns the list of certificates identifying the peer. The peer's
     * identity certificate is followed by the validated certificate authority
     * certificates.
     * <p>
     * <b>Replaced by:</b> {@link #getPeerCertificates()}
     * </p>
     * 
     * @return the list of certificates identifying the peer
     * @throws SSLPeerUnverifiedException
     *             if the identity of the peer has not been verified.
     * @since Android 1.0
     */
    public X509Certificate[] getPeerCertificateChain()
            throws SSLPeerUnverifiedException {
        return session.getPeerCertificateChain();
    }

    /**
     * Returns the {@code Principal} identifying the peer.
     * 
     * @return the {@code Principal} identifying the peer.
     * @throws SSLPeerUnverifiedException
     *             if the identity of the peer has not been verified.
     * @since Android 1.0
     */
    public Principal getPeerPrincipal() throws SSLPeerUnverifiedException {
        return session.getPeerPrincipal();
    }
    
    /**
     * Returns the {@code Principal} used to identify during the handshake.
     * 
     * @return the {@code Principal} used to identify during the handshake.
     * @since Android 1.0
     */
    public Principal getLocalPrincipal() {
        return session.getLocalPrincipal();
    }
    
    /**
     * Returns the SSL socket that produced this event.
     * 
     * @return the SSL socket that produced this event.
     * @since Android 1.0
     */
    public SSLSocket getSocket() {
        return (SSLSocket)this.source;
    }

}