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}