jdk/src/java.base/share/classes/sun/security/ssl/CertStatusReqListV2Extension.java
author ascarpino
Wed, 08 Feb 2017 12:08:28 -0800
changeset 43701 fe8c324ba97c
parent 32032 22badc53802f
permissions -rw-r--r--
8160655: Fix denyAfter and usage types for security properties Reviewed-by: mullan, xuelei
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.util.List;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    30
import java.util.Collections;
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.Objects;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    33
import javax.net.ssl.SSLException;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    34
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    35
/*
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    36
 * RFC6066 defines the TLS extension,"status_request" (type 0x5),
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    37
 * which allows the client to request that the server perform OCSP
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    38
 * on the client's behalf.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    39
 * The "extension data" field of this extension contains a
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    40
 * "CertificateStatusRequest" structure:
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    41
 *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    42
 *      struct {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    43
 *          CertificateStatusType status_type;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    44
 *          select (status_type) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    45
 *              case ocsp: OCSPStatusRequest;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    46
 *          } request;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    47
 *      } CertificateStatusRequest;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    48
 *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    49
 *      enum { ocsp(1), (255) } CertificateStatusType;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    50
 *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    51
 *      struct {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    52
 *          ResponderID responder_id_list<0..2^16-1>;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    53
 *          Extensions  request_extensions;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    54
 *      } OCSPStatusRequest;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    55
 *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    56
 *      opaque ResponderID<1..2^16-1>;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    57
 *      opaque Extensions<0..2^16-1>;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    58
 */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    59
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    60
final class CertStatusReqListV2Extension extends HelloExtension {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    61
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    62
    private final List<CertStatusReqItemV2> itemList;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    63
    private final int itemListLength;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    64
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    65
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    66
     * Construct a default {@code CertStatusReqListV2Extension}.  The default
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    67
     * object results in a status_request_v2 extension where the extension
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    68
     * data segment is zero-length.  This is used primarily in ServerHello
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    69
     * messages where the server asserts it can do RFC 6961 status stapling.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    70
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    71
    CertStatusReqListV2Extension() {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    72
        super(ExtensionType.EXT_STATUS_REQUEST_V2);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    73
        itemList = Collections.emptyList();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    74
        itemListLength = 0;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    75
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    76
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    77
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    78
     * Construct a {@code CertStatusReqListV2Extension} from a provided list
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    79
     *      of {@code CertStatusReqItemV2} objects.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    80
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    81
     * @param reqList a {@code List} containing one or more
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    82
     *      {@code CertStatusReqItemV2} objects to be included in this TLS
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    83
     *      Hello extension.  Passing an empty list will result in the encoded
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    84
     *      extension having a zero-length extension_data segment, and is
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    85
     *      the same as using the default constructor.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    86
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    87
     * @throws NullPointerException if reqList is {@code null}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    88
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    89
    CertStatusReqListV2Extension(List<CertStatusReqItemV2> reqList) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    90
        super(ExtensionType.EXT_STATUS_REQUEST_V2);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    91
        Objects.requireNonNull(reqList,
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    92
                "Unallowed null value for certificate_status_req_list");
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    93
        itemList = Collections.unmodifiableList(new ArrayList<>(reqList));
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    94
        itemListLength = calculateListLength();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    95
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    96
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    97
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    98
     *  Construct the {@code CertStatusReqListV2Extension} object from data
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
    99
     *      read from a {@code HandshakeInputStream}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   100
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   101
     * @param s the {@code HandshakeInputStream} providing the encoded data
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   102
     * @param len the length of the extension data
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   103
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   104
     * @throws IOException if any decoding errors happen during object
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   105
     *      construction.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   106
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   107
    CertStatusReqListV2Extension(HandshakeInStream s, int len)
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   108
            throws IOException {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   109
        super(ExtensionType.EXT_STATUS_REQUEST_V2);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   110
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   111
        if (len <= 0) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   112
            // Handle the empty extension data case (from a ServerHello)
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   113
            itemList = Collections.emptyList();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   114
            itemListLength = 0;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   115
        } else {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   116
            List<CertStatusReqItemV2> workingList = new ArrayList<>();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   117
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   118
            itemListLength = s.getInt16();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   119
            if (itemListLength <= 0) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   120
                throw new SSLException("certificate_status_req_list length " +
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   121
                        "must be greater than zero (received length: " +
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   122
                        itemListLength + ")");
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   123
            }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   124
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   125
            int totalRead = 0;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   126
            CertStatusReqItemV2 reqItem;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   127
            do {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   128
                reqItem = new CertStatusReqItemV2(s);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   129
                totalRead += reqItem.length();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   130
            } while (workingList.add(reqItem) && totalRead < itemListLength);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   131
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   132
            // If for some reason the add returns false, we may not have read
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   133
            // all the necessary bytes from the stream.  Check this and throw
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   134
            // an exception if we terminated the loop early.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   135
            if (totalRead != itemListLength) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   136
                throw new SSLException("Not all certificate_status_req_list " +
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   137
                        "bytes were read: expected " + itemListLength +
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   138
                        ", read " + totalRead);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   139
            }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   140
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   141
            itemList = Collections.unmodifiableList(workingList);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   142
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   143
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   144
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   145
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   146
     * Get the list of {@code CertStatusReqItemV2} objects for this extension
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   147
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   148
     * @return an unmodifiable list of {@code CertStatusReqItemV2} objects
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   149
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   150
    List<CertStatusReqItemV2> getRequestItems() {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   151
        return itemList;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   152
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   153
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   154
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   155
     * Return the length of the encoded extension, including extension type
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   156
     *      and extension length fields.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   157
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   158
     * @return the length in bytes, including the extension type and
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   159
     *      extension_data length.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   160
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   161
    @Override
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   162
    int length() {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   163
        return (itemList.isEmpty() ? 4 : itemListLength + 6);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   164
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   165
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   166
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   167
     * Send the encoded {@code CertStatusReqListV2Extension} through a
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   168
     *      {@code HandshakeOutputStream}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   169
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   170
     * @param s the {@code HandshakeOutputStream} used to send the encoded data
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   171
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   172
     * @throws IOException if any errors occur during the encoding process
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   173
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   174
    @Override
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   175
    void send(HandshakeOutStream s) throws IOException {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   176
        s.putInt16(type.id);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   177
        s.putInt16(this.length() - 4);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   178
        if (itemListLength > 0) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   179
            s.putInt16(itemListLength);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   180
            for (CertStatusReqItemV2 item : itemList) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   181
                item.send(s);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   182
            }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   183
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   184
    }
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
     * Create a string representation of this
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   188
     *      {@code CertStatusReqListV2Extension}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   189
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   190
     * @return the string representation of this
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   191
     *      {@code CertStatusReqListV2Extension}
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   192
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   193
    @Override
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   194
    public String toString() {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   195
        StringBuilder sb = new StringBuilder("Extension ").append(type);
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   196
        for (CertStatusReqItemV2 item : itemList) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   197
            sb.append("\n").append(item);
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
        return sb.toString();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   201
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   202
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   203
    /**
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   204
     * Determine the length of the certificate_status_req_list field in
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   205
     * the status_request_v2 extension.
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   206
     *
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   207
     * @return the total encoded length of all items in the list, or 0 if the
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   208
     *      encapsulating extension_data is zero-length (from a ServerHello)
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   209
     */
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   210
    private int calculateListLength() {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   211
        int listLen = 0;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   212
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   213
        for (CertStatusReqItemV2 item : itemList) {
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   214
            listLen += item.length();
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   215
        }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   216
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   217
        return listLen;
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   218
    }
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   219
22badc53802f 8046321: OCSP Stapling for TLS
jnimeh
parents:
diff changeset
   220
}