| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296 | /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- *//* ***** BEGIN LICENSE BLOCK ***** * Version: MPL 1.1/GPL 2.0/LGPL 2.1 * * The contents of this file are subject to the Mozilla Public License Version * 1.1 (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.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * The Original Code is Mozilla. * * The Initial Developer of the Original Code is * Netscape Communications. * Portions created by the Initial Developer are Copyright (C) 2001 * the Initial Developer. All Rights Reserved. * * Contributor(s): *   Gagan Saksena <[email protected]> (original author) *   Darin Fisher <[email protected]> * * Alternatively, the contents of this file may be used under the terms of * either the GNU General Public License Version 2 or later (the "GPL"), or * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), * in which case the provisions of the GPL or the LGPL are applicable instead * of those above. If you wish to allow use of your version of this file only * under the terms of either the GPL or the LGPL, and not to allow others to * use your version of this file under the terms of the MPL, indicate your * decision by deleting the provisions above and replace them with the notice * and other provisions required by the GPL or the LGPL. If you do not delete * the provisions above, a recipient may use your version of this file under * the terms of any one of the MPL, the GPL or the LGPL. * * ***** END LICENSE BLOCK ***** */#include "nsIChannel.idl"interface nsIHttpHeaderVisitor;/** * nsIHttpChannel * * This interface allows for the modification of HTTP request parameters and * the inspection of the resulting HTTP response status and headers when they * become available. * * @status FROZEN */[scriptable, uuid(9277fe09-f0cc-4cd9-bbce-581dd94b0260)]interface nsIHttpChannel : nsIChannel{    /**************************************************************************     * REQUEST CONFIGURATION     *     * Modifying request parameters after asyncOpen has been called is an error.     */    /**     * Set/get the HTTP request method (default is "GET").  Setter is case     * insensitive; getter returns an uppercase string.     *     * This attribute may only be set before the channel is opened.     *     * NOTE: The data for a "POST" or "PUT" request can be configured via     * nsIUploadChannel; however, after setting the upload data, it may be     * necessary to set the request method explicitly.  The documentation     * for nsIUploadChannel has further details.     *     * @throws NS_ERROR_IN_PROGRESS if set after the channel has been opened.     */    attribute ACString requestMethod;    /**     * Get/set the HTTP referrer URI.  This is the address (URI) of the     * resource from which this channel's URI was obtained (see RFC2616 section     * 14.36).     *      * This attribute may only be set before the channel is opened.     *     * NOTE: The channel may silently refuse to set the Referer header if the     * URI does not pass certain security checks (e.g., a "https://" URL will     * never be sent as the referrer for a plaintext HTTP request).  The     * implementation is not required to throw an exception when the referrer     * URI is rejected.     *     * @throws NS_ERROR_IN_PROGRESS if set after the channel has been opened.     */    attribute nsIURI referrer;    /**     * Get the value of a particular request header.     *     * @param aHeader     *        The case-insensitive name of the request header to query (e.g.,     *        "Cache-Control").     *     * @return the value of the request header.     * @throws NS_ERROR_NOT_AVAILABLE if the header is not set.     */    ACString getRequestHeader(in ACString aHeader);    /**     * Set the value of a particular request header.     *     * This method allows, for example, the cookies module to add "Cookie"     * headers to the outgoing HTTP request.     *     * This method may only be called before the channel is opened.     *     * @param aHeader     *        The case-insensitive name of the request header to set (e.g.,     *        "Cookie").     * @param aValue     *        The request header value to set (e.g., "X=1").     * @param aMerge     *        If true, the new header value will be merged with any existing     *        values for the specified header.  This flag is ignored if the     *        specified header does not support merging (e.g., the "Content-     *        Type" header can only have one value).  The list of headers for     *        which this flag is ignored is an implementation detail.  If this     *        flag is false, then the header value will be replaced with the     *        contents of |aValue|.     *     * If aValue is empty and aMerge is false, the header will be cleared.     *     * @throws NS_ERROR_IN_PROGRESS if called after the channel has been     *         opened.     */    void setRequestHeader(in ACString aHeader,                          in ACString aValue,                          in boolean aMerge);    /**     * Call this method to visit all request headers.  Calling setRequestHeader     * while visiting request headers has undefined behavior.  Don't do it!     *     * @param aVisitor     *        the header visitor instance.     */    void visitRequestHeaders(in nsIHttpHeaderVisitor aVisitor);    /**     * This attribute is a hint to the channel to indicate whether or not     * the underlying HTTP transaction should be allowed to be pipelined     * with other transactions.  This should be set to FALSE, for example,     * if the application knows that the corresponding document is likely     * to be very large.     *     * This attribute is true by default, though other factors may prevent     * pipelining.     *     * This attribute may only be set before the channel is opened.     *     * @throws NS_ERROR_FAILURE if set after the channel has been opened.     */    attribute boolean allowPipelining;    /**     * This attribute specifies the number of redirects this channel is allowed     * to make.  If zero, the channel will fail to redirect and will generate     * a NS_ERROR_REDIRECT_LOOP failure status.     *     * NOTE: An HTTP redirect results in a new channel being created.  If the     * new channel supports nsIHttpChannel, then it will be assigned a value     * to its |redirectionLimit| attribute one less than the value of the     * redirected channel's |redirectionLimit| attribute.  The initial value     * for this attribute may be a configurable preference (depending on the     * implementation).     */    attribute unsigned long redirectionLimit;    /**************************************************************************     * RESPONSE INFO     *     * Accessing response info before the onStartRequest event is an error.     */    /**     * Get the HTTP response code (e.g., 200).     *     * @throws NS_ERROR_NOT_AVAILABLE if called before the response     *         has been received (before onStartRequest).     */    readonly attribute unsigned long responseStatus;    /**     * Get the HTTP response status text (e.g., "OK").     *     * NOTE: This returns the raw (possibly 8-bit) text from the server.  There     * are no assumptions made about the charset of the returned text.  You     * have been warned!     *     * @throws NS_ERROR_NOT_AVAILABLE if called before the response     *         has been received (before onStartRequest).     */    readonly attribute ACString responseStatusText;    /**     * Returns true if the HTTP response code indicates success.  The value of     * nsIRequest::status will be NS_OK even when processing a 404 response     * because a 404 response may include a message body that (in some cases)     * should be shown to the user.     *     * Use this attribute to distinguish server error pages from normal pages,     * instead of comparing the response status manually against the set of     * valid response codes, if that is required by your application.     *     * @throws NS_ERROR_NOT_AVAILABLE if called before the response     *         has been received (before onStartRequest).     */    readonly attribute boolean requestSucceeded;    /**     * Get the value of a particular response header.     *     * @param aHeader     *        The case-insensitive name of the response header to query (e.g.,     *        "Set-Cookie").     *     * @return the value of the response header.     *     * @throws NS_ERROR_NOT_AVAILABLE if called before the response     *         has been received (before onStartRequest) or if the header is     *         not set in the response.     */    ACString getResponseHeader(in ACString header);    /**     * Set the value of a particular response header.     *     * This method allows, for example, the HTML content sink to inform the HTTP     * channel about HTTP-EQUIV headers found in HTML <META> tags.     *     * @param aHeader     *        The case-insensitive name of the response header to set (e.g.,     *        "Cache-control").     * @param aValue     *        The response header value to set (e.g., "no-cache").     * @param aMerge     *        If true, the new header value will be merged with any existing     *        values for the specified header.  This flag is ignored if the     *        specified header does not support merging (e.g., the "Content-     *        Type" header can only have one value).  The list of headers for     *        which this flag is ignored is an implementation detail.  If this     *        flag is false, then the header value will be replaced with the     *        contents of |aValue|.     *     * If aValue is empty and aMerge is false, the header will be cleared.     *      * @throws NS_ERROR_NOT_AVAILABLE if called before the response     *         has been received (before onStartRequest).     * @throws NS_ERROR_ILLEGAL_VALUE if changing the value of this response     *         header is not allowed.     */    void setResponseHeader(in ACString header,                           in ACString value,                           in boolean merge);    /**     * Call this method to visit all response headers.  Calling     * setResponseHeader while visiting response headers has undefined     * behavior.  Don't do it!     *     * @param aVisitor     *        the header visitor instance.     *     * @throws NS_ERROR_NOT_AVAILABLE if called before the response     *         has been received (before onStartRequest).     */    void visitResponseHeaders(in nsIHttpHeaderVisitor aVisitor);    /**     * Returns true if the server sent a "Cache-Control: no-store" response     * header.     *     * @throws NS_ERROR_NOT_AVAILABLE if called before the response     *         has been received (before onStartRequest).     */    boolean isNoStoreResponse();    /**     * Returns true if the server sent the equivalent of a "Cache-control:     * no-cache" response header.  Equivalent response headers include:     * "Pragma: no-cache", "Expires: 0", and "Expires" with a date value     * in the past relative to the value of the "Date" header.     *     * @throws NS_ERROR_NOT_AVAILABLE if called before the response     *         has been received (before onStartRequest).     */    boolean isNoCacheResponse();};
 |