1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /* ***** BEGIN LICENSE BLOCK *****
3 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
5 * The contents of this file are subject to the Mozilla Public License Version
6 * 1.1 (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 * http://www.mozilla.org/MPL/
10 * Software distributed under the License is distributed on an "AS IS" basis,
11 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12 * for the specific language governing rights and limitations under the
15 * The Original Code is Mozilla.
17 * The Initial Developer of the Original Code is
18 * Netscape Communications.
19 * Portions created by the Initial Developer are Copyright (C) 2001
20 * the Initial Developer. All Rights Reserved.
23 * Darin Fisher <darin@netscape.com> (original author)
25 * Alternatively, the contents of this file may be used under the terms of
26 * either the GNU General Public License Version 2 or later (the "GPL"), or
27 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
28 * in which case the provisions of the GPL or the LGPL are applicable instead
29 * of those above. If you wish to allow use of your version of this file only
30 * under the terms of either the GPL or the LGPL, and not to allow others to
31 * use your version of this file under the terms of the MPL, indicate your
32 * decision by deleting the provisions above and replace them with the notice
33 * and other provisions required by the GPL or the LGPL. If you do not delete
34 * the provisions above, a recipient may use your version of this file under
35 * the terms of any one of the MPL, the GPL or the LGPL.
37 * ***** END LICENSE BLOCK ***** */
39 #ifndef nsHttpResponseHead_h__
40 #define nsHttpResponseHead_h__
42 #include "nsHttpHeaderArray.h"
46 //-----------------------------------------------------------------------------
47 // nsHttpResponseHead represents the status line and headers from an HTTP
49 //-----------------------------------------------------------------------------
51 class nsHttpResponseHead
54 nsHttpResponseHead() : mVersion(NS_HTTP_VERSION_1_1
)
56 , mContentLength(LL_MAXUINT
)
57 , mCacheControlNoStore(PR_FALSE
)
58 , mCacheControlNoCache(PR_FALSE
)
59 , mCacheControlPublic(PR_FALSE
)
60 , mPragmaNoCache(PR_FALSE
) {}
66 nsHttpHeaderArray
&Headers() { return mHeaders
; }
67 nsHttpVersion
Version() { return mVersion
; }
68 PRUint16
Status() { return mStatus
; }
69 const nsAFlatCString
&StatusText() { return mStatusText
; }
70 PRInt64
ContentLength() { return mContentLength
; }
71 const nsAFlatCString
&ContentType() { return mContentType
; }
72 const nsAFlatCString
&ContentCharset() { return mContentCharset
; }
73 PRBool
NoStore() { return mCacheControlNoStore
; }
74 PRBool
NoCache() { return (mCacheControlNoCache
|| mPragmaNoCache
); }
75 PRBool
CacheControlPublic() { return mCacheControlPublic
; }
77 * Full length of the entity. For byte-range requests, this may be larger
78 * than ContentLength(), which will only represent the requested part of the
81 PRInt64
TotalEntitySize();
83 const char *PeekHeader(nsHttpAtom h
) { return mHeaders
.PeekHeader(h
); }
84 nsresult
SetHeader(nsHttpAtom h
, const nsACString
&v
, PRBool m
=PR_FALSE
);
85 nsresult
GetHeader(nsHttpAtom h
, nsACString
&v
) { return mHeaders
.GetHeader(h
, v
); }
86 void ClearHeader(nsHttpAtom h
) { mHeaders
.ClearHeader(h
); }
87 void ClearHeaders() { mHeaders
.Clear(); }
89 const char *FindHeaderValue(nsHttpAtom h
, const char *v
) { return mHeaders
.FindHeaderValue(h
, v
); }
90 PRBool
HasHeaderValue(nsHttpAtom h
, const char *v
) { return mHeaders
.HasHeaderValue(h
, v
); }
92 void SetContentType(const nsACString
&s
) { mContentType
= s
; }
93 void SetContentCharset(const nsACString
&s
) { mContentCharset
= s
; }
94 void SetContentLength(PRInt64
);
96 // write out the response status line and headers as a single text block,
97 // optionally pruning out transient headers (ie. headers that only make
98 // sense the first time the response is handled).
99 void Flatten(nsACString
&, PRBool pruneTransients
);
101 // parse flattened response head. block must be null terminated. parsing is
103 nsresult
Parse(char *block
);
105 // parse the status line. line must be null terminated.
106 void ParseStatusLine(char *line
);
108 // parse a header line. line must be null terminated. parsing is destructive.
109 void ParseHeaderLine(char *line
);
111 // cache validation support methods
112 nsresult
ComputeFreshnessLifetime(PRUint32
*);
113 nsresult
ComputeCurrentAge(PRUint32 now
, PRUint32 requestTime
, PRUint32
*result
);
114 PRBool
MustValidate();
115 PRBool
MustValidateIfExpired();
117 // returns true if the server appears to support byte range requests.
118 PRBool
IsResumable();
120 // returns true if the Expires header has a value in the past relative to the
121 // value of the Date header.
122 PRBool
ExpiresInPast();
125 nsresult
UpdateHeaders(nsHttpHeaderArray
&headers
);
127 // reset the response head to it's initial state
130 // these return failure if the header does not exist.
131 nsresult
ParseDateHeader(nsHttpAtom header
, PRUint32
*result
);
132 nsresult
GetAgeValue(PRUint32
*result
);
133 nsresult
GetMaxAgeValue(PRUint32
*result
);
134 nsresult
GetDateValue(PRUint32
*result
) { return ParseDateHeader(nsHttp::Date
, result
); }
135 nsresult
GetExpiresValue(PRUint32
*result
);
136 nsresult
GetLastModifiedValue(PRUint32
*result
) { return ParseDateHeader(nsHttp::Last_Modified
, result
); }
139 void ParseVersion(const char *);
140 void ParseCacheControl(const char *);
141 void ParsePragma(const char *);
144 nsHttpHeaderArray mHeaders
;
145 nsHttpVersion mVersion
;
147 nsCString mStatusText
;
148 PRInt64 mContentLength
;
149 nsCString mContentType
;
150 nsCString mContentCharset
;
151 PRPackedBool mCacheControlNoStore
;
152 PRPackedBool mCacheControlNoCache
;
153 PRPackedBool mCacheControlPublic
;
154 PRPackedBool mPragmaNoCache
;
157 #endif // nsHttpResponseHead_h__