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.juneau.http.response; 018 019import static org.apache.juneau.http.response.Continue.*; 020 021import java.net.*; 022import java.util.*; 023 024import org.apache.http.*; 025import org.apache.http.Header; 026import org.apache.juneau.annotation.*; 027import org.apache.juneau.http.*; 028import org.apache.juneau.http.annotation.*; 029import org.apache.juneau.http.header.*; 030import org.apache.juneau.internal.*; 031 032/** 033 * Represents an <c>HTTP 100 Continue</c> response. 034 * 035 * <p> 036 * The server has received the request headers and the client should proceed to send the request body (in the case of a request for which a body needs to be sent; for example, a POST request). 037 * Sending a large request body to a server after a request has been rejected for inappropriate headers would be inefficient. 038 * To have a server check the request's headers, a client must send Expect: 100-continue as a header in its initial request and receive a 100 Continue status code in response before sending the body. 039 * If the client receives an error code such as 403 (Forbidden) or 405 (Method Not Allowed) then it shouldn't send the request's body. 040 * The response 417 Expectation Failed indicates that the request should be repeated without the Expect header as it indicates that the server doesn't support expectations (this is the case, for example, of HTTP/1.0 servers). 041 * 042 * <h5 class='section'>See Also:</h5><ul> 043 * <li class='link'><a class="doclink" href="https://juneau.apache.org/docs/topics/JuneauRestCommonBasics">juneau-rest-common Basics</a> 044 * </ul> 045 */ 046@Response 047@StatusCode(STATUS_CODE) 048@Schema(description=REASON_PHRASE) 049public class Continue extends BasicHttpResponse { 050 051 /** HTTP status code */ 052 public static final int STATUS_CODE = 100; 053 054 /** Reason phrase */ 055 public static final String REASON_PHRASE = "Continue"; 056 057 /** Default status line */ 058 private static final BasicStatusLine STATUS_LINE = BasicStatusLine.create(STATUS_CODE, REASON_PHRASE); 059 060 /** Default unmodifiable instance */ 061 public static final Continue INSTANCE = new Continue().setUnmodifiable(); 062 063 /** 064 * Constructor. 065 */ 066 public Continue() { 067 super(STATUS_LINE); 068 } 069 070 /** 071 * Copy constructor. 072 * 073 * @param copyFrom The bean to copy from. 074 */ 075 public Continue(Continue copyFrom) { 076 super(copyFrom); 077 } 078 079 /** 080 * Constructor. 081 * 082 * <p> 083 * This is the constructor used when parsing an HTTP response. 084 * 085 * @param response The HTTP response to copy from. Must not be <jk>null</jk>. 086 * @throws AssertionError If HTTP response status code does not match what was expected. 087 */ 088 public Continue(HttpResponse response) { 089 super(response); 090 assertStatusCode(response); 091 } 092 093 /** 094 * Creates a builder for this class initialized with the contents of this bean. 095 * 096 * @return A new builder bean. 097 */ 098 public Continue copy() { 099 return new Continue(this); 100 } 101 @Override /* Overridden from BasicHttpResponse */ 102 public Continue setContent(String value) { 103 super.setContent(value); 104 return this; 105 } 106 107 @Override /* Overridden from BasicHttpResponse */ 108 public Continue setContent(HttpEntity value) { 109 super.setContent(value); 110 return this; 111 } 112 113 @Override /* Overridden from BasicHttpResponse */ 114 public Continue setHeader2(Header value) { 115 super.setHeader2(value); 116 return this; 117 } 118 119 @Override /* Overridden from BasicHttpResponse */ 120 public Continue setHeader2(String name, String value) { 121 super.setHeader2(name, value); 122 return this; 123 } 124 125 @Override /* Overridden from BasicHttpResponse */ 126 public Continue setHeaders(List<Header> values) { 127 super.setHeaders(values); 128 return this; 129 } 130 131 @Override /* Overridden from BasicHttpResponse */ 132 public Continue setHeaders(HeaderList value) { 133 super.setHeaders(value); 134 return this; 135 } 136 137 @Override /* Overridden from BasicHttpResponse */ 138 public Continue setHeaders2(Header...values) { 139 super.setHeaders2(values); 140 return this; 141 } 142 143 @Override /* Overridden from BasicHttpResponse */ 144 public Continue setLocale2(Locale value) { 145 super.setLocale2(value); 146 return this; 147 } 148 149 @Override /* Overridden from BasicHttpResponse */ 150 public Continue setLocation(String value) { 151 super.setLocation(value); 152 return this; 153 } 154 155 @Override /* Overridden from BasicHttpResponse */ 156 public Continue setLocation(URI value) { 157 super.setLocation(value); 158 return this; 159 } 160 161 @Override /* Overridden from BasicHttpResponse */ 162 public Continue setProtocolVersion(ProtocolVersion value) { 163 super.setProtocolVersion(value); 164 return this; 165 } 166 167 @Override /* Overridden from BasicHttpResponse */ 168 public Continue setReasonPhrase2(String value) { 169 super.setReasonPhrase2(value); 170 return this; 171 } 172 173 @Override /* Overridden from BasicHttpResponse */ 174 public Continue setReasonPhraseCatalog(ReasonPhraseCatalog value) { 175 super.setReasonPhraseCatalog(value); 176 return this; 177 } 178 179 @Override /* Overridden from BasicHttpResponse */ 180 public Continue setStatusCode2(int value) { 181 super.setStatusCode2(value); 182 return this; 183 } 184 185 @Override /* Overridden from BasicHttpResponse */ 186 public Continue setStatusLine(BasicStatusLine value) { 187 super.setStatusLine(value); 188 return this; 189 } 190 191 @Override /* Overridden from BasicHttpResponse */ 192 public Continue setUnmodifiable() { 193 super.setUnmodifiable(); 194 return this; 195 } 196}