src/java.base/share/classes/sun/security/ssl/OCSPStatusRequest.java
author erikj
Tue, 12 Sep 2017 19:03:39 +0200
changeset 47216 71c04702a3d5
parent 32032 jdk/src/java.base/share/classes/sun/security/ssl/OCSPStatusRequest.java@22badc53802f
permissions -rw-r--r--
8187443: Forest Consolidation: Move files to unified layout Reviewed-by: darcy, ihse
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
32032
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
     1
/*
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
     2
 * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
     4
 *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    10
 *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    15
 * accompanied this code).
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    16
 *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    20
 *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    23
 * questions.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    24
 */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    25
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    26
package sun.security.ssl;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    27
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    28
import java.io.IOException;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    29
import java.nio.ByteBuffer;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    30
import java.security.cert.Extension;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    31
import java.util.ArrayList;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    32
import java.util.List;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    33
import java.util.Collections;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    34
import javax.net.ssl.SSLException;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    35
import sun.security.util.DerValue;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    36
import sun.security.util.DerInputStream;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    37
import sun.security.util.DerOutputStream;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    38
import sun.security.provider.certpath.ResponderId;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    39
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    40
/*
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    41
 * RFC6066 defines the TLS extension,"status_request" (type 0x5),
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    42
 * which allows the client to request that the server perform OCSP
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    43
 * on the client's behalf.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    44
 *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    45
 * The RFC defines an OCSPStatusRequest structure:
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    46
 *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    47
 *      struct {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    48
 *          ResponderID responder_id_list<0..2^16-1>;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    49
 *          Extensions  request_extensions;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    50
 *      } OCSPStatusRequest;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    51
 */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    52
final class OCSPStatusRequest implements StatusRequest {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    53
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    54
    private final List<ResponderId> responderIds;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    55
    private final List<Extension> extensions;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    56
    private int encodedLen;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    57
    private int ridListLen;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    58
    private int extListLen;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    59
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    60
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    61
     * Construct a default {@code OCSPStatusRequest} object with empty
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    62
     * responder ID and code extension list fields.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    63
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    64
    OCSPStatusRequest() {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    65
        responderIds = new ArrayList<>();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    66
        extensions = new ArrayList<>();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    67
        encodedLen = this.length();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    68
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    69
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    70
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    71
     * Construct an {@code OCSPStatusRequest} object using the provided
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    72
     *      {@code ResponderId} and {@code Extension} lists.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    73
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    74
     * @param respIds the list of {@code ResponderId} objects to be placed
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    75
     *      into the {@code OCSPStatusRequest}.  If the user wishes to place
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    76
     *      no {@code ResponderId} objects in the request, either an empty
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    77
     *      {@code List} or {@code null} is acceptable.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    78
     * @param exts the list of {@code Extension} objects to be placed into
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    79
     *      the {@code OCSPStatusRequest}  If the user wishes to place
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    80
     *      no {@code Extension} objects in the request, either an empty
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    81
     *      {@code List} or {@code null} is acceptable.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    82
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    83
    OCSPStatusRequest(List<ResponderId> respIds, List<Extension> exts) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    84
        responderIds = new ArrayList<>(respIds != null ? respIds :
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    85
                Collections.emptyList());
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    86
        extensions = new ArrayList<>(exts != null ? exts :
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    87
                Collections.emptyList());
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    88
        encodedLen = this.length();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    89
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    90
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    91
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    92
     * Construct an {@code OCSPStatusRequest} object from data read from
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    93
     * a {@code HandshakeInputStream}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    94
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    95
     * @param s the {@code HandshakeInputStream} providing the encoded data
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    96
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    97
     * @throws IOException if any decoding errors happen during object
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    98
     *      construction.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    99
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   100
    OCSPStatusRequest(HandshakeInStream in) throws IOException {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   101
        responderIds = new ArrayList<>();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   102
        extensions = new ArrayList<>();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   103
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   104
        int ridListBytesRemaining = in.getInt16();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   105
        while (ridListBytesRemaining != 0) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   106
            byte[] ridBytes = in.getBytes16();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   107
            responderIds.add(new ResponderId(ridBytes));
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   108
            ridListBytesRemaining -= (ridBytes.length + 2);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   109
            // Make sure that no individual responder ID's length caused an
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   110
            // overrun relative to the outer responder ID list length
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   111
            if (ridListBytesRemaining < 0) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   112
                throw new SSLException("Responder ID length overflow: " +
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   113
                        "current rid = " + ridBytes.length + ", remaining = " +
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   114
                        ridListBytesRemaining);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   115
            }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   116
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   117
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   118
        int extensionLength = in.getInt16();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   119
        if (extensionLength > 0) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   120
            byte[] extensionData = new byte[extensionLength];
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   121
            in.read(extensionData);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   122
            DerInputStream dis = new DerInputStream(extensionData);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   123
            DerValue[] extSeqContents = dis.getSequence(extensionData.length);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   124
            for (DerValue extDerVal : extSeqContents) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   125
                extensions.add(new sun.security.x509.Extension(extDerVal));
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   126
            }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   127
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   128
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   129
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   130
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   131
     * Construct an {@code OCSPStatusRequest} from its encoded form
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   132
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   133
     * @param requestBytes the status request extension bytes
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   134
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   135
     * @throws IOException if any error occurs during decoding
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   136
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   137
    OCSPStatusRequest(byte[] requestBytes) throws IOException {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   138
        responderIds = new ArrayList<>();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   139
        extensions = new ArrayList<>();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   140
        ByteBuffer reqBuf = ByteBuffer.wrap(requestBytes);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   141
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   142
        // Get the ResponderId list length
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   143
        encodedLen = requestBytes.length;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   144
        ridListLen = Short.toUnsignedInt(reqBuf.getShort());
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   145
        int endOfRidList = reqBuf.position() + ridListLen;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   146
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   147
        // The end position of the ResponderId list in the ByteBuffer
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   148
        // should be at least 2 less than the end of the buffer.  This
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   149
        // 2 byte defecit is the minimum length required to encode a
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   150
        // zero-length extensions segment.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   151
        if (reqBuf.limit() - endOfRidList < 2) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   152
            throw new SSLException
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   153
                ("ResponderId List length exceeds provided buffer - Len: "
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   154
                 + ridListLen + ", Buffer: " + reqBuf.remaining());
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   155
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   156
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   157
        while (reqBuf.position() < endOfRidList) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   158
            int ridLength = Short.toUnsignedInt(reqBuf.getShort());
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   159
            // Make sure an individual ResponderId length doesn't
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   160
            // run past the end of the ResponderId list portion of the
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   161
            // provided buffer.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   162
            if (reqBuf.position() + ridLength > endOfRidList) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   163
                throw new SSLException
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   164
                    ("ResponderId length exceeds list length - Off: "
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   165
                     + reqBuf.position() + ", Length: " + ridLength
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   166
                     + ", End offset: " + endOfRidList);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   167
            }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   168
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   169
            // Consume/add the ResponderId
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   170
            if (ridLength > 0) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   171
                byte[] ridData = new byte[ridLength];
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   172
                reqBuf.get(ridData);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   173
                responderIds.add(new ResponderId(ridData));
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   174
            }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   175
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   176
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   177
        // Get the Extensions length
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   178
        int extensionsLen = Short.toUnsignedInt(reqBuf.getShort());
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   179
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   180
        // The end of the extensions should also be the end of the
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   181
        // encoded OCSPStatusRequest
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   182
        if (extensionsLen != reqBuf.remaining()) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   183
            throw new SSLException("Incorrect extensions length: Read "
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   184
                    + extensionsLen + ", Data length: " + reqBuf.remaining());
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   185
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   186
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   187
        // Extensions are a SEQUENCE of Extension
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   188
        if (extensionsLen > 0) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   189
            byte[] extensionData = new byte[extensionsLen];
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   190
            reqBuf.get(extensionData);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   191
            DerInputStream dis = new DerInputStream(extensionData);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   192
            DerValue[] extSeqContents = dis.getSequence(extensionData.length);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   193
            for (DerValue extDerVal : extSeqContents) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   194
                extensions.add(new sun.security.x509.Extension(extDerVal));
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   195
            }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   196
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   197
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   198
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   199
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   200
     * Obtain the length of the {@code OCSPStatusRequest} object in its
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   201
     *      encoded form
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   202
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   203
     * @return the length of the {@code OCSPStatusRequest} object in its
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   204
     *      encoded form
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   205
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   206
    @Override
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   207
    public int length() {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   208
        // If we've previously calculated encodedLen simply return it
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   209
        if (encodedLen != 0) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   210
            return encodedLen;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   211
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   212
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   213
        ridListLen = 0;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   214
        for (ResponderId rid : responderIds) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   215
            ridListLen += rid.length() + 2;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   216
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   217
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   218
        extListLen = 0;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   219
        if (!extensions.isEmpty()) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   220
            try {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   221
                DerOutputStream extSequence = new DerOutputStream();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   222
                DerOutputStream extEncoding = new DerOutputStream();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   223
                for (Extension ext : extensions) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   224
                    ext.encode(extEncoding);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   225
                }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   226
                extSequence.write(DerValue.tag_Sequence, extEncoding);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   227
                extListLen = extSequence.size();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   228
            } catch (IOException ioe) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   229
                // Not sure what to do here
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   230
            }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   231
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   232
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   233
        // Total length is the responder ID list length and extensions length
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   234
        // plus each lists' 2-byte length fields.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   235
        encodedLen = ridListLen + extListLen + 4;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   236
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   237
        return encodedLen;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   238
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   239
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   240
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   241
     * Send the encoded {@code OCSPStatusRequest} out through the provided
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   242
     *      {@code HandshakeOutputStream}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   243
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   244
     * @param s the {@code HandshakeOutputStream} on which to send the encoded
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   245
     *      data
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   246
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   247
     * @throws IOException if any encoding errors occur
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   248
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   249
    @Override
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   250
    public void send(HandshakeOutStream s) throws IOException {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   251
        s.putInt16(ridListLen);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   252
        for (ResponderId rid : responderIds) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   253
            s.putBytes16(rid.getEncoded());
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   254
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   255
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   256
        DerOutputStream seqOut = new DerOutputStream();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   257
        DerOutputStream extBytes = new DerOutputStream();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   258
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   259
        if (extensions.size() > 0) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   260
            for (Extension ext : extensions) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   261
                ext.encode(extBytes);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   262
            }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   263
            seqOut.write(DerValue.tag_Sequence, extBytes);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   264
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   265
        s.putBytes16(seqOut.toByteArray());
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   266
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   267
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   268
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   269
     * Determine if a provided {@code OCSPStatusRequest} objects is equal to
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   270
     *      this one.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   271
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   272
     * @param obj an {@code OCSPStatusRequest} object to be compared against
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   273
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   274
     * @return {@code true} if the objects are equal, {@code false} otherwise.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   275
     *      Equivalence is established if the lists of responder IDs and
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   276
     *      extensions between the two objects are also equal.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   277
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   278
    @Override
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   279
    public boolean equals(Object obj) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   280
        if (obj == null) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   281
            return false;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   282
        } else if (this == obj) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   283
            return true;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   284
        } else if (obj instanceof OCSPStatusRequest) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   285
            OCSPStatusRequest respObj = (OCSPStatusRequest)obj;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   286
            return responderIds.equals(respObj.getResponderIds()) &&
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   287
                extensions.equals(respObj.getExtensions());
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   288
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   289
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   290
        return false;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   291
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   292
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   293
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   294
     * Returns the hash code value for this {@code OCSPStatusRequest}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   295
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   296
     * @return the hash code value for this {@code OCSPStatusRequest}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   297
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   298
    @Override
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   299
    public int hashCode() {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   300
        int result = 17;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   301
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   302
        result = 31 * result + responderIds.hashCode();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   303
        result = 31 * result + extensions.hashCode();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   304
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   305
        return result;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   306
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   307
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   308
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   309
     * Create a string representation of this {@code OCSPStatusRequest}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   310
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   311
     * @return a string representation of this {@code OCSPStatusRequest}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   312
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   313
    @Override
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   314
    public String toString() {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   315
        StringBuilder sb = new StringBuilder();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   316
        sb.append("OCSPStatusRequest\n");
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   317
        sb.append("    ResponderIds:");
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   318
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   319
        if (responderIds.isEmpty()) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   320
            sb.append(" <EMPTY>");
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   321
        } else {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   322
            for (ResponderId rid : responderIds) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   323
                sb.append("\n    ").append(rid.toString());
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   324
            }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   325
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   326
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   327
        sb.append("\n").append("    Extensions:");
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   328
        if (extensions.isEmpty()) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   329
            sb.append(" <EMPTY>");
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   330
        } else {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   331
            for (Extension ext : extensions) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   332
                sb.append("\n    ").append(ext.toString());
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   333
            }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   334
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   335
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   336
        return sb.toString();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   337
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   338
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   339
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   340
     * Get the list of {@code ResponderId} objects for this
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   341
     *      {@code OCSPStatusRequest}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   342
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   343
     * @return an unmodifiable {@code List} of {@code ResponderId} objects
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   344
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   345
    List<ResponderId> getResponderIds() {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   346
        return Collections.unmodifiableList(responderIds);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   347
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   348
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   349
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   350
     * Get the list of {@code Extension} objects for this
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   351
     *      {@code OCSPStatusRequest}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   352
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   353
     * @return an unmodifiable {@code List} of {@code Extension} objects
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   354
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   355
    List<Extension> getExtensions() {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   356
        return Collections.unmodifiableList(extensions);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   357
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   358
}